#4814 Improve the graphs of the stats tab
Merged 4 years ago by pingou. Opened 4 years ago by pingou.

file modified
+63 -1
@@ -1532,6 +1532,68 @@ 

      repo = _get_repo(repo, username, namespace)

      _check_issue_tracker(repo)

  

-     stats = pagure.lib.query.issues_history_stats(flask.g.session, repo)

+     stats = pagure.lib.query.issues_history_stats(

+         flask.g.session, repo, detailed=False

+     )

+     jsonout = flask.jsonify({"stats": stats})

+     return jsonout

+ 

+ 

+ @API.route("/<repo>/issues/history/detailed_stats")

+ @API.route("/<namespace>/<repo>/issues/history/detailed_stats")

+ @API.route("/fork/<username>/<repo>/issues/history/detailed_stats")

+ @API.route("/fork/<username>/<namespace>/<repo>/issues/history/detailed_stats")

+ @api_method

+ def api_view_issues_history_detailed_stats(

+     repo, username=None, namespace=None

+ ):

+     """

+     List project's detailed statistical issues history.

+     ---------------------------------------------------

+     Provides the number of opened issues over the last year of the

+     project.

+ 

+     ::

+ 

+         GET /api/0/<repo>/issues/history/detailed_stats

+         GET /api/0/<namespace>/<repo>/issues/history/detailed_stats

+ 

+     ::

+ 

+         GET /api/0/fork/<username>/<repo>/issues/history/detailed_stats

+         GET /api/0/fork/<username>/<namespace>/<repo>/issues/history/detailed_stats

+ 

+ 

+     Sample response

+     ^^^^^^^^^^^^^^^

+ 

+     ::

+         {

+           "stats": {

+             "2020-03-26T19:21:51.348451": {

+               "closed_ticket": 0,

+               "count": 0,

+               "open_ticket": 0

+             },

+             "2020-04-02T19:21:51.348451": {

+               "closed_ticket": 0,

+               "count": 0,

+               "open_ticket": 0

+             },

+             "2020-04-09T19:21:51.348451": {

+               "closed_ticket": 1,

+               "count": 0,

+               "open_ticket": 2

+             }

+           }

+         }

+ 

+     """  # noqa

+     repo = _get_repo(repo, username, namespace)

+     _check_issue_tracker(repo)

+ 

+     stats = pagure.lib.query.issues_history_stats(

+         flask.g.session, repo, detailed=True

+     )

      jsonout = flask.jsonify({"stats": stats})

      return jsonout

file modified
+54 -17
@@ -5652,7 +5652,7 @@ 

          session.add(repo)

  

  

- def issues_history_stats(session, project):

+ def issues_history_stats(session, project, detailed=False):

      """ Returns the number of opened issues on the specified project over

      the last 365 days

  
@@ -5660,38 +5660,75 @@ 

      :arg repo: model.Project object to get the issues stats about

  

      """

- 

-     # Some ticket got imported as closed but without a closed_at date, so

-     # let's ignore them all

-     to_ignore = (

+     tomorrow = datetime.datetime.utcnow() + datetime.timedelta(days=1)

+     current_open = (

          session.query(model.Issue)

          .filter(model.Issue.project_id == project.id)

-         .filter(model.Issue.closed_at == None)  # noqa

-         .filter(model.Issue.status == "Closed")

+         .filter(model.Issue.status == "Open")

          .count()

      )

  

+     # Check if the oldest ticket with a closed_at date is older than a year

+     # ago, if it is, we will assume that all tickets that were closed last year

+     # have a closed_at date set.

+     oldest_closed = (

+         session.query(model.Issue)

+         .filter(model.Issue.project_id == project.id)

+         .filter(model.Issue.closed_at != None)  # noqa

+         .order_by(sqlalchemy.asc(model.Issue.closed_at))

+         .first()

+     )

+     a_year_ago = tomorrow - datetime.timedelta(days=(53 * 7))

+     if oldest_closed and oldest_closed.closed_at < a_year_ago:

+         to_ignore = 0

+     else:

+         # Some ticket got imported as closed but without a closed_at date, so

+         # let's ignore them all

+         to_ignore = (

+             session.query(model.Issue)

+             .filter(model.Issue.project_id == project.id)

+             .filter(model.Issue.closed_at == None)  # noqa

+             .filter(model.Issue.status == "Closed")

+             .count()

+         )

+ 

      # For each week from tomorrow, get the number of open tickets

-     tomorrow = datetime.datetime.utcnow() + datetime.timedelta(days=1)

+ 

      output = {}

      for week in range(53):

-         start = tomorrow - datetime.timedelta(days=(week * 7))

+         end = tomorrow - datetime.timedelta(days=(week * 7))

+         start = end - datetime.timedelta(days=7)

          closed_ticket = (

              session.query(model.Issue)

              .filter(model.Issue.project_id == project.id)

              .filter(model.Issue.closed_at >= start)

-             .filter(model.Issue.date_created <= start)

-         )

-         open_ticket = (

+             .filter(model.Issue.closed_at < end)

+         ).count()

+         query_open = (

              session.query(model.Issue)

              .filter(model.Issue.project_id == project.id)

-             .filter(model.Issue.status == "Open")

-             .filter(model.Issue.date_created <= start)

-         )

-         cnt = open_ticket.count() + closed_ticket.count() - to_ignore

+             .filter(model.Issue.date_created >= start)

+             .filter(model.Issue.date_created < end)

+         )

+         # For backward compatibility

+         if detailed is False:

+             query_open = query_open.filter(model.Issue.status == "Open")

+         open_ticket = query_open.count()

+         cnt = open_ticket + closed_ticket - to_ignore

+         current_open = current_open - open_ticket + closed_ticket

+ 

+         if current_open < 0:

+             current_open = 0

          if cnt < 0:

              cnt = 0

-         output[start.isoformat()] = cnt

+         if detailed is False:

+             output[start.isoformat()] = cnt

+         else:

+             output[start.isoformat()] = {

+                 "open_ticket": open_ticket,

+                 "closed_ticket": closed_ticket,

+                 "count": current_open,

+             }

  

      return output

  

file modified
+139 -106
@@ -1,64 +1,103 @@ 

- function issues_history_stats_plot(url, _b, _s) {

-   var svg = d3.select("svg"),

-       margin = {top: 20, right: 20, bottom: 30, left: 50},

-       width = $('#stats').width() - margin.left - margin.right,

-       height = +svg.attr("height") - margin.top - margin.bottom,

-       g = svg.append("g").attr("transform", "translate(" + margin.left + "," + margin.top + ")");

- 

-   var parseTime = d3.timeParse("%Y-%m-%d");

- 

-   var x = d3.scaleTime()

-       .rangeRound([0, width]);

- 

-   var y = d3.scaleLinear()

-       .rangeRound([height, 0]);

- 

-   var area = d3.area()

-       .x(function(d) { return x(d.date); })

-       .y1(function(d) { return y(d.value); });

- 

-   function draw_graph(data) {

- 

-     x.domain(d3.extent(data, function(d) { return d.date; }));

-     y.domain([0, d3.max(data, function(d) { return d.value; })]);

-     area.y0(y(0));

- 

-     g.append("path")

-         .datum(data)

-         .attr("fill", "steelblue")

-         .attr("d", area);

- 

-     g.append("g")

-         .attr("transform", "translate(0," + height + ")")

-         .call(d3.axisBottom(x));

- 

-     g.append("g")

-         .call(d3.axisLeft(y))

-       .append("text")

-         .attr("fill", "#000")

-         .attr("transform", "rotate(-90)")

-         .attr("y", 6)

-         .attr("dy", "0.71em")

-         .attr("text-anchor", "end")

-         .text("Open Issues");

+ window.chartColors = {

+   red: 'rgb(255, 20, 100)',

+   orange: 'rgb(255, 159, 64)',

+   yellow: 'rgb(255, 205, 86)',

+   green: 'rgb(75, 192, 192)',

+   blue: 'rgb(54, 162, 235)',

+   purple: 'rgb(153, 102, 255)',

+   grey: 'rgb(201, 203, 207)'

+ };

+ 

+ 

+ function issues_history_stats_plot(data) {

+   $("#commiter_list").hide();

+   $(".commit_trend").hide();

+   var color = Chart.helpers.color;

+ 

+   var _open_tickets = [];

+   var _close_tickets = [];

+   var _total = []

+   var _lbl = []

+   for (var _d in data.stats) {

+     _lbl.push(_d.split('T', 1)[0]);

+     _open_tickets.push(data.stats[_d].open_ticket);

+     _close_tickets.push(data.stats[_d].closed_ticket);

+     _total.push(data.stats[_d].count);

    }

  

-   d3.json(url, function(d) {

-     var _out = [];

-     for (var _d in d.stats) {

-       var t = {};

-       t.date = parseTime(_d.split('T', 1)[0]);

-       t.value = d.stats[_d];

-       _out.push(t);

+   var barChartData = {

+     labels: _lbl,

+     datasets: [{

+       label: 'Tickets opened that week',

+       backgroundColor: color(window.chartColors.blue).alpha(0.5).rgbString(),

+       borderColor: window.chartColors.blue,

+       borderWidth: 1,

+       data: _open_tickets

+     }, {

+       label: 'Tickets closed that week',

+       backgroundColor: color(window.chartColors.red).alpha(0.5).rgbString(),

+       borderColor: window.chartColors.red,

+       borderWidth: 1,

+       data: _close_tickets

+     }]

+   };

+ 

+   var lineData = {

+     labels: _lbl,

+     datasets: [{

+       label: 'Tickets open (total)',

+       backgroundColor: color(window.chartColors.blue).alpha(0.5).rgbString(),

+       borderColor: window.chartColors.blue,

+       borderWidth: 1,

+       pointRadius: 0,

+       data: _total

+     }]

+   };

+ 

+   new Chart('total_issue_trend_graph', {

+     type: 'line',

+     data: lineData,

+     options: {

+       scales: {

+         yAxes: [{

+           stacked: true

+         }]

+       },

+       plugins: {

+         filler: {

+           propagate: true

+         },

+       },

+       title: {

+         display: true,

+         text: 'Evolution of the number of commits over the last year'

+       }

      }

-     draw_graph(_out);

-     _b.show();

-     _s.hide();

    });

+ 

+   new Chart("issue_trend_graph", {

+     type: 'bar',

+     data: barChartData,

+     options: {

+       responsive: true,

+       legend: {

+         position: 'top',

+       },

+       title: {

+         display: true,

+         text: 'Tickets opened and closed per week'

+       }

+     }

+   });

+ 

+   $("#data_stats_spinner").hide();

+   $(".issue_trend").show();

  }

  

  function show_commits_authors(data) {

-   var _b = $("#data_stats");

+   $(".commit_trend").hide();

+   $(".issue_trend").hide();

+   var _b = $("#commiter_list");

    var html = '<h2>Authors stats</h2><p> Since '

      + new Date(data.results[3]*1000) + ' there has been '

      + data.results[0] + ' commits found in this repo, from '
@@ -78,66 +117,60 @@ 

    }

    html += '</div>';

    _b.html(html);

+   $("#data_stats_spinner").hide();

    _b.show();

  }

  

  function show_commits_history(data) {

-   var _b = $("#data_stats");

- 

-   var parseTime = d3.timeParse("%Y-%m-%d");

+   $("#commiter_list").hide();

+   $(".issue_trend").hide();

  

-   var _out = data.results.map(function(x){

-     var t = {};

-     t.date = parseTime(x[0]);

-     t.value = x[1];

-     return t;

-   });

+   var color = Chart.helpers.color;

  

-   var svg = d3.select("svg"),

-       margin = {top: 20, right: 20, bottom: 30, left: 50},

-       width = $('#stats').width() - margin.left - margin.right,

-       height = +svg.attr("height") - margin.top - margin.bottom,

-       g = svg.append("g").attr(

-         "transform", "translate(" + margin.left + "," + margin.top + ")");

- 

-   var x = d3.scaleTime()

-       .rangeRound([0, width]);

- 

-   var y = d3.scaleLinear()

-       .rangeRound([height, 0]);

- 

-   var area = d3.area()

-       .x(function(d) { return x(d.date); })

-       .y1(function(d) { return y(d.value); });

- 

-   function draw_graph(data) {

- 

-     x.domain(d3.extent(data, function(d) { return d.date; }));

-     y.domain([0, d3.max(data, function(d) { return d.value; })]);

-     area.y0(y(0));

- 

-     g.append("path")

-         .datum(data)

-         .attr("fill", "steelblue")

-         .attr("d", area);

- 

-     g.append("g")

-         .attr("transform", "translate(0," + height + ")")

-         .call(d3.axisBottom(x));

- 

-     g.append("g")

-         .call(d3.axisLeft(y))

-       .append("text")

-         .attr("fill", "#000")

-         .attr("transform", "rotate(-90)")

-         .attr("y", 6)

-         .attr("dy", "0.71em")

-         .attr("text-anchor", "end")

-         .text("Number of commits");

+   var _data = [];

+   var _lbl = []

+   for (var _d in data.results) {

+     _lbl.push(data.results[_d][0]);

+     _data.push(data.results[_d][1]);

    }

  

-   draw_graph(_out);

-   _b.show();

+   var data = {

+     labels: _lbl,

+     datasets: [{

+       label: 'Number of commits per week',

+       backgroundColor: color(window.chartColors.blue).alpha(0.5).rgbString(),

+       borderColor: window.chartColors.blue,

+       borderWidth: 1,

+       pointRadius: 0,

+       data: _data

+     }]

+   };

+ 

+   var options = {

+     scales: {

+       yAxes: [{

+         stacked: true

+       }]

+     },

+     plugins: {

+       filler: {

+         propagate: true

+       },

+     },

+     title: {

+       display: true,

+       text: 'Evolution of the number of commits over the last year'

+     }

+   };

+ 

+   var chart = new Chart('commit_trend_graph', {

+     type: 'line',

+     data: data,

+     options: options

+   });

+ 

+   $("#data_stats_spinner").hide();

+   $(".commit_trend").show();

  }

  

  function process_async(url, _data, callback) {

The added file is too large to be shown here, see it at: pagure/static/vendor/chartjs/chartjs-2.9.3.js
@@ -0,0 +1,7 @@ 

+ /*!

+  * Chart.js v2.9.3

+  * https://www.chartjs.org

+  * (c) 2019 Chart.js Contributors

+  * Released under the MIT License

+  */

+ !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e(function(){try{return require("moment")}catch(t){}}()):"function"==typeof define&&define.amd?define(["require"],(function(t){return e(function(){try{return t("moment")}catch(t){}}())})):(t=t||self).Chart=e(t.moment)}(this,(function(t){"use strict";t=t&&t.hasOwnProperty("default")?t.default:t;var e={aliceblue:[240,248,255],antiquewhite:[250,235,215],aqua:[0,255,255],aquamarine:[127,255,212],azure:[240,255,255],beige:[245,245,220],bisque:[255,228,196],black:[0,0,0],blanchedalmond:[255,235,205],blue:[0,0,255],blueviolet:[138,43,226],brown:[165,42,42],burlywood:[222,184,135],cadetblue:[95,158,160],chartreuse:[127,255,0],chocolate:[210,105,30],coral:[255,127,80],cornflowerblue:[100,149,237],cornsilk:[255,248,220],crimson:[220,20,60],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgoldenrod:[184,134,11],darkgray:[169,169,169],darkgreen:[0,100,0],darkgrey:[169,169,169],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkseagreen:[143,188,143],darkslateblue:[72,61,139],darkslategray:[47,79,79],darkslategrey:[47,79,79],darkturquoise:[0,206,209],darkviolet:[148,0,211],deeppink:[255,20,147],deepskyblue:[0,191,255],dimgray:[105,105,105],dimgrey:[105,105,105],dodgerblue:[30,144,255],firebrick:[178,34,34],floralwhite:[255,250,240],forestgreen:[34,139,34],fuchsia:[255,0,255],gainsboro:[220,220,220],ghostwhite:[248,248,255],gold:[255,215,0],goldenrod:[218,165,32],gray:[128,128,128],green:[0,128,0],greenyellow:[173,255,47],grey:[128,128,128],honeydew:[240,255,240],hotpink:[255,105,180],indianred:[205,92,92],indigo:[75,0,130],ivory:[255,255,240],khaki:[240,230,140],lavender:[230,230,250],lavenderblush:[255,240,245],lawngreen:[124,252,0],lemonchiffon:[255,250,205],lightblue:[173,216,230],lightcoral:[240,128,128],lightcyan:[224,255,255],lightgoldenrodyellow:[250,250,210],lightgray:[211,211,211],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightsalmon:[255,160,122],lightseagreen:[32,178,170],lightskyblue:[135,206,250],lightslategray:[119,136,153],lightslategrey:[119,136,153],lightsteelblue:[176,196,222],lightyellow:[255,255,224],lime:[0,255,0],limegreen:[50,205,50],linen:[250,240,230],magenta:[255,0,255],maroon:[128,0,0],mediumaquamarine:[102,205,170],mediumblue:[0,0,205],mediumorchid:[186,85,211],mediumpurple:[147,112,219],mediumseagreen:[60,179,113],mediumslateblue:[123,104,238],mediumspringgreen:[0,250,154],mediumturquoise:[72,209,204],mediumvioletred:[199,21,133],midnightblue:[25,25,112],mintcream:[245,255,250],mistyrose:[255,228,225],moccasin:[255,228,181],navajowhite:[255,222,173],navy:[0,0,128],oldlace:[253,245,230],olive:[128,128,0],olivedrab:[107,142,35],orange:[255,165,0],orangered:[255,69,0],orchid:[218,112,214],palegoldenrod:[238,232,170],palegreen:[152,251,152],paleturquoise:[175,238,238],palevioletred:[219,112,147],papayawhip:[255,239,213],peachpuff:[255,218,185],peru:[205,133,63],pink:[255,192,203],plum:[221,160,221],powderblue:[176,224,230],purple:[128,0,128],rebeccapurple:[102,51,153],red:[255,0,0],rosybrown:[188,143,143],royalblue:[65,105,225],saddlebrown:[139,69,19],salmon:[250,128,114],sandybrown:[244,164,96],seagreen:[46,139,87],seashell:[255,245,238],sienna:[160,82,45],silver:[192,192,192],skyblue:[135,206,235],slateblue:[106,90,205],slategray:[112,128,144],slategrey:[112,128,144],snow:[255,250,250],springgreen:[0,255,127],steelblue:[70,130,180],tan:[210,180,140],teal:[0,128,128],thistle:[216,191,216],tomato:[255,99,71],turquoise:[64,224,208],violet:[238,130,238],wheat:[245,222,179],white:[255,255,255],whitesmoke:[245,245,245],yellow:[255,255,0],yellowgreen:[154,205,50]},n=function(t,e){return t(e={exports:{}},e.exports),e.exports}((function(t){var n={};for(var i in e)e.hasOwnProperty(i)&&(n[e[i]]=i);var a=t.exports={rgb:{channels:3,labels:"rgb"},hsl:{channels:3,labels:"hsl"},hsv:{channels:3,labels:"hsv"},hwb:{channels:3,labels:"hwb"},cmyk:{channels:4,labels:"cmyk"},xyz:{channels:3,labels:"xyz"},lab:{channels:3,labels:"lab"},lch:{channels:3,labels:"lch"},hex:{channels:1,labels:["hex"]},keyword:{channels:1,labels:["keyword"]},ansi16:{channels:1,labels:["ansi16"]},ansi256:{channels:1,labels:["ansi256"]},hcg:{channels:3,labels:["h","c","g"]},apple:{channels:3,labels:["r16","g16","b16"]},gray:{channels:1,labels:["gray"]}};for(var r in a)if(a.hasOwnProperty(r)){if(!("channels"in a[r]))throw new Error("missing channels property: "+r);if(!("labels"in a[r]))throw new Error("missing channel labels property: "+r);if(a[r].labels.length!==a[r].channels)throw new Error("channel and label counts mismatch: "+r);var o=a[r].channels,s=a[r].labels;delete a[r].channels,delete a[r].labels,Object.defineProperty(a[r],"channels",{value:o}),Object.defineProperty(a[r],"labels",{value:s})}a.rgb.hsl=function(t){var e,n,i=t[0]/255,a=t[1]/255,r=t[2]/255,o=Math.min(i,a,r),s=Math.max(i,a,r),l=s-o;return s===o?e=0:i===s?e=(a-r)/l:a===s?e=2+(r-i)/l:r===s&&(e=4+(i-a)/l),(e=Math.min(60*e,360))<0&&(e+=360),n=(o+s)/2,[e,100*(s===o?0:n<=.5?l/(s+o):l/(2-s-o)),100*n]},a.rgb.hsv=function(t){var e,n,i,a,r,o=t[0]/255,s=t[1]/255,l=t[2]/255,u=Math.max(o,s,l),d=u-Math.min(o,s,l),h=function(t){return(u-t)/6/d+.5};return 0===d?a=r=0:(r=d/u,e=h(o),n=h(s),i=h(l),o===u?a=i-n:s===u?a=1/3+e-i:l===u&&(a=2/3+n-e),a<0?a+=1:a>1&&(a-=1)),[360*a,100*r,100*u]},a.rgb.hwb=function(t){var e=t[0],n=t[1],i=t[2];return[a.rgb.hsl(t)[0],100*(1/255*Math.min(e,Math.min(n,i))),100*(i=1-1/255*Math.max(e,Math.max(n,i)))]},a.rgb.cmyk=function(t){var e,n=t[0]/255,i=t[1]/255,a=t[2]/255;return[100*((1-n-(e=Math.min(1-n,1-i,1-a)))/(1-e)||0),100*((1-i-e)/(1-e)||0),100*((1-a-e)/(1-e)||0),100*e]},a.rgb.keyword=function(t){var i=n[t];if(i)return i;var a,r,o,s=1/0;for(var l in e)if(e.hasOwnProperty(l)){var u=e[l],d=(r=t,o=u,Math.pow(r[0]-o[0],2)+Math.pow(r[1]-o[1],2)+Math.pow(r[2]-o[2],2));d<s&&(s=d,a=l)}return a},a.keyword.rgb=function(t){return e[t]},a.rgb.xyz=function(t){var e=t[0]/255,n=t[1]/255,i=t[2]/255;return[100*(.4124*(e=e>.04045?Math.pow((e+.055)/1.055,2.4):e/12.92)+.3576*(n=n>.04045?Math.pow((n+.055)/1.055,2.4):n/12.92)+.1805*(i=i>.04045?Math.pow((i+.055)/1.055,2.4):i/12.92)),100*(.2126*e+.7152*n+.0722*i),100*(.0193*e+.1192*n+.9505*i)]},a.rgb.lab=function(t){var e=a.rgb.xyz(t),n=e[0],i=e[1],r=e[2];return i/=100,r/=108.883,n=(n/=95.047)>.008856?Math.pow(n,1/3):7.787*n+16/116,[116*(i=i>.008856?Math.pow(i,1/3):7.787*i+16/116)-16,500*(n-i),200*(i-(r=r>.008856?Math.pow(r,1/3):7.787*r+16/116))]},a.hsl.rgb=function(t){var e,n,i,a,r,o=t[0]/360,s=t[1]/100,l=t[2]/100;if(0===s)return[r=255*l,r,r];e=2*l-(n=l<.5?l*(1+s):l+s-l*s),a=[0,0,0];for(var u=0;u<3;u++)(i=o+1/3*-(u-1))<0&&i++,i>1&&i--,r=6*i<1?e+6*(n-e)*i:2*i<1?n:3*i<2?e+(n-e)*(2/3-i)*6:e,a[u]=255*r;return a},a.hsl.hsv=function(t){var e=t[0],n=t[1]/100,i=t[2]/100,a=n,r=Math.max(i,.01);return n*=(i*=2)<=1?i:2-i,a*=r<=1?r:2-r,[e,100*(0===i?2*a/(r+a):2*n/(i+n)),100*((i+n)/2)]},a.hsv.rgb=function(t){var e=t[0]/60,n=t[1]/100,i=t[2]/100,a=Math.floor(e)%6,r=e-Math.floor(e),o=255*i*(1-n),s=255*i*(1-n*r),l=255*i*(1-n*(1-r));switch(i*=255,a){case 0:return[i,l,o];case 1:return[s,i,o];case 2:return[o,i,l];case 3:return[o,s,i];case 4:return[l,o,i];case 5:return[i,o,s]}},a.hsv.hsl=function(t){var e,n,i,a=t[0],r=t[1]/100,o=t[2]/100,s=Math.max(o,.01);return i=(2-r)*o,n=r*s,[a,100*(n=(n/=(e=(2-r)*s)<=1?e:2-e)||0),100*(i/=2)]},a.hwb.rgb=function(t){var e,n,i,a,r,o,s,l=t[0]/360,u=t[1]/100,d=t[2]/100,h=u+d;switch(h>1&&(u/=h,d/=h),i=6*l-(e=Math.floor(6*l)),0!=(1&e)&&(i=1-i),a=u+i*((n=1-d)-u),e){default:case 6:case 0:r=n,o=a,s=u;break;case 1:r=a,o=n,s=u;break;case 2:r=u,o=n,s=a;break;case 3:r=u,o=a,s=n;break;case 4:r=a,o=u,s=n;break;case 5:r=n,o=u,s=a}return[255*r,255*o,255*s]},a.cmyk.rgb=function(t){var e=t[0]/100,n=t[1]/100,i=t[2]/100,a=t[3]/100;return[255*(1-Math.min(1,e*(1-a)+a)),255*(1-Math.min(1,n*(1-a)+a)),255*(1-Math.min(1,i*(1-a)+a))]},a.xyz.rgb=function(t){var e,n,i,a=t[0]/100,r=t[1]/100,o=t[2]/100;return n=-.9689*a+1.8758*r+.0415*o,i=.0557*a+-.204*r+1.057*o,e=(e=3.2406*a+-1.5372*r+-.4986*o)>.0031308?1.055*Math.pow(e,1/2.4)-.055:12.92*e,n=n>.0031308?1.055*Math.pow(n,1/2.4)-.055:12.92*n,i=i>.0031308?1.055*Math.pow(i,1/2.4)-.055:12.92*i,[255*(e=Math.min(Math.max(0,e),1)),255*(n=Math.min(Math.max(0,n),1)),255*(i=Math.min(Math.max(0,i),1))]},a.xyz.lab=function(t){var e=t[0],n=t[1],i=t[2];return n/=100,i/=108.883,e=(e/=95.047)>.008856?Math.pow(e,1/3):7.787*e+16/116,[116*(n=n>.008856?Math.pow(n,1/3):7.787*n+16/116)-16,500*(e-n),200*(n-(i=i>.008856?Math.pow(i,1/3):7.787*i+16/116))]},a.lab.xyz=function(t){var e,n,i,a=t[0];e=t[1]/500+(n=(a+16)/116),i=n-t[2]/200;var r=Math.pow(n,3),o=Math.pow(e,3),s=Math.pow(i,3);return n=r>.008856?r:(n-16/116)/7.787,e=o>.008856?o:(e-16/116)/7.787,i=s>.008856?s:(i-16/116)/7.787,[e*=95.047,n*=100,i*=108.883]},a.lab.lch=function(t){var e,n=t[0],i=t[1],a=t[2];return(e=360*Math.atan2(a,i)/2/Math.PI)<0&&(e+=360),[n,Math.sqrt(i*i+a*a),e]},a.lch.lab=function(t){var e,n=t[0],i=t[1];return e=t[2]/360*2*Math.PI,[n,i*Math.cos(e),i*Math.sin(e)]},a.rgb.ansi16=function(t){var e=t[0],n=t[1],i=t[2],r=1 in arguments?arguments[1]:a.rgb.hsv(t)[2];if(0===(r=Math.round(r/50)))return 30;var o=30+(Math.round(i/255)<<2|Math.round(n/255)<<1|Math.round(e/255));return 2===r&&(o+=60),o},a.hsv.ansi16=function(t){return a.rgb.ansi16(a.hsv.rgb(t),t[2])},a.rgb.ansi256=function(t){var e=t[0],n=t[1],i=t[2];return e===n&&n===i?e<8?16:e>248?231:Math.round((e-8)/247*24)+232:16+36*Math.round(e/255*5)+6*Math.round(n/255*5)+Math.round(i/255*5)},a.ansi16.rgb=function(t){var e=t%10;if(0===e||7===e)return t>50&&(e+=3.5),[e=e/10.5*255,e,e];var n=.5*(1+~~(t>50));return[(1&e)*n*255,(e>>1&1)*n*255,(e>>2&1)*n*255]},a.ansi256.rgb=function(t){if(t>=232){var e=10*(t-232)+8;return[e,e,e]}var n;return t-=16,[Math.floor(t/36)/5*255,Math.floor((n=t%36)/6)/5*255,n%6/5*255]},a.rgb.hex=function(t){var e=(((255&Math.round(t[0]))<<16)+((255&Math.round(t[1]))<<8)+(255&Math.round(t[2]))).toString(16).toUpperCase();return"000000".substring(e.length)+e},a.hex.rgb=function(t){var e=t.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);if(!e)return[0,0,0];var n=e[0];3===e[0].length&&(n=n.split("").map((function(t){return t+t})).join(""));var i=parseInt(n,16);return[i>>16&255,i>>8&255,255&i]},a.rgb.hcg=function(t){var e,n=t[0]/255,i=t[1]/255,a=t[2]/255,r=Math.max(Math.max(n,i),a),o=Math.min(Math.min(n,i),a),s=r-o;return e=s<=0?0:r===n?(i-a)/s%6:r===i?2+(a-n)/s:4+(n-i)/s+4,e/=6,[360*(e%=1),100*s,100*(s<1?o/(1-s):0)]},a.hsl.hcg=function(t){var e=t[1]/100,n=t[2]/100,i=1,a=0;return(i=n<.5?2*e*n:2*e*(1-n))<1&&(a=(n-.5*i)/(1-i)),[t[0],100*i,100*a]},a.hsv.hcg=function(t){var e=t[1]/100,n=t[2]/100,i=e*n,a=0;return i<1&&(a=(n-i)/(1-i)),[t[0],100*i,100*a]},a.hcg.rgb=function(t){var e=t[0]/360,n=t[1]/100,i=t[2]/100;if(0===n)return[255*i,255*i,255*i];var a,r=[0,0,0],o=e%1*6,s=o%1,l=1-s;switch(Math.floor(o)){case 0:r[0]=1,r[1]=s,r[2]=0;break;case 1:r[0]=l,r[1]=1,r[2]=0;break;case 2:r[0]=0,r[1]=1,r[2]=s;break;case 3:r[0]=0,r[1]=l,r[2]=1;break;case 4:r[0]=s,r[1]=0,r[2]=1;break;default:r[0]=1,r[1]=0,r[2]=l}return a=(1-n)*i,[255*(n*r[0]+a),255*(n*r[1]+a),255*(n*r[2]+a)]},a.hcg.hsv=function(t){var e=t[1]/100,n=e+t[2]/100*(1-e),i=0;return n>0&&(i=e/n),[t[0],100*i,100*n]},a.hcg.hsl=function(t){var e=t[1]/100,n=t[2]/100*(1-e)+.5*e,i=0;return n>0&&n<.5?i=e/(2*n):n>=.5&&n<1&&(i=e/(2*(1-n))),[t[0],100*i,100*n]},a.hcg.hwb=function(t){var e=t[1]/100,n=e+t[2]/100*(1-e);return[t[0],100*(n-e),100*(1-n)]},a.hwb.hcg=function(t){var e=t[1]/100,n=1-t[2]/100,i=n-e,a=0;return i<1&&(a=(n-i)/(1-i)),[t[0],100*i,100*a]},a.apple.rgb=function(t){return[t[0]/65535*255,t[1]/65535*255,t[2]/65535*255]},a.rgb.apple=function(t){return[t[0]/255*65535,t[1]/255*65535,t[2]/255*65535]},a.gray.rgb=function(t){return[t[0]/100*255,t[0]/100*255,t[0]/100*255]},a.gray.hsl=a.gray.hsv=function(t){return[0,0,t[0]]},a.gray.hwb=function(t){return[0,100,t[0]]},a.gray.cmyk=function(t){return[0,0,0,t[0]]},a.gray.lab=function(t){return[t[0],0,0]},a.gray.hex=function(t){var e=255&Math.round(t[0]/100*255),n=((e<<16)+(e<<8)+e).toString(16).toUpperCase();return"000000".substring(n.length)+n},a.rgb.gray=function(t){return[(t[0]+t[1]+t[2])/3/255*100]}}));n.rgb,n.hsl,n.hsv,n.hwb,n.cmyk,n.xyz,n.lab,n.lch,n.hex,n.keyword,n.ansi16,n.ansi256,n.hcg,n.apple,n.gray;function i(t){var e=function(){for(var t={},e=Object.keys(n),i=e.length,a=0;a<i;a++)t[e[a]]={distance:-1,parent:null};return t}(),i=[t];for(e[t].distance=0;i.length;)for(var a=i.pop(),r=Object.keys(n[a]),o=r.length,s=0;s<o;s++){var l=r[s],u=e[l];-1===u.distance&&(u.distance=e[a].distance+1,u.parent=a,i.unshift(l))}return e}function a(t,e){return function(n){return e(t(n))}}function r(t,e){for(var i=[e[t].parent,t],r=n[e[t].parent][t],o=e[t].parent;e[o].parent;)i.unshift(e[o].parent),r=a(n[e[o].parent][o],r),o=e[o].parent;return r.conversion=i,r}var o={};Object.keys(n).forEach((function(t){o[t]={},Object.defineProperty(o[t],"channels",{value:n[t].channels}),Object.defineProperty(o[t],"labels",{value:n[t].labels});var e=function(t){for(var e=i(t),n={},a=Object.keys(e),o=a.length,s=0;s<o;s++){var l=a[s];null!==e[l].parent&&(n[l]=r(l,e))}return n}(t);Object.keys(e).forEach((function(n){var i=e[n];o[t][n]=function(t){var e=function(e){if(null==e)return e;arguments.length>1&&(e=Array.prototype.slice.call(arguments));var n=t(e);if("object"==typeof n)for(var i=n.length,a=0;a<i;a++)n[a]=Math.round(n[a]);return n};return"conversion"in t&&(e.conversion=t.conversion),e}(i),o[t][n].raw=function(t){var e=function(e){return null==e?e:(arguments.length>1&&(e=Array.prototype.slice.call(arguments)),t(e))};return"conversion"in t&&(e.conversion=t.conversion),e}(i)}))}));var s=o,l={aliceblue:[240,248,255],antiquewhite:[250,235,215],aqua:[0,255,255],aquamarine:[127,255,212],azure:[240,255,255],beige:[245,245,220],bisque:[255,228,196],black:[0,0,0],blanchedalmond:[255,235,205],blue:[0,0,255],blueviolet:[138,43,226],brown:[165,42,42],burlywood:[222,184,135],cadetblue:[95,158,160],chartreuse:[127,255,0],chocolate:[210,105,30],coral:[255,127,80],cornflowerblue:[100,149,237],cornsilk:[255,248,220],crimson:[220,20,60],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgoldenrod:[184,134,11],darkgray:[169,169,169],darkgreen:[0,100,0],darkgrey:[169,169,169],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkseagreen:[143,188,143],darkslateblue:[72,61,139],darkslategray:[47,79,79],darkslategrey:[47,79,79],darkturquoise:[0,206,209],darkviolet:[148,0,211],deeppink:[255,20,147],deepskyblue:[0,191,255],dimgray:[105,105,105],dimgrey:[105,105,105],dodgerblue:[30,144,255],firebrick:[178,34,34],floralwhite:[255,250,240],forestgreen:[34,139,34],fuchsia:[255,0,255],gainsboro:[220,220,220],ghostwhite:[248,248,255],gold:[255,215,0],goldenrod:[218,165,32],gray:[128,128,128],green:[0,128,0],greenyellow:[173,255,47],grey:[128,128,128],honeydew:[240,255,240],hotpink:[255,105,180],indianred:[205,92,92],indigo:[75,0,130],ivory:[255,255,240],khaki:[240,230,140],lavender:[230,230,250],lavenderblush:[255,240,245],lawngreen:[124,252,0],lemonchiffon:[255,250,205],lightblue:[173,216,230],lightcoral:[240,128,128],lightcyan:[224,255,255],lightgoldenrodyellow:[250,250,210],lightgray:[211,211,211],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightsalmon:[255,160,122],lightseagreen:[32,178,170],lightskyblue:[135,206,250],lightslategray:[119,136,153],lightslategrey:[119,136,153],lightsteelblue:[176,196,222],lightyellow:[255,255,224],lime:[0,255,0],limegreen:[50,205,50],linen:[250,240,230],magenta:[255,0,255],maroon:[128,0,0],mediumaquamarine:[102,205,170],mediumblue:[0,0,205],mediumorchid:[186,85,211],mediumpurple:[147,112,219],mediumseagreen:[60,179,113],mediumslateblue:[123,104,238],mediumspringgreen:[0,250,154],mediumturquoise:[72,209,204],mediumvioletred:[199,21,133],midnightblue:[25,25,112],mintcream:[245,255,250],mistyrose:[255,228,225],moccasin:[255,228,181],navajowhite:[255,222,173],navy:[0,0,128],oldlace:[253,245,230],olive:[128,128,0],olivedrab:[107,142,35],orange:[255,165,0],orangered:[255,69,0],orchid:[218,112,214],palegoldenrod:[238,232,170],palegreen:[152,251,152],paleturquoise:[175,238,238],palevioletred:[219,112,147],papayawhip:[255,239,213],peachpuff:[255,218,185],peru:[205,133,63],pink:[255,192,203],plum:[221,160,221],powderblue:[176,224,230],purple:[128,0,128],rebeccapurple:[102,51,153],red:[255,0,0],rosybrown:[188,143,143],royalblue:[65,105,225],saddlebrown:[139,69,19],salmon:[250,128,114],sandybrown:[244,164,96],seagreen:[46,139,87],seashell:[255,245,238],sienna:[160,82,45],silver:[192,192,192],skyblue:[135,206,235],slateblue:[106,90,205],slategray:[112,128,144],slategrey:[112,128,144],snow:[255,250,250],springgreen:[0,255,127],steelblue:[70,130,180],tan:[210,180,140],teal:[0,128,128],thistle:[216,191,216],tomato:[255,99,71],turquoise:[64,224,208],violet:[238,130,238],wheat:[245,222,179],white:[255,255,255],whitesmoke:[245,245,245],yellow:[255,255,0],yellowgreen:[154,205,50]},u={getRgba:d,getHsla:h,getRgb:function(t){var e=d(t);return e&&e.slice(0,3)},getHsl:function(t){var e=h(t);return e&&e.slice(0,3)},getHwb:c,getAlpha:function(t){var e=d(t);if(e)return e[3];if(e=h(t))return e[3];if(e=c(t))return e[3]},hexString:function(t,e){e=void 0!==e&&3===t.length?e:t[3];return"#"+v(t[0])+v(t[1])+v(t[2])+(e>=0&&e<1?v(Math.round(255*e)):"")},rgbString:function(t,e){if(e<1||t[3]&&t[3]<1)return f(t,e);return"rgb("+t[0]+", "+t[1]+", "+t[2]+")"},rgbaString:f,percentString:function(t,e){if(e<1||t[3]&&t[3]<1)return g(t,e);var n=Math.round(t[0]/255*100),i=Math.round(t[1]/255*100),a=Math.round(t[2]/255*100);return"rgb("+n+"%, "+i+"%, "+a+"%)"},percentaString:g,hslString:function(t,e){if(e<1||t[3]&&t[3]<1)return p(t,e);return"hsl("+t[0]+", "+t[1]+"%, "+t[2]+"%)"},hslaString:p,hwbString:function(t,e){void 0===e&&(e=void 0!==t[3]?t[3]:1);return"hwb("+t[0]+", "+t[1]+"%, "+t[2]+"%"+(void 0!==e&&1!==e?", "+e:"")+")"},keyword:function(t){return b[t.slice(0,3)]}};function d(t){if(t){var e=[0,0,0],n=1,i=t.match(/^#([a-fA-F0-9]{3,4})$/i),a="";if(i){a=(i=i[1])[3];for(var r=0;r<e.length;r++)e[r]=parseInt(i[r]+i[r],16);a&&(n=Math.round(parseInt(a+a,16)/255*100)/100)}else if(i=t.match(/^#([a-fA-F0-9]{6}([a-fA-F0-9]{2})?)$/i)){a=i[2],i=i[1];for(r=0;r<e.length;r++)e[r]=parseInt(i.slice(2*r,2*r+2),16);a&&(n=Math.round(parseInt(a,16)/255*100)/100)}else if(i=t.match(/^rgba?\(\s*([+-]?\d+)\s*,\s*([+-]?\d+)\s*,\s*([+-]?\d+)\s*(?:,\s*([+-]?[\d\.]+)\s*)?\)$/i)){for(r=0;r<e.length;r++)e[r]=parseInt(i[r+1]);n=parseFloat(i[4])}else if(i=t.match(/^rgba?\(\s*([+-]?[\d\.]+)\%\s*,\s*([+-]?[\d\.]+)\%\s*,\s*([+-]?[\d\.]+)\%\s*(?:,\s*([+-]?[\d\.]+)\s*)?\)$/i)){for(r=0;r<e.length;r++)e[r]=Math.round(2.55*parseFloat(i[r+1]));n=parseFloat(i[4])}else if(i=t.match(/(\w+)/)){if("transparent"==i[1])return[0,0,0,0];if(!(e=l[i[1]]))return}for(r=0;r<e.length;r++)e[r]=m(e[r],0,255);return n=n||0==n?m(n,0,1):1,e[3]=n,e}}function h(t){if(t){var e=t.match(/^hsla?\(\s*([+-]?\d+)(?:deg)?\s*,\s*([+-]?[\d\.]+)%\s*,\s*([+-]?[\d\.]+)%\s*(?:,\s*([+-]?[\d\.]+)\s*)?\)/);if(e){var n=parseFloat(e[4]);return[m(parseInt(e[1]),0,360),m(parseFloat(e[2]),0,100),m(parseFloat(e[3]),0,100),m(isNaN(n)?1:n,0,1)]}}}function c(t){if(t){var e=t.match(/^hwb\(\s*([+-]?\d+)(?:deg)?\s*,\s*([+-]?[\d\.]+)%\s*,\s*([+-]?[\d\.]+)%\s*(?:,\s*([+-]?[\d\.]+)\s*)?\)/);if(e){var n=parseFloat(e[4]);return[m(parseInt(e[1]),0,360),m(parseFloat(e[2]),0,100),m(parseFloat(e[3]),0,100),m(isNaN(n)?1:n,0,1)]}}}function f(t,e){return void 0===e&&(e=void 0!==t[3]?t[3]:1),"rgba("+t[0]+", "+t[1]+", "+t[2]+", "+e+")"}function g(t,e){return"rgba("+Math.round(t[0]/255*100)+"%, "+Math.round(t[1]/255*100)+"%, "+Math.round(t[2]/255*100)+"%, "+(e||t[3]||1)+")"}function p(t,e){return void 0===e&&(e=void 0!==t[3]?t[3]:1),"hsla("+t[0]+", "+t[1]+"%, "+t[2]+"%, "+e+")"}function m(t,e,n){return Math.min(Math.max(e,t),n)}function v(t){var e=t.toString(16).toUpperCase();return e.length<2?"0"+e:e}var b={};for(var x in l)b[l[x]]=x;var y=function(t){return t instanceof y?t:this instanceof y?(this.valid=!1,this.values={rgb:[0,0,0],hsl:[0,0,0],hsv:[0,0,0],hwb:[0,0,0],cmyk:[0,0,0,0],alpha:1},void("string"==typeof t?(e=u.getRgba(t))?this.setValues("rgb",e):(e=u.getHsla(t))?this.setValues("hsl",e):(e=u.getHwb(t))&&this.setValues("hwb",e):"object"==typeof t&&(void 0!==(e=t).r||void 0!==e.red?this.setValues("rgb",e):void 0!==e.l||void 0!==e.lightness?this.setValues("hsl",e):void 0!==e.v||void 0!==e.value?this.setValues("hsv",e):void 0!==e.w||void 0!==e.whiteness?this.setValues("hwb",e):void 0===e.c&&void 0===e.cyan||this.setValues("cmyk",e)))):new y(t);var e};y.prototype={isValid:function(){return this.valid},rgb:function(){return this.setSpace("rgb",arguments)},hsl:function(){return this.setSpace("hsl",arguments)},hsv:function(){return this.setSpace("hsv",arguments)},hwb:function(){return this.setSpace("hwb",arguments)},cmyk:function(){return this.setSpace("cmyk",arguments)},rgbArray:function(){return this.values.rgb},hslArray:function(){return this.values.hsl},hsvArray:function(){return this.values.hsv},hwbArray:function(){var t=this.values;return 1!==t.alpha?t.hwb.concat([t.alpha]):t.hwb},cmykArray:function(){return this.values.cmyk},rgbaArray:function(){var t=this.values;return t.rgb.concat([t.alpha])},hslaArray:function(){var t=this.values;return t.hsl.concat([t.alpha])},alpha:function(t){return void 0===t?this.values.alpha:(this.setValues("alpha",t),this)},red:function(t){return this.setChannel("rgb",0,t)},green:function(t){return this.setChannel("rgb",1,t)},blue:function(t){return this.setChannel("rgb",2,t)},hue:function(t){return t&&(t=(t%=360)<0?360+t:t),this.setChannel("hsl",0,t)},saturation:function(t){return this.setChannel("hsl",1,t)},lightness:function(t){return this.setChannel("hsl",2,t)},saturationv:function(t){return this.setChannel("hsv",1,t)},whiteness:function(t){return this.setChannel("hwb",1,t)},blackness:function(t){return this.setChannel("hwb",2,t)},value:function(t){return this.setChannel("hsv",2,t)},cyan:function(t){return this.setChannel("cmyk",0,t)},magenta:function(t){return this.setChannel("cmyk",1,t)},yellow:function(t){return this.setChannel("cmyk",2,t)},black:function(t){return this.setChannel("cmyk",3,t)},hexString:function(){return u.hexString(this.values.rgb)},rgbString:function(){return u.rgbString(this.values.rgb,this.values.alpha)},rgbaString:function(){return u.rgbaString(this.values.rgb,this.values.alpha)},percentString:function(){return u.percentString(this.values.rgb,this.values.alpha)},hslString:function(){return u.hslString(this.values.hsl,this.values.alpha)},hslaString:function(){return u.hslaString(this.values.hsl,this.values.alpha)},hwbString:function(){return u.hwbString(this.values.hwb,this.values.alpha)},keyword:function(){return u.keyword(this.values.rgb,this.values.alpha)},rgbNumber:function(){var t=this.values.rgb;return t[0]<<16|t[1]<<8|t[2]},luminosity:function(){for(var t=this.values.rgb,e=[],n=0;n<t.length;n++){var i=t[n]/255;e[n]=i<=.03928?i/12.92:Math.pow((i+.055)/1.055,2.4)}return.2126*e[0]+.7152*e[1]+.0722*e[2]},contrast:function(t){var e=this.luminosity(),n=t.luminosity();return e>n?(e+.05)/(n+.05):(n+.05)/(e+.05)},level:function(t){var e=this.contrast(t);return e>=7.1?"AAA":e>=4.5?"AA":""},dark:function(){var t=this.values.rgb;return(299*t[0]+587*t[1]+114*t[2])/1e3<128},light:function(){return!this.dark()},negate:function(){for(var t=[],e=0;e<3;e++)t[e]=255-this.values.rgb[e];return this.setValues("rgb",t),this},lighten:function(t){var e=this.values.hsl;return e[2]+=e[2]*t,this.setValues("hsl",e),this},darken:function(t){var e=this.values.hsl;return e[2]-=e[2]*t,this.setValues("hsl",e),this},saturate:function(t){var e=this.values.hsl;return e[1]+=e[1]*t,this.setValues("hsl",e),this},desaturate:function(t){var e=this.values.hsl;return e[1]-=e[1]*t,this.setValues("hsl",e),this},whiten:function(t){var e=this.values.hwb;return e[1]+=e[1]*t,this.setValues("hwb",e),this},blacken:function(t){var e=this.values.hwb;return e[2]+=e[2]*t,this.setValues("hwb",e),this},greyscale:function(){var t=this.values.rgb,e=.3*t[0]+.59*t[1]+.11*t[2];return this.setValues("rgb",[e,e,e]),this},clearer:function(t){var e=this.values.alpha;return this.setValues("alpha",e-e*t),this},opaquer:function(t){var e=this.values.alpha;return this.setValues("alpha",e+e*t),this},rotate:function(t){var e=this.values.hsl,n=(e[0]+t)%360;return e[0]=n<0?360+n:n,this.setValues("hsl",e),this},mix:function(t,e){var n=t,i=void 0===e?.5:e,a=2*i-1,r=this.alpha()-n.alpha(),o=((a*r==-1?a:(a+r)/(1+a*r))+1)/2,s=1-o;return this.rgb(o*this.red()+s*n.red(),o*this.green()+s*n.green(),o*this.blue()+s*n.blue()).alpha(this.alpha()*i+n.alpha()*(1-i))},toJSON:function(){return this.rgb()},clone:function(){var t,e,n=new y,i=this.values,a=n.values;for(var r in i)i.hasOwnProperty(r)&&(t=i[r],"[object Array]"===(e={}.toString.call(t))?a[r]=t.slice(0):"[object Number]"===e?a[r]=t:console.error("unexpected color value:",t));return n}},y.prototype.spaces={rgb:["red","green","blue"],hsl:["hue","saturation","lightness"],hsv:["hue","saturation","value"],hwb:["hue","whiteness","blackness"],cmyk:["cyan","magenta","yellow","black"]},y.prototype.maxes={rgb:[255,255,255],hsl:[360,100,100],hsv:[360,100,100],hwb:[360,100,100],cmyk:[100,100,100,100]},y.prototype.getValues=function(t){for(var e=this.values,n={},i=0;i<t.length;i++)n[t.charAt(i)]=e[t][i];return 1!==e.alpha&&(n.a=e.alpha),n},y.prototype.setValues=function(t,e){var n,i,a=this.values,r=this.spaces,o=this.maxes,l=1;if(this.valid=!0,"alpha"===t)l=e;else if(e.length)a[t]=e.slice(0,t.length),l=e[t.length];else if(void 0!==e[t.charAt(0)]){for(n=0;n<t.length;n++)a[t][n]=e[t.charAt(n)];l=e.a}else if(void 0!==e[r[t][0]]){var u=r[t];for(n=0;n<t.length;n++)a[t][n]=e[u[n]];l=e.alpha}if(a.alpha=Math.max(0,Math.min(1,void 0===l?a.alpha:l)),"alpha"===t)return!1;for(n=0;n<t.length;n++)i=Math.max(0,Math.min(o[t][n],a[t][n])),a[t][n]=Math.round(i);for(var d in r)d!==t&&(a[d]=s[t][d](a[t]));return!0},y.prototype.setSpace=function(t,e){var n=e[0];return void 0===n?this.getValues(t):("number"==typeof n&&(n=Array.prototype.slice.call(e)),this.setValues(t,n),this)},y.prototype.setChannel=function(t,e,n){var i=this.values[t];return void 0===n?i[e]:n===i[e]?this:(i[e]=n,this.setValues(t,i),this)},"undefined"!=typeof window&&(window.Color=y);var _,k=y,w={noop:function(){},uid:(_=0,function(){return _++}),isNullOrUndef:function(t){return null==t},isArray:function(t){if(Array.isArray&&Array.isArray(t))return!0;var e=Object.prototype.toString.call(t);return"[object"===e.substr(0,7)&&"Array]"===e.substr(-6)},isObject:function(t){return null!==t&&"[object Object]"===Object.prototype.toString.call(t)},isFinite:function(t){return("number"==typeof t||t instanceof Number)&&isFinite(t)},valueOrDefault:function(t,e){return void 0===t?e:t},valueAtIndexOrDefault:function(t,e,n){return w.valueOrDefault(w.isArray(t)?t[e]:t,n)},callback:function(t,e,n){if(t&&"function"==typeof t.call)return t.apply(n,e)},each:function(t,e,n,i){var a,r,o;if(w.isArray(t))if(r=t.length,i)for(a=r-1;a>=0;a--)e.call(n,t[a],a);else for(a=0;a<r;a++)e.call(n,t[a],a);else if(w.isObject(t))for(r=(o=Object.keys(t)).length,a=0;a<r;a++)e.call(n,t[o[a]],o[a])},arrayEquals:function(t,e){var n,i,a,r;if(!t||!e||t.length!==e.length)return!1;for(n=0,i=t.length;n<i;++n)if(a=t[n],r=e[n],a instanceof Array&&r instanceof Array){if(!w.arrayEquals(a,r))return!1}else if(a!==r)return!1;return!0},clone:function(t){if(w.isArray(t))return t.map(w.clone);if(w.isObject(t)){for(var e={},n=Object.keys(t),i=n.length,a=0;a<i;++a)e[n[a]]=w.clone(t[n[a]]);return e}return t},_merger:function(t,e,n,i){var a=e[t],r=n[t];w.isObject(a)&&w.isObject(r)?w.merge(a,r,i):e[t]=w.clone(r)},_mergerIf:function(t,e,n){var i=e[t],a=n[t];w.isObject(i)&&w.isObject(a)?w.mergeIf(i,a):e.hasOwnProperty(t)||(e[t]=w.clone(a))},merge:function(t,e,n){var i,a,r,o,s,l=w.isArray(e)?e:[e],u=l.length;if(!w.isObject(t))return t;for(i=(n=n||{}).merger||w._merger,a=0;a<u;++a)if(e=l[a],w.isObject(e))for(s=0,o=(r=Object.keys(e)).length;s<o;++s)i(r[s],t,e,n);return t},mergeIf:function(t,e){return w.merge(t,e,{merger:w._mergerIf})},extend:Object.assign||function(t){return w.merge(t,[].slice.call(arguments,1),{merger:function(t,e,n){e[t]=n[t]}})},inherits:function(t){var e=this,n=t&&t.hasOwnProperty("constructor")?t.constructor:function(){return e.apply(this,arguments)},i=function(){this.constructor=n};return i.prototype=e.prototype,n.prototype=new i,n.extend=w.inherits,t&&w.extend(n.prototype,t),n.__super__=e.prototype,n},_deprecated:function(t,e,n,i){void 0!==e&&console.warn(t+': "'+n+'" is deprecated. Please use "'+i+'" instead')}},M=w;w.callCallback=w.callback,w.indexOf=function(t,e,n){return Array.prototype.indexOf.call(t,e,n)},w.getValueOrDefault=w.valueOrDefault,w.getValueAtIndexOrDefault=w.valueAtIndexOrDefault;var S={linear:function(t){return t},easeInQuad:function(t){return t*t},easeOutQuad:function(t){return-t*(t-2)},easeInOutQuad:function(t){return(t/=.5)<1?.5*t*t:-.5*(--t*(t-2)-1)},easeInCubic:function(t){return t*t*t},easeOutCubic:function(t){return(t-=1)*t*t+1},easeInOutCubic:function(t){return(t/=.5)<1?.5*t*t*t:.5*((t-=2)*t*t+2)},easeInQuart:function(t){return t*t*t*t},easeOutQuart:function(t){return-((t-=1)*t*t*t-1)},easeInOutQuart:function(t){return(t/=.5)<1?.5*t*t*t*t:-.5*((t-=2)*t*t*t-2)},easeInQuint:function(t){return t*t*t*t*t},easeOutQuint:function(t){return(t-=1)*t*t*t*t+1},easeInOutQuint:function(t){return(t/=.5)<1?.5*t*t*t*t*t:.5*((t-=2)*t*t*t*t+2)},easeInSine:function(t){return 1-Math.cos(t*(Math.PI/2))},easeOutSine:function(t){return Math.sin(t*(Math.PI/2))},easeInOutSine:function(t){return-.5*(Math.cos(Math.PI*t)-1)},easeInExpo:function(t){return 0===t?0:Math.pow(2,10*(t-1))},easeOutExpo:function(t){return 1===t?1:1-Math.pow(2,-10*t)},easeInOutExpo:function(t){return 0===t?0:1===t?1:(t/=.5)<1?.5*Math.pow(2,10*(t-1)):.5*(2-Math.pow(2,-10*--t))},easeInCirc:function(t){return t>=1?t:-(Math.sqrt(1-t*t)-1)},easeOutCirc:function(t){return Math.sqrt(1-(t-=1)*t)},easeInOutCirc:function(t){return(t/=.5)<1?-.5*(Math.sqrt(1-t*t)-1):.5*(Math.sqrt(1-(t-=2)*t)+1)},easeInElastic:function(t){var e=1.70158,n=0,i=1;return 0===t?0:1===t?1:(n||(n=.3),i<1?(i=1,e=n/4):e=n/(2*Math.PI)*Math.asin(1/i),-i*Math.pow(2,10*(t-=1))*Math.sin((t-e)*(2*Math.PI)/n))},easeOutElastic:function(t){var e=1.70158,n=0,i=1;return 0===t?0:1===t?1:(n||(n=.3),i<1?(i=1,e=n/4):e=n/(2*Math.PI)*Math.asin(1/i),i*Math.pow(2,-10*t)*Math.sin((t-e)*(2*Math.PI)/n)+1)},easeInOutElastic:function(t){var e=1.70158,n=0,i=1;return 0===t?0:2==(t/=.5)?1:(n||(n=.45),i<1?(i=1,e=n/4):e=n/(2*Math.PI)*Math.asin(1/i),t<1?i*Math.pow(2,10*(t-=1))*Math.sin((t-e)*(2*Math.PI)/n)*-.5:i*Math.pow(2,-10*(t-=1))*Math.sin((t-e)*(2*Math.PI)/n)*.5+1)},easeInBack:function(t){var e=1.70158;return t*t*((e+1)*t-e)},easeOutBack:function(t){var e=1.70158;return(t-=1)*t*((e+1)*t+e)+1},easeInOutBack:function(t){var e=1.70158;return(t/=.5)<1?t*t*((1+(e*=1.525))*t-e)*.5:.5*((t-=2)*t*((1+(e*=1.525))*t+e)+2)},easeInBounce:function(t){return 1-S.easeOutBounce(1-t)},easeOutBounce:function(t){return t<1/2.75?7.5625*t*t:t<2/2.75?7.5625*(t-=1.5/2.75)*t+.75:t<2.5/2.75?7.5625*(t-=2.25/2.75)*t+.9375:7.5625*(t-=2.625/2.75)*t+.984375},easeInOutBounce:function(t){return t<.5?.5*S.easeInBounce(2*t):.5*S.easeOutBounce(2*t-1)+.5}},C={effects:S};M.easingEffects=S;var P=Math.PI,A=P/180,D=2*P,T=P/2,I=P/4,F=2*P/3,L={clear:function(t){t.ctx.clearRect(0,0,t.width,t.height)},roundedRect:function(t,e,n,i,a,r){if(r){var o=Math.min(r,a/2,i/2),s=e+o,l=n+o,u=e+i-o,d=n+a-o;t.moveTo(e,l),s<u&&l<d?(t.arc(s,l,o,-P,-T),t.arc(u,l,o,-T,0),t.arc(u,d,o,0,T),t.arc(s,d,o,T,P)):s<u?(t.moveTo(s,n),t.arc(u,l,o,-T,T),t.arc(s,l,o,T,P+T)):l<d?(t.arc(s,l,o,-P,0),t.arc(s,d,o,0,P)):t.arc(s,l,o,-P,P),t.closePath(),t.moveTo(e,n)}else t.rect(e,n,i,a)},drawPoint:function(t,e,n,i,a,r){var o,s,l,u,d,h=(r||0)*A;if(e&&"object"==typeof e&&("[object HTMLImageElement]"===(o=e.toString())||"[object HTMLCanvasElement]"===o))return t.save(),t.translate(i,a),t.rotate(h),t.drawImage(e,-e.width/2,-e.height/2,e.width,e.height),void t.restore();if(!(isNaN(n)||n<=0)){switch(t.beginPath(),e){default:t.arc(i,a,n,0,D),t.closePath();break;case"triangle":t.moveTo(i+Math.sin(h)*n,a-Math.cos(h)*n),h+=F,t.lineTo(i+Math.sin(h)*n,a-Math.cos(h)*n),h+=F,t.lineTo(i+Math.sin(h)*n,a-Math.cos(h)*n),t.closePath();break;case"rectRounded":u=n-(d=.516*n),s=Math.cos(h+I)*u,l=Math.sin(h+I)*u,t.arc(i-s,a-l,d,h-P,h-T),t.arc(i+l,a-s,d,h-T,h),t.arc(i+s,a+l,d,h,h+T),t.arc(i-l,a+s,d,h+T,h+P),t.closePath();break;case"rect":if(!r){u=Math.SQRT1_2*n,t.rect(i-u,a-u,2*u,2*u);break}h+=I;case"rectRot":s=Math.cos(h)*n,l=Math.sin(h)*n,t.moveTo(i-s,a-l),t.lineTo(i+l,a-s),t.lineTo(i+s,a+l),t.lineTo(i-l,a+s),t.closePath();break;case"crossRot":h+=I;case"cross":s=Math.cos(h)*n,l=Math.sin(h)*n,t.moveTo(i-s,a-l),t.lineTo(i+s,a+l),t.moveTo(i+l,a-s),t.lineTo(i-l,a+s);break;case"star":s=Math.cos(h)*n,l=Math.sin(h)*n,t.moveTo(i-s,a-l),t.lineTo(i+s,a+l),t.moveTo(i+l,a-s),t.lineTo(i-l,a+s),h+=I,s=Math.cos(h)*n,l=Math.sin(h)*n,t.moveTo(i-s,a-l),t.lineTo(i+s,a+l),t.moveTo(i+l,a-s),t.lineTo(i-l,a+s);break;case"line":s=Math.cos(h)*n,l=Math.sin(h)*n,t.moveTo(i-s,a-l),t.lineTo(i+s,a+l);break;case"dash":t.moveTo(i,a),t.lineTo(i+Math.cos(h)*n,a+Math.sin(h)*n)}t.fill(),t.stroke()}},_isPointInArea:function(t,e){return t.x>e.left-1e-6&&t.x<e.right+1e-6&&t.y>e.top-1e-6&&t.y<e.bottom+1e-6},clipArea:function(t,e){t.save(),t.beginPath(),t.rect(e.left,e.top,e.right-e.left,e.bottom-e.top),t.clip()},unclipArea:function(t){t.restore()},lineTo:function(t,e,n,i){var a=n.steppedLine;if(a){if("middle"===a){var r=(e.x+n.x)/2;t.lineTo(r,i?n.y:e.y),t.lineTo(r,i?e.y:n.y)}else"after"===a&&!i||"after"!==a&&i?t.lineTo(e.x,n.y):t.lineTo(n.x,e.y);t.lineTo(n.x,n.y)}else n.tension?t.bezierCurveTo(i?e.controlPointPreviousX:e.controlPointNextX,i?e.controlPointPreviousY:e.controlPointNextY,i?n.controlPointNextX:n.controlPointPreviousX,i?n.controlPointNextY:n.controlPointPreviousY,n.x,n.y):t.lineTo(n.x,n.y)}},O=L;M.clear=L.clear,M.drawRoundedRectangle=function(t){t.beginPath(),L.roundedRect.apply(L,arguments)};var R={_set:function(t,e){return M.merge(this[t]||(this[t]={}),e)}};R._set("global",{defaultColor:"rgba(0,0,0,0.1)",defaultFontColor:"#666",defaultFontFamily:"'Helvetica Neue', 'Helvetica', 'Arial', sans-serif",defaultFontSize:12,defaultFontStyle:"normal",defaultLineHeight:1.2,showLines:!0});var z=R,N=M.valueOrDefault;var B={toLineHeight:function(t,e){var n=(""+t).match(/^(normal|(\d+(?:\.\d+)?)(px|em|%)?)$/);if(!n||"normal"===n[1])return 1.2*e;switch(t=+n[2],n[3]){case"px":return t;case"%":t/=100}return e*t},toPadding:function(t){var e,n,i,a;return M.isObject(t)?(e=+t.top||0,n=+t.right||0,i=+t.bottom||0,a=+t.left||0):e=n=i=a=+t||0,{top:e,right:n,bottom:i,left:a,height:e+i,width:a+n}},_parseFont:function(t){var e=z.global,n=N(t.fontSize,e.defaultFontSize),i={family:N(t.fontFamily,e.defaultFontFamily),lineHeight:M.options.toLineHeight(N(t.lineHeight,e.defaultLineHeight),n),size:n,style:N(t.fontStyle,e.defaultFontStyle),weight:null,string:""};return i.string=function(t){return!t||M.isNullOrUndef(t.size)||M.isNullOrUndef(t.family)?null:(t.style?t.style+" ":"")+(t.weight?t.weight+" ":"")+t.size+"px "+t.family}(i),i},resolve:function(t,e,n,i){var a,r,o,s=!0;for(a=0,r=t.length;a<r;++a)if(void 0!==(o=t[a])&&(void 0!==e&&"function"==typeof o&&(o=o(e),s=!1),void 0!==n&&M.isArray(o)&&(o=o[n],s=!1),void 0!==o))return i&&!s&&(i.cacheable=!1),o}},E={_factorize:function(t){var e,n=[],i=Math.sqrt(t);for(e=1;e<i;e++)t%e==0&&(n.push(e),n.push(t/e));return i===(0|i)&&n.push(i),n.sort((function(t,e){return t-e})).pop(),n},log10:Math.log10||function(t){var e=Math.log(t)*Math.LOG10E,n=Math.round(e);return t===Math.pow(10,n)?n:e}},W=E;M.log10=E.log10;var V=M,H=C,j=O,q=B,U=W,Y={getRtlAdapter:function(t,e,n){return t?function(t,e){return{x:function(n){return t+t+e-n},setWidth:function(t){e=t},textAlign:function(t){return"center"===t?t:"right"===t?"left":"right"},xPlus:function(t,e){return t-e},leftForLtr:function(t,e){return t-e}}}(e,n):{x:function(t){return t},setWidth:function(t){},textAlign:function(t){return t},xPlus:function(t,e){return t+e},leftForLtr:function(t,e){return t}}},overrideTextDirection:function(t,e){var n,i;"ltr"!==e&&"rtl"!==e||(i=[(n=t.canvas.style).getPropertyValue("direction"),n.getPropertyPriority("direction")],n.setProperty("direction",e,"important"),t.prevTextDirection=i)},restoreTextDirection:function(t){var e=t.prevTextDirection;void 0!==e&&(delete t.prevTextDirection,t.canvas.style.setProperty("direction",e[0],e[1]))}};V.easing=H,V.canvas=j,V.options=q,V.math=U,V.rtl=Y;var G=function(t){V.extend(this,t),this.initialize.apply(this,arguments)};V.extend(G.prototype,{_type:void 0,initialize:function(){this.hidden=!1},pivot:function(){var t=this;return t._view||(t._view=V.extend({},t._model)),t._start={},t},transition:function(t){var e=this,n=e._model,i=e._start,a=e._view;return n&&1!==t?(a||(a=e._view={}),i||(i=e._start={}),function(t,e,n,i){var a,r,o,s,l,u,d,h,c,f=Object.keys(n);for(a=0,r=f.length;a<r;++a)if(u=n[o=f[a]],e.hasOwnProperty(o)||(e[o]=u),(s=e[o])!==u&&"_"!==o[0]){if(t.hasOwnProperty(o)||(t[o]=s),(d=typeof u)===typeof(l=t[o]))if("string"===d){if((h=k(l)).valid&&(c=k(u)).valid){e[o]=c.mix(h,i).rgbString();continue}}else if(V.isFinite(l)&&V.isFinite(u)){e[o]=l+(u-l)*i;continue}e[o]=u}}(i,a,n,t),e):(e._view=V.extend({},n),e._start=null,e)},tooltipPosition:function(){return{x:this._model.x,y:this._model.y}},hasValue:function(){return V.isNumber(this._model.x)&&V.isNumber(this._model.y)}}),G.extend=V.inherits;var X=G,K=X.extend({chart:null,currentStep:0,numSteps:60,easing:"",render:null,onAnimationProgress:null,onAnimationComplete:null}),Z=K;Object.defineProperty(K.prototype,"animationObject",{get:function(){return this}}),Object.defineProperty(K.prototype,"chartInstance",{get:function(){return this.chart},set:function(t){this.chart=t}}),z._set("global",{animation:{duration:1e3,easing:"easeOutQuart",onProgress:V.noop,onComplete:V.noop}});var $={animations:[],request:null,addAnimation:function(t,e,n,i){var a,r,o=this.animations;for(e.chart=t,e.startTime=Date.now(),e.duration=n,i||(t.animating=!0),a=0,r=o.length;a<r;++a)if(o[a].chart===t)return void(o[a]=e);o.push(e),1===o.length&&this.requestAnimationFrame()},cancelAnimation:function(t){var e=V.findIndex(this.animations,(function(e){return e.chart===t}));-1!==e&&(this.animations.splice(e,1),t.animating=!1)},requestAnimationFrame:function(){var t=this;null===t.request&&(t.request=V.requestAnimFrame.call(window,(function(){t.request=null,t.startDigest()})))},startDigest:function(){this.advance(),this.animations.length>0&&this.requestAnimationFrame()},advance:function(){for(var t,e,n,i,a=this.animations,r=0;r<a.length;)e=(t=a[r]).chart,n=t.numSteps,i=Math.floor((Date.now()-t.startTime)/t.duration*n)+1,t.currentStep=Math.min(i,n),V.callback(t.render,[e,t],e),V.callback(t.onAnimationProgress,[t],e),t.currentStep>=n?(V.callback(t.onAnimationComplete,[t],e),e.animating=!1,a.splice(r,1)):++r}},J=V.options.resolve,Q=["push","pop","shift","splice","unshift"];function tt(t,e){var n=t._chartjs;if(n){var i=n.listeners,a=i.indexOf(e);-1!==a&&i.splice(a,1),i.length>0||(Q.forEach((function(e){delete t[e]})),delete t._chartjs)}}var et=function(t,e){this.initialize(t,e)};V.extend(et.prototype,{datasetElementType:null,dataElementType:null,_datasetElementOptions:["backgroundColor","borderCapStyle","borderColor","borderDash","borderDashOffset","borderJoinStyle","borderWidth"],_dataElementOptions:["backgroundColor","borderColor","borderWidth","pointStyle"],initialize:function(t,e){var n=this;n.chart=t,n.index=e,n.linkScales(),n.addElements(),n._type=n.getMeta().type},updateIndex:function(t){this.index=t},linkScales:function(){var t=this.getMeta(),e=this.chart,n=e.scales,i=this.getDataset(),a=e.options.scales;null!==t.xAxisID&&t.xAxisID in n&&!i.xAxisID||(t.xAxisID=i.xAxisID||a.xAxes[0].id),null!==t.yAxisID&&t.yAxisID in n&&!i.yAxisID||(t.yAxisID=i.yAxisID||a.yAxes[0].id)},getDataset:function(){return this.chart.data.datasets[this.index]},getMeta:function(){return this.chart.getDatasetMeta(this.index)},getScaleForId:function(t){return this.chart.scales[t]},_getValueScaleId:function(){return this.getMeta().yAxisID},_getIndexScaleId:function(){return this.getMeta().xAxisID},_getValueScale:function(){return this.getScaleForId(this._getValueScaleId())},_getIndexScale:function(){return this.getScaleForId(this._getIndexScaleId())},reset:function(){this._update(!0)},destroy:function(){this._data&&tt(this._data,this)},createMetaDataset:function(){var t=this.datasetElementType;return t&&new t({_chart:this.chart,_datasetIndex:this.index})},createMetaData:function(t){var e=this.dataElementType;return e&&new e({_chart:this.chart,_datasetIndex:this.index,_index:t})},addElements:function(){var t,e,n=this.getMeta(),i=this.getDataset().data||[],a=n.data;for(t=0,e=i.length;t<e;++t)a[t]=a[t]||this.createMetaData(t);n.dataset=n.dataset||this.createMetaDataset()},addElementAndReset:function(t){var e=this.createMetaData(t);this.getMeta().data.splice(t,0,e),this.updateElement(e,t,!0)},buildOrUpdateElements:function(){var t,e,n=this,i=n.getDataset(),a=i.data||(i.data=[]);n._data!==a&&(n._data&&tt(n._data,n),a&&Object.isExtensible(a)&&(e=n,(t=a)._chartjs?t._chartjs.listeners.push(e):(Object.defineProperty(t,"_chartjs",{configurable:!0,enumerable:!1,value:{listeners:[e]}}),Q.forEach((function(e){var n="onData"+e.charAt(0).toUpperCase()+e.slice(1),i=t[e];Object.defineProperty(t,e,{configurable:!0,enumerable:!1,value:function(){var e=Array.prototype.slice.call(arguments),a=i.apply(this,e);return V.each(t._chartjs.listeners,(function(t){"function"==typeof t[n]&&t[n].apply(t,e)})),a}})})))),n._data=a),n.resyncElements()},_configure:function(){this._config=V.merge({},[this.chart.options.datasets[this._type],this.getDataset()],{merger:function(t,e,n){"_meta"!==t&&"data"!==t&&V._merger(t,e,n)}})},_update:function(t){this._configure(),this._cachedDataOpts=null,this.update(t)},update:V.noop,transition:function(t){for(var e=this.getMeta(),n=e.data||[],i=n.length,a=0;a<i;++a)n[a].transition(t);e.dataset&&e.dataset.transition(t)},draw:function(){var t=this.getMeta(),e=t.data||[],n=e.length,i=0;for(t.dataset&&t.dataset.draw();i<n;++i)e[i].draw()},getStyle:function(t){var e,n=this.getMeta(),i=n.dataset;return this._configure(),i&&void 0===t?e=this._resolveDatasetElementOptions(i||{}):(t=t||0,e=this._resolveDataElementOptions(n.data[t]||{},t)),!1!==e.fill&&null!==e.fill||(e.backgroundColor=e.borderColor),e},_resolveDatasetElementOptions:function(t,e){var n,i,a,r,o=this,s=o.chart,l=o._config,u=t.custom||{},d=s.options.elements[o.datasetElementType.prototype._type]||{},h=o._datasetElementOptions,c={},f={chart:s,dataset:o.getDataset(),datasetIndex:o.index,hover:e};for(n=0,i=h.length;n<i;++n)a=h[n],r=e?"hover"+a.charAt(0).toUpperCase()+a.slice(1):a,c[a]=J([u[r],l[r],d[r]],f);return c},_resolveDataElementOptions:function(t,e){var n=this,i=t&&t.custom,a=n._cachedDataOpts;if(a&&!i)return a;var r,o,s,l,u=n.chart,d=n._config,h=u.options.elements[n.dataElementType.prototype._type]||{},c=n._dataElementOptions,f={},g={chart:u,dataIndex:e,dataset:n.getDataset(),datasetIndex:n.index},p={cacheable:!i};if(i=i||{},V.isArray(c))for(o=0,s=c.length;o<s;++o)f[l=c[o]]=J([i[l],d[l],h[l]],g,e,p);else for(o=0,s=(r=Object.keys(c)).length;o<s;++o)f[l=r[o]]=J([i[l],d[c[l]],d[l],h[l]],g,e,p);return p.cacheable&&(n._cachedDataOpts=Object.freeze(f)),f},removeHoverStyle:function(t){V.merge(t._model,t.$previousStyle||{}),delete t.$previousStyle},setHoverStyle:function(t){var e=this.chart.data.datasets[t._datasetIndex],n=t._index,i=t.custom||{},a=t._model,r=V.getHoverColor;t.$previousStyle={backgroundColor:a.backgroundColor,borderColor:a.borderColor,borderWidth:a.borderWidth},a.backgroundColor=J([i.hoverBackgroundColor,e.hoverBackgroundColor,r(a.backgroundColor)],void 0,n),a.borderColor=J([i.hoverBorderColor,e.hoverBorderColor,r(a.borderColor)],void 0,n),a.borderWidth=J([i.hoverBorderWidth,e.hoverBorderWidth,a.borderWidth],void 0,n)},_removeDatasetHoverStyle:function(){var t=this.getMeta().dataset;t&&this.removeHoverStyle(t)},_setDatasetHoverStyle:function(){var t,e,n,i,a,r,o=this.getMeta().dataset,s={};if(o){for(r=o._model,a=this._resolveDatasetElementOptions(o,!0),t=0,e=(i=Object.keys(a)).length;t<e;++t)s[n=i[t]]=r[n],r[n]=a[n];o.$previousStyle=s}},resyncElements:function(){var t=this.getMeta(),e=this.getDataset().data,n=t.data.length,i=e.length;i<n?t.data.splice(i,n-i):i>n&&this.insertElements(n,i-n)},insertElements:function(t,e){for(var n=0;n<e;++n)this.addElementAndReset(t+n)},onDataPush:function(){var t=arguments.length;this.insertElements(this.getDataset().data.length-t,t)},onDataPop:function(){this.getMeta().data.pop()},onDataShift:function(){this.getMeta().data.shift()},onDataSplice:function(t,e){this.getMeta().data.splice(t,e),this.insertElements(t,arguments.length-2)},onDataUnshift:function(){this.insertElements(0,arguments.length)}}),et.extend=V.inherits;var nt=et,it=2*Math.PI;function at(t,e){var n=e.startAngle,i=e.endAngle,a=e.pixelMargin,r=a/e.outerRadius,o=e.x,s=e.y;t.beginPath(),t.arc(o,s,e.outerRadius,n-r,i+r),e.innerRadius>a?(r=a/e.innerRadius,t.arc(o,s,e.innerRadius-a,i+r,n-r,!0)):t.arc(o,s,a,i+Math.PI/2,n-Math.PI/2),t.closePath(),t.clip()}function rt(t,e,n){var i="inner"===e.borderAlign;i?(t.lineWidth=2*e.borderWidth,t.lineJoin="round"):(t.lineWidth=e.borderWidth,t.lineJoin="bevel"),n.fullCircles&&function(t,e,n,i){var a,r=n.endAngle;for(i&&(n.endAngle=n.startAngle+it,at(t,n),n.endAngle=r,n.endAngle===n.startAngle&&n.fullCircles&&(n.endAngle+=it,n.fullCircles--)),t.beginPath(),t.arc(n.x,n.y,n.innerRadius,n.startAngle+it,n.startAngle,!0),a=0;a<n.fullCircles;++a)t.stroke();for(t.beginPath(),t.arc(n.x,n.y,e.outerRadius,n.startAngle,n.startAngle+it),a=0;a<n.fullCircles;++a)t.stroke()}(t,e,n,i),i&&at(t,n),t.beginPath(),t.arc(n.x,n.y,e.outerRadius,n.startAngle,n.endAngle),t.arc(n.x,n.y,n.innerRadius,n.endAngle,n.startAngle,!0),t.closePath(),t.stroke()}z._set("global",{elements:{arc:{backgroundColor:z.global.defaultColor,borderColor:"#fff",borderWidth:2,borderAlign:"center"}}});var ot=X.extend({_type:"arc",inLabelRange:function(t){var e=this._view;return!!e&&Math.pow(t-e.x,2)<Math.pow(e.radius+e.hoverRadius,2)},inRange:function(t,e){var n=this._view;if(n){for(var i=V.getAngleFromPoint(n,{x:t,y:e}),a=i.angle,r=i.distance,o=n.startAngle,s=n.endAngle;s<o;)s+=it;for(;a>s;)a-=it;for(;a<o;)a+=it;var l=a>=o&&a<=s,u=r>=n.innerRadius&&r<=n.outerRadius;return l&&u}return!1},getCenterPoint:function(){var t=this._view,e=(t.startAngle+t.endAngle)/2,n=(t.innerRadius+t.outerRadius)/2;return{x:t.x+Math.cos(e)*n,y:t.y+Math.sin(e)*n}},getArea:function(){var t=this._view;return Math.PI*((t.endAngle-t.startAngle)/(2*Math.PI))*(Math.pow(t.outerRadius,2)-Math.pow(t.innerRadius,2))},tooltipPosition:function(){var t=this._view,e=t.startAngle+(t.endAngle-t.startAngle)/2,n=(t.outerRadius-t.innerRadius)/2+t.innerRadius;return{x:t.x+Math.cos(e)*n,y:t.y+Math.sin(e)*n}},draw:function(){var t,e=this._chart.ctx,n=this._view,i="inner"===n.borderAlign?.33:0,a={x:n.x,y:n.y,innerRadius:n.innerRadius,outerRadius:Math.max(n.outerRadius-i,0),pixelMargin:i,startAngle:n.startAngle,endAngle:n.endAngle,fullCircles:Math.floor(n.circumference/it)};if(e.save(),e.fillStyle=n.backgroundColor,e.strokeStyle=n.borderColor,a.fullCircles){for(a.endAngle=a.startAngle+it,e.beginPath(),e.arc(a.x,a.y,a.outerRadius,a.startAngle,a.endAngle),e.arc(a.x,a.y,a.innerRadius,a.endAngle,a.startAngle,!0),e.closePath(),t=0;t<a.fullCircles;++t)e.fill();a.endAngle=a.startAngle+n.circumference%it}e.beginPath(),e.arc(a.x,a.y,a.outerRadius,a.startAngle,a.endAngle),e.arc(a.x,a.y,a.innerRadius,a.endAngle,a.startAngle,!0),e.closePath(),e.fill(),n.borderWidth&&rt(e,n,a),e.restore()}}),st=V.valueOrDefault,lt=z.global.defaultColor;z._set("global",{elements:{line:{tension:.4,backgroundColor:lt,borderWidth:3,borderColor:lt,borderCapStyle:"butt",borderDash:[],borderDashOffset:0,borderJoinStyle:"miter",capBezierPoints:!0,fill:!0}}});var ut=X.extend({_type:"line",draw:function(){var t,e,n,i=this,a=i._view,r=i._chart.ctx,o=a.spanGaps,s=i._children.slice(),l=z.global,u=l.elements.line,d=-1,h=i._loop;if(s.length){if(i._loop){for(t=0;t<s.length;++t)if(e=V.previousItem(s,t),!s[t]._view.skip&&e._view.skip){s=s.slice(t).concat(s.slice(0,t)),h=o;break}h&&s.push(s[0])}for(r.save(),r.lineCap=a.borderCapStyle||u.borderCapStyle,r.setLineDash&&r.setLineDash(a.borderDash||u.borderDash),r.lineDashOffset=st(a.borderDashOffset,u.borderDashOffset),r.lineJoin=a.borderJoinStyle||u.borderJoinStyle,r.lineWidth=st(a.borderWidth,u.borderWidth),r.strokeStyle=a.borderColor||l.defaultColor,r.beginPath(),(n=s[0]._view).skip||(r.moveTo(n.x,n.y),d=0),t=1;t<s.length;++t)n=s[t]._view,e=-1===d?V.previousItem(s,t):s[d],n.skip||(d!==t-1&&!o||-1===d?r.moveTo(n.x,n.y):V.canvas.lineTo(r,e._view,n),d=t);h&&r.closePath(),r.stroke(),r.restore()}}}),dt=V.valueOrDefault,ht=z.global.defaultColor;function ct(t){var e=this._view;return!!e&&Math.abs(t-e.x)<e.radius+e.hitRadius}z._set("global",{elements:{point:{radius:3,pointStyle:"circle",backgroundColor:ht,borderColor:ht,borderWidth:1,hitRadius:1,hoverRadius:4,hoverBorderWidth:1}}});var ft=X.extend({_type:"point",inRange:function(t,e){var n=this._view;return!!n&&Math.pow(t-n.x,2)+Math.pow(e-n.y,2)<Math.pow(n.hitRadius+n.radius,2)},inLabelRange:ct,inXRange:ct,inYRange:function(t){var e=this._view;return!!e&&Math.abs(t-e.y)<e.radius+e.hitRadius},getCenterPoint:function(){var t=this._view;return{x:t.x,y:t.y}},getArea:function(){return Math.PI*Math.pow(this._view.radius,2)},tooltipPosition:function(){var t=this._view;return{x:t.x,y:t.y,padding:t.radius+t.borderWidth}},draw:function(t){var e=this._view,n=this._chart.ctx,i=e.pointStyle,a=e.rotation,r=e.radius,o=e.x,s=e.y,l=z.global,u=l.defaultColor;e.skip||(void 0===t||V.canvas._isPointInArea(e,t))&&(n.strokeStyle=e.borderColor||u,n.lineWidth=dt(e.borderWidth,l.elements.point.borderWidth),n.fillStyle=e.backgroundColor||u,V.canvas.drawPoint(n,i,r,o,s,a))}}),gt=z.global.defaultColor;function pt(t){return t&&void 0!==t.width}function mt(t){var e,n,i,a,r;return pt(t)?(r=t.width/2,e=t.x-r,n=t.x+r,i=Math.min(t.y,t.base),a=Math.max(t.y,t.base)):(r=t.height/2,e=Math.min(t.x,t.base),n=Math.max(t.x,t.base),i=t.y-r,a=t.y+r),{left:e,top:i,right:n,bottom:a}}function vt(t,e,n){return t===e?n:t===n?e:t}function bt(t,e,n){var i,a,r,o,s=t.borderWidth,l=function(t){var e=t.borderSkipped,n={};return e?(t.horizontal?t.base>t.x&&(e=vt(e,"left","right")):t.base<t.y&&(e=vt(e,"bottom","top")),n[e]=!0,n):n}(t);return V.isObject(s)?(i=+s.top||0,a=+s.right||0,r=+s.bottom||0,o=+s.left||0):i=a=r=o=+s||0,{t:l.top||i<0?0:i>n?n:i,r:l.right||a<0?0:a>e?e:a,b:l.bottom||r<0?0:r>n?n:r,l:l.left||o<0?0:o>e?e:o}}function xt(t,e,n){var i=null===e,a=null===n,r=!(!t||i&&a)&&mt(t);return r&&(i||e>=r.left&&e<=r.right)&&(a||n>=r.top&&n<=r.bottom)}z._set("global",{elements:{rectangle:{backgroundColor:gt,borderColor:gt,borderSkipped:"bottom",borderWidth:0}}});var yt=X.extend({_type:"rectangle",draw:function(){var t=this._chart.ctx,e=this._view,n=function(t){var e=mt(t),n=e.right-e.left,i=e.bottom-e.top,a=bt(t,n/2,i/2);return{outer:{x:e.left,y:e.top,w:n,h:i},inner:{x:e.left+a.l,y:e.top+a.t,w:n-a.l-a.r,h:i-a.t-a.b}}}(e),i=n.outer,a=n.inner;t.fillStyle=e.backgroundColor,t.fillRect(i.x,i.y,i.w,i.h),i.w===a.w&&i.h===a.h||(t.save(),t.beginPath(),t.rect(i.x,i.y,i.w,i.h),t.clip(),t.fillStyle=e.borderColor,t.rect(a.x,a.y,a.w,a.h),t.fill("evenodd"),t.restore())},height:function(){var t=this._view;return t.base-t.y},inRange:function(t,e){return xt(this._view,t,e)},inLabelRange:function(t,e){var n=this._view;return pt(n)?xt(n,t,null):xt(n,null,e)},inXRange:function(t){return xt(this._view,t,null)},inYRange:function(t){return xt(this._view,null,t)},getCenterPoint:function(){var t,e,n=this._view;return pt(n)?(t=n.x,e=(n.y+n.base)/2):(t=(n.x+n.base)/2,e=n.y),{x:t,y:e}},getArea:function(){var t=this._view;return pt(t)?t.width*Math.abs(t.y-t.base):t.height*Math.abs(t.x-t.base)},tooltipPosition:function(){var t=this._view;return{x:t.x,y:t.y}}}),_t={},kt=ot,wt=ut,Mt=ft,St=yt;_t.Arc=kt,_t.Line=wt,_t.Point=Mt,_t.Rectangle=St;var Ct=V._deprecated,Pt=V.valueOrDefault;function At(t,e,n){var i,a,r=n.barThickness,o=e.stackCount,s=e.pixels[t],l=V.isNullOrUndef(r)?function(t,e){var n,i,a,r,o=t._length;for(a=1,r=e.length;a<r;++a)o=Math.min(o,Math.abs(e[a]-e[a-1]));for(a=0,r=t.getTicks().length;a<r;++a)i=t.getPixelForTick(a),o=a>0?Math.min(o,Math.abs(i-n)):o,n=i;return o}(e.scale,e.pixels):-1;return V.isNullOrUndef(r)?(i=l*n.categoryPercentage,a=n.barPercentage):(i=r*o,a=1),{chunk:i/o,ratio:a,start:s-i/2}}z._set("bar",{hover:{mode:"label"},scales:{xAxes:[{type:"category",offset:!0,gridLines:{offsetGridLines:!0}}],yAxes:[{type:"linear"}]}}),z._set("global",{datasets:{bar:{categoryPercentage:.8,barPercentage:.9}}});var Dt=nt.extend({dataElementType:_t.Rectangle,_dataElementOptions:["backgroundColor","borderColor","borderSkipped","borderWidth","barPercentage","barThickness","categoryPercentage","maxBarThickness","minBarLength"],initialize:function(){var t,e,n=this;nt.prototype.initialize.apply(n,arguments),(t=n.getMeta()).stack=n.getDataset().stack,t.bar=!0,e=n._getIndexScale().options,Ct("bar chart",e.barPercentage,"scales.[x/y]Axes.barPercentage","dataset.barPercentage"),Ct("bar chart",e.barThickness,"scales.[x/y]Axes.barThickness","dataset.barThickness"),Ct("bar chart",e.categoryPercentage,"scales.[x/y]Axes.categoryPercentage","dataset.categoryPercentage"),Ct("bar chart",n._getValueScale().options.minBarLength,"scales.[x/y]Axes.minBarLength","dataset.minBarLength"),Ct("bar chart",e.maxBarThickness,"scales.[x/y]Axes.maxBarThickness","dataset.maxBarThickness")},update:function(t){var e,n,i=this.getMeta().data;for(this._ruler=this.getRuler(),e=0,n=i.length;e<n;++e)this.updateElement(i[e],e,t)},updateElement:function(t,e,n){var i=this,a=i.getMeta(),r=i.getDataset(),o=i._resolveDataElementOptions(t,e);t._xScale=i.getScaleForId(a.xAxisID),t._yScale=i.getScaleForId(a.yAxisID),t._datasetIndex=i.index,t._index=e,t._model={backgroundColor:o.backgroundColor,borderColor:o.borderColor,borderSkipped:o.borderSkipped,borderWidth:o.borderWidth,datasetLabel:r.label,label:i.chart.data.labels[e]},V.isArray(r.data[e])&&(t._model.borderSkipped=null),i._updateElementGeometry(t,e,n,o),t.pivot()},_updateElementGeometry:function(t,e,n,i){var a=this,r=t._model,o=a._getValueScale(),s=o.getBasePixel(),l=o.isHorizontal(),u=a._ruler||a.getRuler(),d=a.calculateBarValuePixels(a.index,e,i),h=a.calculateBarIndexPixels(a.index,e,u,i);r.horizontal=l,r.base=n?s:d.base,r.x=l?n?s:d.head:h.center,r.y=l?h.center:n?s:d.head,r.height=l?h.size:void 0,r.width=l?void 0:h.size},_getStacks:function(t){var e,n,i=this._getIndexScale(),a=i._getMatchingVisibleMetas(this._type),r=i.options.stacked,o=a.length,s=[];for(e=0;e<o&&(n=a[e],(!1===r||-1===s.indexOf(n.stack)||void 0===r&&void 0===n.stack)&&s.push(n.stack),n.index!==t);++e);return s},getStackCount:function(){return this._getStacks().length},getStackIndex:function(t,e){var n=this._getStacks(t),i=void 0!==e?n.indexOf(e):-1;return-1===i?n.length-1:i},getRuler:function(){var t,e,n=this._getIndexScale(),i=[];for(t=0,e=this.getMeta().data.length;t<e;++t)i.push(n.getPixelForValue(null,t,this.index));return{pixels:i,start:n._startPixel,end:n._endPixel,stackCount:this.getStackCount(),scale:n}},calculateBarValuePixels:function(t,e,n){var i,a,r,o,s,l,u,d=this.chart,h=this._getValueScale(),c=h.isHorizontal(),f=d.data.datasets,g=h._getMatchingVisibleMetas(this._type),p=h._parseValue(f[t].data[e]),m=n.minBarLength,v=h.options.stacked,b=this.getMeta().stack,x=void 0===p.start?0:p.max>=0&&p.min>=0?p.min:p.max,y=void 0===p.start?p.end:p.max>=0&&p.min>=0?p.max-p.min:p.min-p.max,_=g.length;if(v||void 0===v&&void 0!==b)for(i=0;i<_&&(a=g[i]).index!==t;++i)a.stack===b&&(r=void 0===(u=h._parseValue(f[a.index].data[e])).start?u.end:u.min>=0&&u.max>=0?u.max:u.min,(p.min<0&&r<0||p.max>=0&&r>0)&&(x+=r));return o=h.getPixelForValue(x),l=(s=h.getPixelForValue(x+y))-o,void 0!==m&&Math.abs(l)<m&&(l=m,s=y>=0&&!c||y<0&&c?o-m:o+m),{size:l,base:o,head:s,center:s+l/2}},calculateBarIndexPixels:function(t,e,n,i){var a="flex"===i.barThickness?function(t,e,n){var i,a=e.pixels,r=a[t],o=t>0?a[t-1]:null,s=t<a.length-1?a[t+1]:null,l=n.categoryPercentage;return null===o&&(o=r-(null===s?e.end-e.start:s-r)),null===s&&(s=r+r-o),i=r-(r-Math.min(o,s))/2*l,{chunk:Math.abs(s-o)/2*l/e.stackCount,ratio:n.barPercentage,start:i}}(e,n,i):At(e,n,i),r=this.getStackIndex(t,this.getMeta().stack),o=a.start+a.chunk*r+a.chunk/2,s=Math.min(Pt(i.maxBarThickness,1/0),a.chunk*a.ratio);return{base:o-s/2,head:o+s/2,center:o,size:s}},draw:function(){var t=this.chart,e=this._getValueScale(),n=this.getMeta().data,i=this.getDataset(),a=n.length,r=0;for(V.canvas.clipArea(t.ctx,t.chartArea);r<a;++r){var o=e._parseValue(i.data[r]);isNaN(o.min)||isNaN(o.max)||n[r].draw()}V.canvas.unclipArea(t.ctx)},_resolveDataElementOptions:function(){var t=this,e=V.extend({},nt.prototype._resolveDataElementOptions.apply(t,arguments)),n=t._getIndexScale().options,i=t._getValueScale().options;return e.barPercentage=Pt(n.barPercentage,e.barPercentage),e.barThickness=Pt(n.barThickness,e.barThickness),e.categoryPercentage=Pt(n.categoryPercentage,e.categoryPercentage),e.maxBarThickness=Pt(n.maxBarThickness,e.maxBarThickness),e.minBarLength=Pt(i.minBarLength,e.minBarLength),e}}),Tt=V.valueOrDefault,It=V.options.resolve;z._set("bubble",{hover:{mode:"single"},scales:{xAxes:[{type:"linear",position:"bottom",id:"x-axis-0"}],yAxes:[{type:"linear",position:"left",id:"y-axis-0"}]},tooltips:{callbacks:{title:function(){return""},label:function(t,e){var n=e.datasets[t.datasetIndex].label||"",i=e.datasets[t.datasetIndex].data[t.index];return n+": ("+t.xLabel+", "+t.yLabel+", "+i.r+")"}}}});var Ft=nt.extend({dataElementType:_t.Point,_dataElementOptions:["backgroundColor","borderColor","borderWidth","hoverBackgroundColor","hoverBorderColor","hoverBorderWidth","hoverRadius","hitRadius","pointStyle","rotation"],update:function(t){var e=this,n=e.getMeta().data;V.each(n,(function(n,i){e.updateElement(n,i,t)}))},updateElement:function(t,e,n){var i=this,a=i.getMeta(),r=t.custom||{},o=i.getScaleForId(a.xAxisID),s=i.getScaleForId(a.yAxisID),l=i._resolveDataElementOptions(t,e),u=i.getDataset().data[e],d=i.index,h=n?o.getPixelForDecimal(.5):o.getPixelForValue("object"==typeof u?u:NaN,e,d),c=n?s.getBasePixel():s.getPixelForValue(u,e,d);t._xScale=o,t._yScale=s,t._options=l,t._datasetIndex=d,t._index=e,t._model={backgroundColor:l.backgroundColor,borderColor:l.borderColor,borderWidth:l.borderWidth,hitRadius:l.hitRadius,pointStyle:l.pointStyle,rotation:l.rotation,radius:n?0:l.radius,skip:r.skip||isNaN(h)||isNaN(c),x:h,y:c},t.pivot()},setHoverStyle:function(t){var e=t._model,n=t._options,i=V.getHoverColor;t.$previousStyle={backgroundColor:e.backgroundColor,borderColor:e.borderColor,borderWidth:e.borderWidth,radius:e.radius},e.backgroundColor=Tt(n.hoverBackgroundColor,i(n.backgroundColor)),e.borderColor=Tt(n.hoverBorderColor,i(n.borderColor)),e.borderWidth=Tt(n.hoverBorderWidth,n.borderWidth),e.radius=n.radius+n.hoverRadius},_resolveDataElementOptions:function(t,e){var n=this,i=n.chart,a=n.getDataset(),r=t.custom||{},o=a.data[e]||{},s=nt.prototype._resolveDataElementOptions.apply(n,arguments),l={chart:i,dataIndex:e,dataset:a,datasetIndex:n.index};return n._cachedDataOpts===s&&(s=V.extend({},s)),s.radius=It([r.radius,o.r,n._config.radius,i.options.elements.point.radius],l,e),s}}),Lt=V.valueOrDefault,Ot=Math.PI,Rt=2*Ot,zt=Ot/2;z._set("doughnut",{animation:{animateRotate:!0,animateScale:!1},hover:{mode:"single"},legendCallback:function(t){var e,n,i,a=document.createElement("ul"),r=t.data,o=r.datasets,s=r.labels;if(a.setAttribute("class",t.id+"-legend"),o.length)for(e=0,n=o[0].data.length;e<n;++e)(i=a.appendChild(document.createElement("li"))).appendChild(document.createElement("span")).style.backgroundColor=o[0].backgroundColor[e],s[e]&&i.appendChild(document.createTextNode(s[e]));return a.outerHTML},legend:{labels:{generateLabels:function(t){var e=t.data;return e.labels.length&&e.datasets.length?e.labels.map((function(n,i){var a=t.getDatasetMeta(0),r=a.controller.getStyle(i);return{text:n,fillStyle:r.backgroundColor,strokeStyle:r.borderColor,lineWidth:r.borderWidth,hidden:isNaN(e.datasets[0].data[i])||a.data[i].hidden,index:i}})):[]}},onClick:function(t,e){var n,i,a,r=e.index,o=this.chart;for(n=0,i=(o.data.datasets||[]).length;n<i;++n)(a=o.getDatasetMeta(n)).data[r]&&(a.data[r].hidden=!a.data[r].hidden);o.update()}},cutoutPercentage:50,rotation:-zt,circumference:Rt,tooltips:{callbacks:{title:function(){return""},label:function(t,e){var n=e.labels[t.index],i=": "+e.datasets[t.datasetIndex].data[t.index];return V.isArray(n)?(n=n.slice())[0]+=i:n+=i,n}}}});var Nt=nt.extend({dataElementType:_t.Arc,linkScales:V.noop,_dataElementOptions:["backgroundColor","borderColor","borderWidth","borderAlign","hoverBackgroundColor","hoverBorderColor","hoverBorderWidth"],getRingIndex:function(t){for(var e=0,n=0;n<t;++n)this.chart.isDatasetVisible(n)&&++e;return e},update:function(t){var e,n,i,a,r=this,o=r.chart,s=o.chartArea,l=o.options,u=1,d=1,h=0,c=0,f=r.getMeta(),g=f.data,p=l.cutoutPercentage/100||0,m=l.circumference,v=r._getRingWeight(r.index);if(m<Rt){var b=l.rotation%Rt,x=(b+=b>=Ot?-Rt:b<-Ot?Rt:0)+m,y=Math.cos(b),_=Math.sin(b),k=Math.cos(x),w=Math.sin(x),M=b<=0&&x>=0||x>=Rt,S=b<=zt&&x>=zt||x>=Rt+zt,C=b<=-zt&&x>=-zt||x>=Ot+zt,P=b===-Ot||x>=Ot?-1:Math.min(y,y*p,k,k*p),A=C?-1:Math.min(_,_*p,w,w*p),D=M?1:Math.max(y,y*p,k,k*p),T=S?1:Math.max(_,_*p,w,w*p);u=(D-P)/2,d=(T-A)/2,h=-(D+P)/2,c=-(T+A)/2}for(i=0,a=g.length;i<a;++i)g[i]._options=r._resolveDataElementOptions(g[i],i);for(o.borderWidth=r.getMaxBorderWidth(),e=(s.right-s.left-o.borderWidth)/u,n=(s.bottom-s.top-o.borderWidth)/d,o.outerRadius=Math.max(Math.min(e,n)/2,0),o.innerRadius=Math.max(o.outerRadius*p,0),o.radiusLength=(o.outerRadius-o.innerRadius)/(r._getVisibleDatasetWeightTotal()||1),o.offsetX=h*o.outerRadius,o.offsetY=c*o.outerRadius,f.total=r.calculateTotal(),r.outerRadius=o.outerRadius-o.radiusLength*r._getRingWeightOffset(r.index),r.innerRadius=Math.max(r.outerRadius-o.radiusLength*v,0),i=0,a=g.length;i<a;++i)r.updateElement(g[i],i,t)},updateElement:function(t,e,n){var i=this,a=i.chart,r=a.chartArea,o=a.options,s=o.animation,l=(r.left+r.right)/2,u=(r.top+r.bottom)/2,d=o.rotation,h=o.rotation,c=i.getDataset(),f=n&&s.animateRotate?0:t.hidden?0:i.calculateCircumference(c.data[e])*(o.circumference/Rt),g=n&&s.animateScale?0:i.innerRadius,p=n&&s.animateScale?0:i.outerRadius,m=t._options||{};V.extend(t,{_datasetIndex:i.index,_index:e,_model:{backgroundColor:m.backgroundColor,borderColor:m.borderColor,borderWidth:m.borderWidth,borderAlign:m.borderAlign,x:l+a.offsetX,y:u+a.offsetY,startAngle:d,endAngle:h,circumference:f,outerRadius:p,innerRadius:g,label:V.valueAtIndexOrDefault(c.label,e,a.data.labels[e])}});var v=t._model;n&&s.animateRotate||(v.startAngle=0===e?o.rotation:i.getMeta().data[e-1]._model.endAngle,v.endAngle=v.startAngle+v.circumference),t.pivot()},calculateTotal:function(){var t,e=this.getDataset(),n=this.getMeta(),i=0;return V.each(n.data,(function(n,a){t=e.data[a],isNaN(t)||n.hidden||(i+=Math.abs(t))})),i},calculateCircumference:function(t){var e=this.getMeta().total;return e>0&&!isNaN(t)?Rt*(Math.abs(t)/e):0},getMaxBorderWidth:function(t){var e,n,i,a,r,o,s,l,u=0,d=this.chart;if(!t)for(e=0,n=d.data.datasets.length;e<n;++e)if(d.isDatasetVisible(e)){t=(i=d.getDatasetMeta(e)).data,e!==this.index&&(r=i.controller);break}if(!t)return 0;for(e=0,n=t.length;e<n;++e)a=t[e],r?(r._configure(),o=r._resolveDataElementOptions(a,e)):o=a._options,"inner"!==o.borderAlign&&(s=o.borderWidth,u=(l=o.hoverBorderWidth)>(u=s>u?s:u)?l:u);return u},setHoverStyle:function(t){var e=t._model,n=t._options,i=V.getHoverColor;t.$previousStyle={backgroundColor:e.backgroundColor,borderColor:e.borderColor,borderWidth:e.borderWidth},e.backgroundColor=Lt(n.hoverBackgroundColor,i(n.backgroundColor)),e.borderColor=Lt(n.hoverBorderColor,i(n.borderColor)),e.borderWidth=Lt(n.hoverBorderWidth,n.borderWidth)},_getRingWeightOffset:function(t){for(var e=0,n=0;n<t;++n)this.chart.isDatasetVisible(n)&&(e+=this._getRingWeight(n));return e},_getRingWeight:function(t){return Math.max(Lt(this.chart.data.datasets[t].weight,1),0)},_getVisibleDatasetWeightTotal:function(){return this._getRingWeightOffset(this.chart.data.datasets.length)}});z._set("horizontalBar",{hover:{mode:"index",axis:"y"},scales:{xAxes:[{type:"linear",position:"bottom"}],yAxes:[{type:"category",position:"left",offset:!0,gridLines:{offsetGridLines:!0}}]},elements:{rectangle:{borderSkipped:"left"}},tooltips:{mode:"index",axis:"y"}}),z._set("global",{datasets:{horizontalBar:{categoryPercentage:.8,barPercentage:.9}}});var Bt=Dt.extend({_getValueScaleId:function(){return this.getMeta().xAxisID},_getIndexScaleId:function(){return this.getMeta().yAxisID}}),Et=V.valueOrDefault,Wt=V.options.resolve,Vt=V.canvas._isPointInArea;function Ht(t,e){var n=t&&t.options.ticks||{},i=n.reverse,a=void 0===n.min?e:0,r=void 0===n.max?e:0;return{start:i?r:a,end:i?a:r}}function jt(t,e,n){var i=n/2,a=Ht(t,i),r=Ht(e,i);return{top:r.end,right:a.end,bottom:r.start,left:a.start}}function qt(t){var e,n,i,a;return V.isObject(t)?(e=t.top,n=t.right,i=t.bottom,a=t.left):e=n=i=a=t,{top:e,right:n,bottom:i,left:a}}z._set("line",{showLines:!0,spanGaps:!1,hover:{mode:"label"},scales:{xAxes:[{type:"category",id:"x-axis-0"}],yAxes:[{type:"linear",id:"y-axis-0"}]}});var Ut=nt.extend({datasetElementType:_t.Line,dataElementType:_t.Point,_datasetElementOptions:["backgroundColor","borderCapStyle","borderColor","borderDash","borderDashOffset","borderJoinStyle","borderWidth","cubicInterpolationMode","fill"],_dataElementOptions:{backgroundColor:"pointBackgroundColor",borderColor:"pointBorderColor",borderWidth:"pointBorderWidth",hitRadius:"pointHitRadius",hoverBackgroundColor:"pointHoverBackgroundColor",hoverBorderColor:"pointHoverBorderColor",hoverBorderWidth:"pointHoverBorderWidth",hoverRadius:"pointHoverRadius",pointStyle:"pointStyle",radius:"pointRadius",rotation:"pointRotation"},update:function(t){var e,n,i=this,a=i.getMeta(),r=a.dataset,o=a.data||[],s=i.chart.options,l=i._config,u=i._showLine=Et(l.showLine,s.showLines);for(i._xScale=i.getScaleForId(a.xAxisID),i._yScale=i.getScaleForId(a.yAxisID),u&&(void 0!==l.tension&&void 0===l.lineTension&&(l.lineTension=l.tension),r._scale=i._yScale,r._datasetIndex=i.index,r._children=o,r._model=i._resolveDatasetElementOptions(r),r.pivot()),e=0,n=o.length;e<n;++e)i.updateElement(o[e],e,t);for(u&&0!==r._model.tension&&i.updateBezierControlPoints(),e=0,n=o.length;e<n;++e)o[e].pivot()},updateElement:function(t,e,n){var i,a,r=this,o=r.getMeta(),s=t.custom||{},l=r.getDataset(),u=r.index,d=l.data[e],h=r._xScale,c=r._yScale,f=o.dataset._model,g=r._resolveDataElementOptions(t,e);i=h.getPixelForValue("object"==typeof d?d:NaN,e,u),a=n?c.getBasePixel():r.calculatePointY(d,e,u),t._xScale=h,t._yScale=c,t._options=g,t._datasetIndex=u,t._index=e,t._model={x:i,y:a,skip:s.skip||isNaN(i)||isNaN(a),radius:g.radius,pointStyle:g.pointStyle,rotation:g.rotation,backgroundColor:g.backgroundColor,borderColor:g.borderColor,borderWidth:g.borderWidth,tension:Et(s.tension,f?f.tension:0),steppedLine:!!f&&f.steppedLine,hitRadius:g.hitRadius}},_resolveDatasetElementOptions:function(t){var e=this,n=e._config,i=t.custom||{},a=e.chart.options,r=a.elements.line,o=nt.prototype._resolveDatasetElementOptions.apply(e,arguments);return o.spanGaps=Et(n.spanGaps,a.spanGaps),o.tension=Et(n.lineTension,r.tension),o.steppedLine=Wt([i.steppedLine,n.steppedLine,r.stepped]),o.clip=qt(Et(n.clip,jt(e._xScale,e._yScale,o.borderWidth))),o},calculatePointY:function(t,e,n){var i,a,r,o,s,l,u,d=this.chart,h=this._yScale,c=0,f=0;if(h.options.stacked){for(s=+h.getRightValue(t),u=(l=d._getSortedVisibleDatasetMetas()).length,i=0;i<u&&(r=l[i]).index!==n;++i)a=d.data.datasets[r.index],"line"===r.type&&r.yAxisID===h.id&&((o=+h.getRightValue(a.data[e]))<0?f+=o||0:c+=o||0);return s<0?h.getPixelForValue(f+s):h.getPixelForValue(c+s)}return h.getPixelForValue(t)},updateBezierControlPoints:function(){var t,e,n,i,a=this.chart,r=this.getMeta(),o=r.dataset._model,s=a.chartArea,l=r.data||[];function u(t,e,n){return Math.max(Math.min(t,n),e)}if(o.spanGaps&&(l=l.filter((function(t){return!t._model.skip}))),"monotone"===o.cubicInterpolationMode)V.splineCurveMonotone(l);else for(t=0,e=l.length;t<e;++t)n=l[t]._model,i=V.splineCurve(V.previousItem(l,t)._model,n,V.nextItem(l,t)._model,o.tension),n.controlPointPreviousX=i.previous.x,n.controlPointPreviousY=i.previous.y,n.controlPointNextX=i.next.x,n.controlPointNextY=i.next.y;if(a.options.elements.line.capBezierPoints)for(t=0,e=l.length;t<e;++t)n=l[t]._model,Vt(n,s)&&(t>0&&Vt(l[t-1]._model,s)&&(n.controlPointPreviousX=u(n.controlPointPreviousX,s.left,s.right),n.controlPointPreviousY=u(n.controlPointPreviousY,s.top,s.bottom)),t<l.length-1&&Vt(l[t+1]._model,s)&&(n.controlPointNextX=u(n.controlPointNextX,s.left,s.right),n.controlPointNextY=u(n.controlPointNextY,s.top,s.bottom)))},draw:function(){var t,e=this.chart,n=this.getMeta(),i=n.data||[],a=e.chartArea,r=e.canvas,o=0,s=i.length;for(this._showLine&&(t=n.dataset._model.clip,V.canvas.clipArea(e.ctx,{left:!1===t.left?0:a.left-t.left,right:!1===t.right?r.width:a.right+t.right,top:!1===t.top?0:a.top-t.top,bottom:!1===t.bottom?r.height:a.bottom+t.bottom}),n.dataset.draw(),V.canvas.unclipArea(e.ctx));o<s;++o)i[o].draw(a)},setHoverStyle:function(t){var e=t._model,n=t._options,i=V.getHoverColor;t.$previousStyle={backgroundColor:e.backgroundColor,borderColor:e.borderColor,borderWidth:e.borderWidth,radius:e.radius},e.backgroundColor=Et(n.hoverBackgroundColor,i(n.backgroundColor)),e.borderColor=Et(n.hoverBorderColor,i(n.borderColor)),e.borderWidth=Et(n.hoverBorderWidth,n.borderWidth),e.radius=Et(n.hoverRadius,n.radius)}}),Yt=V.options.resolve;z._set("polarArea",{scale:{type:"radialLinear",angleLines:{display:!1},gridLines:{circular:!0},pointLabels:{display:!1},ticks:{beginAtZero:!0}},animation:{animateRotate:!0,animateScale:!0},startAngle:-.5*Math.PI,legendCallback:function(t){var e,n,i,a=document.createElement("ul"),r=t.data,o=r.datasets,s=r.labels;if(a.setAttribute("class",t.id+"-legend"),o.length)for(e=0,n=o[0].data.length;e<n;++e)(i=a.appendChild(document.createElement("li"))).appendChild(document.createElement("span")).style.backgroundColor=o[0].backgroundColor[e],s[e]&&i.appendChild(document.createTextNode(s[e]));return a.outerHTML},legend:{labels:{generateLabels:function(t){var e=t.data;return e.labels.length&&e.datasets.length?e.labels.map((function(n,i){var a=t.getDatasetMeta(0),r=a.controller.getStyle(i);return{text:n,fillStyle:r.backgroundColor,strokeStyle:r.borderColor,lineWidth:r.borderWidth,hidden:isNaN(e.datasets[0].data[i])||a.data[i].hidden,index:i}})):[]}},onClick:function(t,e){var n,i,a,r=e.index,o=this.chart;for(n=0,i=(o.data.datasets||[]).length;n<i;++n)(a=o.getDatasetMeta(n)).data[r].hidden=!a.data[r].hidden;o.update()}},tooltips:{callbacks:{title:function(){return""},label:function(t,e){return e.labels[t.index]+": "+t.yLabel}}}});var Gt=nt.extend({dataElementType:_t.Arc,linkScales:V.noop,_dataElementOptions:["backgroundColor","borderColor","borderWidth","borderAlign","hoverBackgroundColor","hoverBorderColor","hoverBorderWidth"],_getIndexScaleId:function(){return this.chart.scale.id},_getValueScaleId:function(){return this.chart.scale.id},update:function(t){var e,n,i,a=this,r=a.getDataset(),o=a.getMeta(),s=a.chart.options.startAngle||0,l=a._starts=[],u=a._angles=[],d=o.data;for(a._updateRadius(),o.count=a.countVisibleElements(),e=0,n=r.data.length;e<n;e++)l[e]=s,i=a._computeAngle(e),u[e]=i,s+=i;for(e=0,n=d.length;e<n;++e)d[e]._options=a._resolveDataElementOptions(d[e],e),a.updateElement(d[e],e,t)},_updateRadius:function(){var t=this,e=t.chart,n=e.chartArea,i=e.options,a=Math.min(n.right-n.left,n.bottom-n.top);e.outerRadius=Math.max(a/2,0),e.innerRadius=Math.max(i.cutoutPercentage?e.outerRadius/100*i.cutoutPercentage:1,0),e.radiusLength=(e.outerRadius-e.innerRadius)/e.getVisibleDatasetCount(),t.outerRadius=e.outerRadius-e.radiusLength*t.index,t.innerRadius=t.outerRadius-e.radiusLength},updateElement:function(t,e,n){var i=this,a=i.chart,r=i.getDataset(),o=a.options,s=o.animation,l=a.scale,u=a.data.labels,d=l.xCenter,h=l.yCenter,c=o.startAngle,f=t.hidden?0:l.getDistanceFromCenterForValue(r.data[e]),g=i._starts[e],p=g+(t.hidden?0:i._angles[e]),m=s.animateScale?0:l.getDistanceFromCenterForValue(r.data[e]),v=t._options||{};V.extend(t,{_datasetIndex:i.index,_index:e,_scale:l,_model:{backgroundColor:v.backgroundColor,borderColor:v.borderColor,borderWidth:v.borderWidth,borderAlign:v.borderAlign,x:d,y:h,innerRadius:0,outerRadius:n?m:f,startAngle:n&&s.animateRotate?c:g,endAngle:n&&s.animateRotate?c:p,label:V.valueAtIndexOrDefault(u,e,u[e])}}),t.pivot()},countVisibleElements:function(){var t=this.getDataset(),e=this.getMeta(),n=0;return V.each(e.data,(function(e,i){isNaN(t.data[i])||e.hidden||n++})),n},setHoverStyle:function(t){var e=t._model,n=t._options,i=V.getHoverColor,a=V.valueOrDefault;t.$previousStyle={backgroundColor:e.backgroundColor,borderColor:e.borderColor,borderWidth:e.borderWidth},e.backgroundColor=a(n.hoverBackgroundColor,i(n.backgroundColor)),e.borderColor=a(n.hoverBorderColor,i(n.borderColor)),e.borderWidth=a(n.hoverBorderWidth,n.borderWidth)},_computeAngle:function(t){var e=this,n=this.getMeta().count,i=e.getDataset(),a=e.getMeta();if(isNaN(i.data[t])||a.data[t].hidden)return 0;var r={chart:e.chart,dataIndex:t,dataset:i,datasetIndex:e.index};return Yt([e.chart.options.elements.arc.angle,2*Math.PI/n],r,t)}});z._set("pie",V.clone(z.doughnut)),z._set("pie",{cutoutPercentage:0});var Xt=Nt,Kt=V.valueOrDefault;z._set("radar",{spanGaps:!1,scale:{type:"radialLinear"},elements:{line:{fill:"start",tension:0}}});var Zt=nt.extend({datasetElementType:_t.Line,dataElementType:_t.Point,linkScales:V.noop,_datasetElementOptions:["backgroundColor","borderWidth","borderColor","borderCapStyle","borderDash","borderDashOffset","borderJoinStyle","fill"],_dataElementOptions:{backgroundColor:"pointBackgroundColor",borderColor:"pointBorderColor",borderWidth:"pointBorderWidth",hitRadius:"pointHitRadius",hoverBackgroundColor:"pointHoverBackgroundColor",hoverBorderColor:"pointHoverBorderColor",hoverBorderWidth:"pointHoverBorderWidth",hoverRadius:"pointHoverRadius",pointStyle:"pointStyle",radius:"pointRadius",rotation:"pointRotation"},_getIndexScaleId:function(){return this.chart.scale.id},_getValueScaleId:function(){return this.chart.scale.id},update:function(t){var e,n,i=this,a=i.getMeta(),r=a.dataset,o=a.data||[],s=i.chart.scale,l=i._config;for(void 0!==l.tension&&void 0===l.lineTension&&(l.lineTension=l.tension),r._scale=s,r._datasetIndex=i.index,r._children=o,r._loop=!0,r._model=i._resolveDatasetElementOptions(r),r.pivot(),e=0,n=o.length;e<n;++e)i.updateElement(o[e],e,t);for(i.updateBezierControlPoints(),e=0,n=o.length;e<n;++e)o[e].pivot()},updateElement:function(t,e,n){var i=this,a=t.custom||{},r=i.getDataset(),o=i.chart.scale,s=o.getPointPositionForValue(e,r.data[e]),l=i._resolveDataElementOptions(t,e),u=i.getMeta().dataset._model,d=n?o.xCenter:s.x,h=n?o.yCenter:s.y;t._scale=o,t._options=l,t._datasetIndex=i.index,t._index=e,t._model={x:d,y:h,skip:a.skip||isNaN(d)||isNaN(h),radius:l.radius,pointStyle:l.pointStyle,rotation:l.rotation,backgroundColor:l.backgroundColor,borderColor:l.borderColor,borderWidth:l.borderWidth,tension:Kt(a.tension,u?u.tension:0),hitRadius:l.hitRadius}},_resolveDatasetElementOptions:function(){var t=this,e=t._config,n=t.chart.options,i=nt.prototype._resolveDatasetElementOptions.apply(t,arguments);return i.spanGaps=Kt(e.spanGaps,n.spanGaps),i.tension=Kt(e.lineTension,n.elements.line.tension),i},updateBezierControlPoints:function(){var t,e,n,i,a=this.getMeta(),r=this.chart.chartArea,o=a.data||[];function s(t,e,n){return Math.max(Math.min(t,n),e)}for(a.dataset._model.spanGaps&&(o=o.filter((function(t){return!t._model.skip}))),t=0,e=o.length;t<e;++t)n=o[t]._model,i=V.splineCurve(V.previousItem(o,t,!0)._model,n,V.nextItem(o,t,!0)._model,n.tension),n.controlPointPreviousX=s(i.previous.x,r.left,r.right),n.controlPointPreviousY=s(i.previous.y,r.top,r.bottom),n.controlPointNextX=s(i.next.x,r.left,r.right),n.controlPointNextY=s(i.next.y,r.top,r.bottom)},setHoverStyle:function(t){var e=t._model,n=t._options,i=V.getHoverColor;t.$previousStyle={backgroundColor:e.backgroundColor,borderColor:e.borderColor,borderWidth:e.borderWidth,radius:e.radius},e.backgroundColor=Kt(n.hoverBackgroundColor,i(n.backgroundColor)),e.borderColor=Kt(n.hoverBorderColor,i(n.borderColor)),e.borderWidth=Kt(n.hoverBorderWidth,n.borderWidth),e.radius=Kt(n.hoverRadius,n.radius)}});z._set("scatter",{hover:{mode:"single"},scales:{xAxes:[{id:"x-axis-1",type:"linear",position:"bottom"}],yAxes:[{id:"y-axis-1",type:"linear",position:"left"}]},tooltips:{callbacks:{title:function(){return""},label:function(t){return"("+t.xLabel+", "+t.yLabel+")"}}}}),z._set("global",{datasets:{scatter:{showLine:!1}}});var $t={bar:Dt,bubble:Ft,doughnut:Nt,horizontalBar:Bt,line:Ut,polarArea:Gt,pie:Xt,radar:Zt,scatter:Ut};function Jt(t,e){return t.native?{x:t.x,y:t.y}:V.getRelativePosition(t,e)}function Qt(t,e){var n,i,a,r,o,s,l=t._getSortedVisibleDatasetMetas();for(i=0,r=l.length;i<r;++i)for(a=0,o=(n=l[i].data).length;a<o;++a)(s=n[a])._view.skip||e(s)}function te(t,e){var n=[];return Qt(t,(function(t){t.inRange(e.x,e.y)&&n.push(t)})),n}function ee(t,e,n,i){var a=Number.POSITIVE_INFINITY,r=[];return Qt(t,(function(t){if(!n||t.inRange(e.x,e.y)){var o=t.getCenterPoint(),s=i(e,o);s<a?(r=[t],a=s):s===a&&r.push(t)}})),r}function ne(t){var e=-1!==t.indexOf("x"),n=-1!==t.indexOf("y");return function(t,i){var a=e?Math.abs(t.x-i.x):0,r=n?Math.abs(t.y-i.y):0;return Math.sqrt(Math.pow(a,2)+Math.pow(r,2))}}function ie(t,e,n){var i=Jt(e,t);n.axis=n.axis||"x";var a=ne(n.axis),r=n.intersect?te(t,i):ee(t,i,!1,a),o=[];return r.length?(t._getSortedVisibleDatasetMetas().forEach((function(t){var e=t.data[r[0]._index];e&&!e._view.skip&&o.push(e)})),o):[]}var ae={modes:{single:function(t,e){var n=Jt(e,t),i=[];return Qt(t,(function(t){if(t.inRange(n.x,n.y))return i.push(t),i})),i.slice(0,1)},label:ie,index:ie,dataset:function(t,e,n){var i=Jt(e,t);n.axis=n.axis||"xy";var a=ne(n.axis),r=n.intersect?te(t,i):ee(t,i,!1,a);return r.length>0&&(r=t.getDatasetMeta(r[0]._datasetIndex).data),r},"x-axis":function(t,e){return ie(t,e,{intersect:!1})},point:function(t,e){return te(t,Jt(e,t))},nearest:function(t,e,n){var i=Jt(e,t);n.axis=n.axis||"xy";var a=ne(n.axis);return ee(t,i,n.intersect,a)},x:function(t,e,n){var i=Jt(e,t),a=[],r=!1;return Qt(t,(function(t){t.inXRange(i.x)&&a.push(t),t.inRange(i.x,i.y)&&(r=!0)})),n.intersect&&!r&&(a=[]),a},y:function(t,e,n){var i=Jt(e,t),a=[],r=!1;return Qt(t,(function(t){t.inYRange(i.y)&&a.push(t),t.inRange(i.x,i.y)&&(r=!0)})),n.intersect&&!r&&(a=[]),a}}},re=V.extend;function oe(t,e){return V.where(t,(function(t){return t.pos===e}))}function se(t,e){return t.sort((function(t,n){var i=e?n:t,a=e?t:n;return i.weight===a.weight?i.index-a.index:i.weight-a.weight}))}function le(t,e,n,i){return Math.max(t[n],e[n])+Math.max(t[i],e[i])}function ue(t,e,n){var i,a,r=n.box,o=t.maxPadding;if(n.size&&(t[n.pos]-=n.size),n.size=n.horizontal?r.height:r.width,t[n.pos]+=n.size,r.getPadding){var s=r.getPadding();o.top=Math.max(o.top,s.top),o.left=Math.max(o.left,s.left),o.bottom=Math.max(o.bottom,s.bottom),o.right=Math.max(o.right,s.right)}if(i=e.outerWidth-le(o,t,"left","right"),a=e.outerHeight-le(o,t,"top","bottom"),i!==t.w||a!==t.h)return t.w=i,t.h=a,n.horizontal?i!==t.w:a!==t.h}function de(t,e){var n=e.maxPadding;function i(t){var i={left:0,top:0,right:0,bottom:0};return t.forEach((function(t){i[t]=Math.max(e[t],n[t])})),i}return i(t?["left","right"]:["top","bottom"])}function he(t,e,n){var i,a,r,o,s,l,u=[];for(i=0,a=t.length;i<a;++i)(o=(r=t[i]).box).update(r.width||e.w,r.height||e.h,de(r.horizontal,e)),ue(e,n,r)&&(l=!0,u.length&&(s=!0)),o.fullWidth||u.push(r);return s&&he(u,e,n)||l}function ce(t,e,n){var i,a,r,o,s=n.padding,l=e.x,u=e.y;for(i=0,a=t.length;i<a;++i)o=(r=t[i]).box,r.horizontal?(o.left=o.fullWidth?s.left:e.left,o.right=o.fullWidth?n.outerWidth-s.right:e.left+e.w,o.top=u,o.bottom=u+o.height,o.width=o.right-o.left,u=o.bottom):(o.left=l,o.right=l+o.width,o.top=e.top,o.bottom=e.top+e.h,o.height=o.bottom-o.top,l=o.right);e.x=l,e.y=u}z._set("global",{layout:{padding:{top:0,right:0,bottom:0,left:0}}});var fe,ge={defaults:{},addBox:function(t,e){t.boxes||(t.boxes=[]),e.fullWidth=e.fullWidth||!1,e.position=e.position||"top",e.weight=e.weight||0,e._layers=e._layers||function(){return[{z:0,draw:function(){e.draw.apply(e,arguments)}}]},t.boxes.push(e)},removeBox:function(t,e){var n=t.boxes?t.boxes.indexOf(e):-1;-1!==n&&t.boxes.splice(n,1)},configure:function(t,e,n){for(var i,a=["fullWidth","position","weight"],r=a.length,o=0;o<r;++o)i=a[o],n.hasOwnProperty(i)&&(e[i]=n[i])},update:function(t,e,n){if(t){var i=t.options.layout||{},a=V.options.toPadding(i.padding),r=e-a.width,o=n-a.height,s=function(t){var e=function(t){var e,n,i,a=[];for(e=0,n=(t||[]).length;e<n;++e)i=t[e],a.push({index:e,box:i,pos:i.position,horizontal:i.isHorizontal(),weight:i.weight});return a}(t),n=se(oe(e,"left"),!0),i=se(oe(e,"right")),a=se(oe(e,"top"),!0),r=se(oe(e,"bottom"));return{leftAndTop:n.concat(a),rightAndBottom:i.concat(r),chartArea:oe(e,"chartArea"),vertical:n.concat(i),horizontal:a.concat(r)}}(t.boxes),l=s.vertical,u=s.horizontal,d=Object.freeze({outerWidth:e,outerHeight:n,padding:a,availableWidth:r,vBoxMaxWidth:r/2/l.length,hBoxMaxHeight:o/2}),h=re({maxPadding:re({},a),w:r,h:o,x:a.left,y:a.top},a);!function(t,e){var n,i,a;for(n=0,i=t.length;n<i;++n)(a=t[n]).width=a.horizontal?a.box.fullWidth&&e.availableWidth:e.vBoxMaxWidth,a.height=a.horizontal&&e.hBoxMaxHeight}(l.concat(u),d),he(l,h,d),he(u,h,d)&&he(l,h,d),function(t){var e=t.maxPadding;function n(n){var i=Math.max(e[n]-t[n],0);return t[n]+=i,i}t.y+=n("top"),t.x+=n("left"),n("right"),n("bottom")}(h),ce(s.leftAndTop,h,d),h.x+=h.w,h.y+=h.h,ce(s.rightAndBottom,h,d),t.chartArea={left:h.left,top:h.top,right:h.left+h.w,bottom:h.top+h.h},V.each(s.chartArea,(function(e){var n=e.box;re(n,t.chartArea),n.update(h.w,h.h)}))}}},pe=(fe=Object.freeze({__proto__:null,default:"@keyframes chartjs-render-animation{from{opacity:.99}to{opacity:1}}.chartjs-render-monitor{animation:chartjs-render-animation 1ms}.chartjs-size-monitor,.chartjs-size-monitor-expand,.chartjs-size-monitor-shrink{position:absolute;direction:ltr;left:0;top:0;right:0;bottom:0;overflow:hidden;pointer-events:none;visibility:hidden;z-index:-1}.chartjs-size-monitor-expand>div{position:absolute;width:1000000px;height:1000000px;left:0;top:0}.chartjs-size-monitor-shrink>div{position:absolute;width:200%;height:200%;left:0;top:0}"}))&&fe.default||fe,me="$chartjs",ve="chartjs-size-monitor",be="chartjs-render-monitor",xe="chartjs-render-animation",ye=["animationstart","webkitAnimationStart"],_e={touchstart:"mousedown",touchmove:"mousemove",touchend:"mouseup",pointerenter:"mouseenter",pointerdown:"mousedown",pointermove:"mousemove",pointerup:"mouseup",pointerleave:"mouseout",pointerout:"mouseout"};function ke(t,e){var n=V.getStyle(t,e),i=n&&n.match(/^(\d+)(\.\d+)?px$/);return i?Number(i[1]):void 0}var we=!!function(){var t=!1;try{var e=Object.defineProperty({},"passive",{get:function(){t=!0}});window.addEventListener("e",null,e)}catch(t){}return t}()&&{passive:!0};function Me(t,e,n){t.addEventListener(e,n,we)}function Se(t,e,n){t.removeEventListener(e,n,we)}function Ce(t,e,n,i,a){return{type:t,chart:e,native:a||null,x:void 0!==n?n:null,y:void 0!==i?i:null}}function Pe(t){var e=document.createElement("div");return e.className=t||"",e}function Ae(t,e,n){var i,a,r,o,s=t[me]||(t[me]={}),l=s.resizer=function(t){var e=Pe(ve),n=Pe(ve+"-expand"),i=Pe(ve+"-shrink");n.appendChild(Pe()),i.appendChild(Pe()),e.appendChild(n),e.appendChild(i),e._reset=function(){n.scrollLeft=1e6,n.scrollTop=1e6,i.scrollLeft=1e6,i.scrollTop=1e6};var a=function(){e._reset(),t()};return Me(n,"scroll",a.bind(n,"expand")),Me(i,"scroll",a.bind(i,"shrink")),e}((i=function(){if(s.resizer){var i=n.options.maintainAspectRatio&&t.parentNode,a=i?i.clientWidth:0;e(Ce("resize",n)),i&&i.clientWidth<a&&n.canvas&&e(Ce("resize",n))}},r=!1,o=[],function(){o=Array.prototype.slice.call(arguments),a=a||this,r||(r=!0,V.requestAnimFrame.call(window,(function(){r=!1,i.apply(a,o)})))}));!function(t,e){var n=t[me]||(t[me]={}),i=n.renderProxy=function(t){t.animationName===xe&&e()};V.each(ye,(function(e){Me(t,e,i)})),n.reflow=!!t.offsetParent,t.classList.add(be)}(t,(function(){if(s.resizer){var e=t.parentNode;e&&e!==l.parentNode&&e.insertBefore(l,e.firstChild),l._reset()}}))}function De(t){var e=t[me]||{},n=e.resizer;delete e.resizer,function(t){var e=t[me]||{},n=e.renderProxy;n&&(V.each(ye,(function(e){Se(t,e,n)})),delete e.renderProxy),t.classList.remove(be)}(t),n&&n.parentNode&&n.parentNode.removeChild(n)}var Te={disableCSSInjection:!1,_enabled:"undefined"!=typeof window&&"undefined"!=typeof document,_ensureLoaded:function(t){if(!this.disableCSSInjection){var e=t.getRootNode?t.getRootNode():document;!function(t,e){var n=t[me]||(t[me]={});if(!n.containsStyles){n.containsStyles=!0,e="/* Chart.js */\n"+e;var i=document.createElement("style");i.setAttribute("type","text/css"),i.appendChild(document.createTextNode(e)),t.appendChild(i)}}(e.host?e:document.head,pe)}},acquireContext:function(t,e){"string"==typeof t?t=document.getElementById(t):t.length&&(t=t[0]),t&&t.canvas&&(t=t.canvas);var n=t&&t.getContext&&t.getContext("2d");return n&&n.canvas===t?(this._ensureLoaded(t),function(t,e){var n=t.style,i=t.getAttribute("height"),a=t.getAttribute("width");if(t[me]={initial:{height:i,width:a,style:{display:n.display,height:n.height,width:n.width}}},n.display=n.display||"block",null===a||""===a){var r=ke(t,"width");void 0!==r&&(t.width=r)}if(null===i||""===i)if(""===t.style.height)t.height=t.width/(e.options.aspectRatio||2);else{var o=ke(t,"height");void 0!==r&&(t.height=o)}}(t,e),n):null},releaseContext:function(t){var e=t.canvas;if(e[me]){var n=e[me].initial;["height","width"].forEach((function(t){var i=n[t];V.isNullOrUndef(i)?e.removeAttribute(t):e.setAttribute(t,i)})),V.each(n.style||{},(function(t,n){e.style[n]=t})),e.width=e.width,delete e[me]}},addEventListener:function(t,e,n){var i=t.canvas;if("resize"!==e){var a=n[me]||(n[me]={});Me(i,e,(a.proxies||(a.proxies={}))[t.id+"_"+e]=function(e){n(function(t,e){var n=_e[t.type]||t.type,i=V.getRelativePosition(t,e);return Ce(n,e,i.x,i.y,t)}(e,t))})}else Ae(i,n,t)},removeEventListener:function(t,e,n){var i=t.canvas;if("resize"!==e){var a=((n[me]||{}).proxies||{})[t.id+"_"+e];a&&Se(i,e,a)}else De(i)}};V.addEvent=Me,V.removeEvent=Se;var Ie=Te._enabled?Te:{acquireContext:function(t){return t&&t.canvas&&(t=t.canvas),t&&t.getContext("2d")||null}},Fe=V.extend({initialize:function(){},acquireContext:function(){},releaseContext:function(){},addEventListener:function(){},removeEventListener:function(){}},Ie);z._set("global",{plugins:{}});var Le={_plugins:[],_cacheId:0,register:function(t){var e=this._plugins;[].concat(t).forEach((function(t){-1===e.indexOf(t)&&e.push(t)})),this._cacheId++},unregister:function(t){var e=this._plugins;[].concat(t).forEach((function(t){var n=e.indexOf(t);-1!==n&&e.splice(n,1)})),this._cacheId++},clear:function(){this._plugins=[],this._cacheId++},count:function(){return this._plugins.length},getAll:function(){return this._plugins},notify:function(t,e,n){var i,a,r,o,s,l=this.descriptors(t),u=l.length;for(i=0;i<u;++i)if("function"==typeof(s=(r=(a=l[i]).plugin)[e])&&((o=[t].concat(n||[])).push(a.options),!1===s.apply(r,o)))return!1;return!0},descriptors:function(t){var e=t.$plugins||(t.$plugins={});if(e.id===this._cacheId)return e.descriptors;var n=[],i=[],a=t&&t.config||{},r=a.options&&a.options.plugins||{};return this._plugins.concat(a.plugins||[]).forEach((function(t){if(-1===n.indexOf(t)){var e=t.id,a=r[e];!1!==a&&(!0===a&&(a=V.clone(z.global.plugins[e])),n.push(t),i.push({plugin:t,options:a||{}}))}})),e.descriptors=i,e.id=this._cacheId,i},_invalidate:function(t){delete t.$plugins}},Oe={constructors:{},defaults:{},registerScaleType:function(t,e,n){this.constructors[t]=e,this.defaults[t]=V.clone(n)},getScaleConstructor:function(t){return this.constructors.hasOwnProperty(t)?this.constructors[t]:void 0},getScaleDefaults:function(t){return this.defaults.hasOwnProperty(t)?V.merge({},[z.scale,this.defaults[t]]):{}},updateScaleDefaults:function(t,e){this.defaults.hasOwnProperty(t)&&(this.defaults[t]=V.extend(this.defaults[t],e))},addScalesToLayout:function(t){V.each(t.scales,(function(e){e.fullWidth=e.options.fullWidth,e.position=e.options.position,e.weight=e.options.weight,ge.addBox(t,e)}))}},Re=V.valueOrDefault,ze=V.rtl.getRtlAdapter;z._set("global",{tooltips:{enabled:!0,custom:null,mode:"nearest",position:"average",intersect:!0,backgroundColor:"rgba(0,0,0,0.8)",titleFontStyle:"bold",titleSpacing:2,titleMarginBottom:6,titleFontColor:"#fff",titleAlign:"left",bodySpacing:2,bodyFontColor:"#fff",bodyAlign:"left",footerFontStyle:"bold",footerSpacing:2,footerMarginTop:6,footerFontColor:"#fff",footerAlign:"left",yPadding:6,xPadding:6,caretPadding:2,caretSize:5,cornerRadius:6,multiKeyBackground:"#fff",displayColors:!0,borderColor:"rgba(0,0,0,0)",borderWidth:0,callbacks:{beforeTitle:V.noop,title:function(t,e){var n="",i=e.labels,a=i?i.length:0;if(t.length>0){var r=t[0];r.label?n=r.label:r.xLabel?n=r.xLabel:a>0&&r.index<a&&(n=i[r.index])}return n},afterTitle:V.noop,beforeBody:V.noop,beforeLabel:V.noop,label:function(t,e){var n=e.datasets[t.datasetIndex].label||"";return n&&(n+=": "),V.isNullOrUndef(t.value)?n+=t.yLabel:n+=t.value,n},labelColor:function(t,e){var n=e.getDatasetMeta(t.datasetIndex).data[t.index]._view;return{borderColor:n.borderColor,backgroundColor:n.backgroundColor}},labelTextColor:function(){return this._options.bodyFontColor},afterLabel:V.noop,afterBody:V.noop,beforeFooter:V.noop,footer:V.noop,afterFooter:V.noop}}});var Ne={average:function(t){if(!t.length)return!1;var e,n,i=0,a=0,r=0;for(e=0,n=t.length;e<n;++e){var o=t[e];if(o&&o.hasValue()){var s=o.tooltipPosition();i+=s.x,a+=s.y,++r}}return{x:i/r,y:a/r}},nearest:function(t,e){var n,i,a,r=e.x,o=e.y,s=Number.POSITIVE_INFINITY;for(n=0,i=t.length;n<i;++n){var l=t[n];if(l&&l.hasValue()){var u=l.getCenterPoint(),d=V.distanceBetweenPoints(e,u);d<s&&(s=d,a=l)}}if(a){var h=a.tooltipPosition();r=h.x,o=h.y}return{x:r,y:o}}};function Be(t,e){return e&&(V.isArray(e)?Array.prototype.push.apply(t,e):t.push(e)),t}function Ee(t){return("string"==typeof t||t instanceof String)&&t.indexOf("\n")>-1?t.split("\n"):t}function We(t){var e=z.global;return{xPadding:t.xPadding,yPadding:t.yPadding,xAlign:t.xAlign,yAlign:t.yAlign,rtl:t.rtl,textDirection:t.textDirection,bodyFontColor:t.bodyFontColor,_bodyFontFamily:Re(t.bodyFontFamily,e.defaultFontFamily),_bodyFontStyle:Re(t.bodyFontStyle,e.defaultFontStyle),_bodyAlign:t.bodyAlign,bodyFontSize:Re(t.bodyFontSize,e.defaultFontSize),bodySpacing:t.bodySpacing,titleFontColor:t.titleFontColor,_titleFontFamily:Re(t.titleFontFamily,e.defaultFontFamily),_titleFontStyle:Re(t.titleFontStyle,e.defaultFontStyle),titleFontSize:Re(t.titleFontSize,e.defaultFontSize),_titleAlign:t.titleAlign,titleSpacing:t.titleSpacing,titleMarginBottom:t.titleMarginBottom,footerFontColor:t.footerFontColor,_footerFontFamily:Re(t.footerFontFamily,e.defaultFontFamily),_footerFontStyle:Re(t.footerFontStyle,e.defaultFontStyle),footerFontSize:Re(t.footerFontSize,e.defaultFontSize),_footerAlign:t.footerAlign,footerSpacing:t.footerSpacing,footerMarginTop:t.footerMarginTop,caretSize:t.caretSize,cornerRadius:t.cornerRadius,backgroundColor:t.backgroundColor,opacity:0,legendColorBackground:t.multiKeyBackground,displayColors:t.displayColors,borderColor:t.borderColor,borderWidth:t.borderWidth}}function Ve(t,e){return"center"===e?t.x+t.width/2:"right"===e?t.x+t.width-t.xPadding:t.x+t.xPadding}function He(t){return Be([],Ee(t))}var je=X.extend({initialize:function(){this._model=We(this._options),this._lastActive=[]},getTitle:function(){var t=this,e=t._options,n=e.callbacks,i=n.beforeTitle.apply(t,arguments),a=n.title.apply(t,arguments),r=n.afterTitle.apply(t,arguments),o=[];return o=Be(o,Ee(i)),o=Be(o,Ee(a)),o=Be(o,Ee(r))},getBeforeBody:function(){return He(this._options.callbacks.beforeBody.apply(this,arguments))},getBody:function(t,e){var n=this,i=n._options.callbacks,a=[];return V.each(t,(function(t){var r={before:[],lines:[],after:[]};Be(r.before,Ee(i.beforeLabel.call(n,t,e))),Be(r.lines,i.label.call(n,t,e)),Be(r.after,Ee(i.afterLabel.call(n,t,e))),a.push(r)})),a},getAfterBody:function(){return He(this._options.callbacks.afterBody.apply(this,arguments))},getFooter:function(){var t=this,e=t._options.callbacks,n=e.beforeFooter.apply(t,arguments),i=e.footer.apply(t,arguments),a=e.afterFooter.apply(t,arguments),r=[];return r=Be(r,Ee(n)),r=Be(r,Ee(i)),r=Be(r,Ee(a))},update:function(t){var e,n,i,a,r,o,s,l,u,d,h=this,c=h._options,f=h._model,g=h._model=We(c),p=h._active,m=h._data,v={xAlign:f.xAlign,yAlign:f.yAlign},b={x:f.x,y:f.y},x={width:f.width,height:f.height},y={x:f.caretX,y:f.caretY};if(p.length){g.opacity=1;var _=[],k=[];y=Ne[c.position].call(h,p,h._eventPosition);var w=[];for(e=0,n=p.length;e<n;++e)w.push((i=p[e],a=void 0,r=void 0,o=void 0,s=void 0,l=void 0,u=void 0,d=void 0,a=i._xScale,r=i._yScale||i._scale,o=i._index,s=i._datasetIndex,l=i._chart.getDatasetMeta(s).controller,u=l._getIndexScale(),d=l._getValueScale(),{xLabel:a?a.getLabelForIndex(o,s):"",yLabel:r?r.getLabelForIndex(o,s):"",label:u?""+u.getLabelForIndex(o,s):"",value:d?""+d.getLabelForIndex(o,s):"",index:o,datasetIndex:s,x:i._model.x,y:i._model.y}));c.filter&&(w=w.filter((function(t){return c.filter(t,m)}))),c.itemSort&&(w=w.sort((function(t,e){return c.itemSort(t,e,m)}))),V.each(w,(function(t){_.push(c.callbacks.labelColor.call(h,t,h._chart)),k.push(c.callbacks.labelTextColor.call(h,t,h._chart))})),g.title=h.getTitle(w,m),g.beforeBody=h.getBeforeBody(w,m),g.body=h.getBody(w,m),g.afterBody=h.getAfterBody(w,m),g.footer=h.getFooter(w,m),g.x=y.x,g.y=y.y,g.caretPadding=c.caretPadding,g.labelColors=_,g.labelTextColors=k,g.dataPoints=w,x=function(t,e){var n=t._chart.ctx,i=2*e.yPadding,a=0,r=e.body,o=r.reduce((function(t,e){return t+e.before.length+e.lines.length+e.after.length}),0);o+=e.beforeBody.length+e.afterBody.length;var s=e.title.length,l=e.footer.length,u=e.titleFontSize,d=e.bodyFontSize,h=e.footerFontSize;i+=s*u,i+=s?(s-1)*e.titleSpacing:0,i+=s?e.titleMarginBottom:0,i+=o*d,i+=o?(o-1)*e.bodySpacing:0,i+=l?e.footerMarginTop:0,i+=l*h,i+=l?(l-1)*e.footerSpacing:0;var c=0,f=function(t){a=Math.max(a,n.measureText(t).width+c)};return n.font=V.fontString(u,e._titleFontStyle,e._titleFontFamily),V.each(e.title,f),n.font=V.fontString(d,e._bodyFontStyle,e._bodyFontFamily),V.each(e.beforeBody.concat(e.afterBody),f),c=e.displayColors?d+2:0,V.each(r,(function(t){V.each(t.before,f),V.each(t.lines,f),V.each(t.after,f)})),c=0,n.font=V.fontString(h,e._footerFontStyle,e._footerFontFamily),V.each(e.footer,f),{width:a+=2*e.xPadding,height:i}}(this,g),b=function(t,e,n,i){var a=t.x,r=t.y,o=t.caretSize,s=t.caretPadding,l=t.cornerRadius,u=n.xAlign,d=n.yAlign,h=o+s,c=l+s;return"right"===u?a-=e.width:"center"===u&&((a-=e.width/2)+e.width>i.width&&(a=i.width-e.width),a<0&&(a=0)),"top"===d?r+=h:r-="bottom"===d?e.height+h:e.height/2,"center"===d?"left"===u?a+=h:"right"===u&&(a-=h):"left"===u?a-=c:"right"===u&&(a+=c),{x:a,y:r}}(g,x,v=function(t,e){var n,i,a,r,o,s=t._model,l=t._chart,u=t._chart.chartArea,d="center",h="center";s.y<e.height?h="top":s.y>l.height-e.height&&(h="bottom");var c=(u.left+u.right)/2,f=(u.top+u.bottom)/2;"center"===h?(n=function(t){return t<=c},i=function(t){return t>c}):(n=function(t){return t<=e.width/2},i=function(t){return t>=l.width-e.width/2}),a=function(t){return t+e.width+s.caretSize+s.caretPadding>l.width},r=function(t){return t-e.width-s.caretSize-s.caretPadding<0},o=function(t){return t<=f?"top":"bottom"},n(s.x)?(d="left",a(s.x)&&(d="center",h=o(s.y))):i(s.x)&&(d="right",r(s.x)&&(d="center",h=o(s.y)));var g=t._options;return{xAlign:g.xAlign?g.xAlign:d,yAlign:g.yAlign?g.yAlign:h}}(this,x),h._chart)}else g.opacity=0;return g.xAlign=v.xAlign,g.yAlign=v.yAlign,g.x=b.x,g.y=b.y,g.width=x.width,g.height=x.height,g.caretX=y.x,g.caretY=y.y,h._model=g,t&&c.custom&&c.custom.call(h,g),h},drawCaret:function(t,e){var n=this._chart.ctx,i=this._view,a=this.getCaretPosition(t,e,i);n.lineTo(a.x1,a.y1),n.lineTo(a.x2,a.y2),n.lineTo(a.x3,a.y3)},getCaretPosition:function(t,e,n){var i,a,r,o,s,l,u=n.caretSize,d=n.cornerRadius,h=n.xAlign,c=n.yAlign,f=t.x,g=t.y,p=e.width,m=e.height;if("center"===c)s=g+m/2,"left"===h?(a=(i=f)-u,r=i,o=s+u,l=s-u):(a=(i=f+p)+u,r=i,o=s-u,l=s+u);else if("left"===h?(i=(a=f+d+u)-u,r=a+u):"right"===h?(i=(a=f+p-d-u)-u,r=a+u):(i=(a=n.caretX)-u,r=a+u),"top"===c)s=(o=g)-u,l=o;else{s=(o=g+m)+u,l=o;var v=r;r=i,i=v}return{x1:i,x2:a,x3:r,y1:o,y2:s,y3:l}},drawTitle:function(t,e,n){var i,a,r,o=e.title,s=o.length;if(s){var l=ze(e.rtl,e.x,e.width);for(t.x=Ve(e,e._titleAlign),n.textAlign=l.textAlign(e._titleAlign),n.textBaseline="middle",i=e.titleFontSize,a=e.titleSpacing,n.fillStyle=e.titleFontColor,n.font=V.fontString(i,e._titleFontStyle,e._titleFontFamily),r=0;r<s;++r)n.fillText(o[r],l.x(t.x),t.y+i/2),t.y+=i+a,r+1===s&&(t.y+=e.titleMarginBottom-a)}},drawBody:function(t,e,n){var i,a,r,o,s,l,u,d,h=e.bodyFontSize,c=e.bodySpacing,f=e._bodyAlign,g=e.body,p=e.displayColors,m=0,v=p?Ve(e,"left"):0,b=ze(e.rtl,e.x,e.width),x=function(e){n.fillText(e,b.x(t.x+m),t.y+h/2),t.y+=h+c},y=b.textAlign(f);for(n.textAlign=f,n.textBaseline="middle",n.font=V.fontString(h,e._bodyFontStyle,e._bodyFontFamily),t.x=Ve(e,y),n.fillStyle=e.bodyFontColor,V.each(e.beforeBody,x),m=p&&"right"!==y?"center"===f?h/2+1:h+2:0,s=0,u=g.length;s<u;++s){for(i=g[s],a=e.labelTextColors[s],r=e.labelColors[s],n.fillStyle=a,V.each(i.before,x),l=0,d=(o=i.lines).length;l<d;++l){if(p){var _=b.x(v);n.fillStyle=e.legendColorBackground,n.fillRect(b.leftForLtr(_,h),t.y,h,h),n.lineWidth=1,n.strokeStyle=r.borderColor,n.strokeRect(b.leftForLtr(_,h),t.y,h,h),n.fillStyle=r.backgroundColor,n.fillRect(b.leftForLtr(b.xPlus(_,1),h-2),t.y+1,h-2,h-2),n.fillStyle=a}x(o[l])}V.each(i.after,x)}m=0,V.each(e.afterBody,x),t.y-=c},drawFooter:function(t,e,n){var i,a,r=e.footer,o=r.length;if(o){var s=ze(e.rtl,e.x,e.width);for(t.x=Ve(e,e._footerAlign),t.y+=e.footerMarginTop,n.textAlign=s.textAlign(e._footerAlign),n.textBaseline="middle",i=e.footerFontSize,n.fillStyle=e.footerFontColor,n.font=V.fontString(i,e._footerFontStyle,e._footerFontFamily),a=0;a<o;++a)n.fillText(r[a],s.x(t.x),t.y+i/2),t.y+=i+e.footerSpacing}},drawBackground:function(t,e,n,i){n.fillStyle=e.backgroundColor,n.strokeStyle=e.borderColor,n.lineWidth=e.borderWidth;var a=e.xAlign,r=e.yAlign,o=t.x,s=t.y,l=i.width,u=i.height,d=e.cornerRadius;n.beginPath(),n.moveTo(o+d,s),"top"===r&&this.drawCaret(t,i),n.lineTo(o+l-d,s),n.quadraticCurveTo(o+l,s,o+l,s+d),"center"===r&&"right"===a&&this.drawCaret(t,i),n.lineTo(o+l,s+u-d),n.quadraticCurveTo(o+l,s+u,o+l-d,s+u),"bottom"===r&&this.drawCaret(t,i),n.lineTo(o+d,s+u),n.quadraticCurveTo(o,s+u,o,s+u-d),"center"===r&&"left"===a&&this.drawCaret(t,i),n.lineTo(o,s+d),n.quadraticCurveTo(o,s,o+d,s),n.closePath(),n.fill(),e.borderWidth>0&&n.stroke()},draw:function(){var t=this._chart.ctx,e=this._view;if(0!==e.opacity){var n={width:e.width,height:e.height},i={x:e.x,y:e.y},a=Math.abs(e.opacity<.001)?0:e.opacity,r=e.title.length||e.beforeBody.length||e.body.length||e.afterBody.length||e.footer.length;this._options.enabled&&r&&(t.save(),t.globalAlpha=a,this.drawBackground(i,e,t,n),i.y+=e.yPadding,V.rtl.overrideTextDirection(t,e.textDirection),this.drawTitle(i,e,t),this.drawBody(i,e,t),this.drawFooter(i,e,t),V.rtl.restoreTextDirection(t,e.textDirection),t.restore())}},handleEvent:function(t){var e,n=this,i=n._options;return n._lastActive=n._lastActive||[],"mouseout"===t.type?n._active=[]:(n._active=n._chart.getElementsAtEventForMode(t,i.mode,i),i.reverse&&n._active.reverse()),(e=!V.arrayEquals(n._active,n._lastActive))&&(n._lastActive=n._active,(i.enabled||i.custom)&&(n._eventPosition={x:t.x,y:t.y},n.update(!0),n.pivot())),e}}),qe=Ne,Ue=je;Ue.positioners=qe;var Ye=V.valueOrDefault;function Ge(){return V.merge({},[].slice.call(arguments),{merger:function(t,e,n,i){if("xAxes"===t||"yAxes"===t){var a,r,o,s=n[t].length;for(e[t]||(e[t]=[]),a=0;a<s;++a)o=n[t][a],r=Ye(o.type,"xAxes"===t?"category":"linear"),a>=e[t].length&&e[t].push({}),!e[t][a].type||o.type&&o.type!==e[t][a].type?V.merge(e[t][a],[Oe.getScaleDefaults(r),o]):V.merge(e[t][a],o)}else V._merger(t,e,n,i)}})}function Xe(){return V.merge({},[].slice.call(arguments),{merger:function(t,e,n,i){var a=e[t]||{},r=n[t];"scales"===t?e[t]=Ge(a,r):"scale"===t?e[t]=V.merge(a,[Oe.getScaleDefaults(r.type),r]):V._merger(t,e,n,i)}})}function Ke(t){var e=t.options;V.each(t.scales,(function(e){ge.removeBox(t,e)})),e=Xe(z.global,z[t.config.type],e),t.options=t.config.options=e,t.ensureScalesHaveIDs(),t.buildOrUpdateScales(),t.tooltip._options=e.tooltips,t.tooltip.initialize()}function Ze(t,e,n){var i,a=function(t){return t.id===i};do{i=e+n++}while(V.findIndex(t,a)>=0);return i}function $e(t){return"top"===t||"bottom"===t}function Je(t,e){return function(n,i){return n[t]===i[t]?n[e]-i[e]:n[t]-i[t]}}z._set("global",{elements:{},events:["mousemove","mouseout","click","touchstart","touchmove"],hover:{onHover:null,mode:"nearest",intersect:!0,animationDuration:400},onClick:null,maintainAspectRatio:!0,responsive:!0,responsiveAnimationDuration:0});var Qe=function(t,e){return this.construct(t,e),this};V.extend(Qe.prototype,{construct:function(t,e){var n=this;e=function(t){var e=(t=t||{}).data=t.data||{};return e.datasets=e.datasets||[],e.labels=e.labels||[],t.options=Xe(z.global,z[t.type],t.options||{}),t}(e);var i=Fe.acquireContext(t,e),a=i&&i.canvas,r=a&&a.height,o=a&&a.width;n.id=V.uid(),n.ctx=i,n.canvas=a,n.config=e,n.width=o,n.height=r,n.aspectRatio=r?o/r:null,n.options=e.options,n._bufferedRender=!1,n._layers=[],n.chart=n,n.controller=n,Qe.instances[n.id]=n,Object.defineProperty(n,"data",{get:function(){return n.config.data},set:function(t){n.config.data=t}}),i&&a?(n.initialize(),n.update()):console.error("Failed to create chart: can't acquire context from the given item")},initialize:function(){var t=this;return Le.notify(t,"beforeInit"),V.retinaScale(t,t.options.devicePixelRatio),t.bindEvents(),t.options.responsive&&t.resize(!0),t.initToolTip(),Le.notify(t,"afterInit"),t},clear:function(){return V.canvas.clear(this),this},stop:function(){return $.cancelAnimation(this),this},resize:function(t){var e=this,n=e.options,i=e.canvas,a=n.maintainAspectRatio&&e.aspectRatio||null,r=Math.max(0,Math.floor(V.getMaximumWidth(i))),o=Math.max(0,Math.floor(a?r/a:V.getMaximumHeight(i)));if((e.width!==r||e.height!==o)&&(i.width=e.width=r,i.height=e.height=o,i.style.width=r+"px",i.style.height=o+"px",V.retinaScale(e,n.devicePixelRatio),!t)){var s={width:r,height:o};Le.notify(e,"resize",[s]),n.onResize&&n.onResize(e,s),e.stop(),e.update({duration:n.responsiveAnimationDuration})}},ensureScalesHaveIDs:function(){var t=this.options,e=t.scales||{},n=t.scale;V.each(e.xAxes,(function(t,n){t.id||(t.id=Ze(e.xAxes,"x-axis-",n))})),V.each(e.yAxes,(function(t,n){t.id||(t.id=Ze(e.yAxes,"y-axis-",n))})),n&&(n.id=n.id||"scale")},buildOrUpdateScales:function(){var t=this,e=t.options,n=t.scales||{},i=[],a=Object.keys(n).reduce((function(t,e){return t[e]=!1,t}),{});e.scales&&(i=i.concat((e.scales.xAxes||[]).map((function(t){return{options:t,dtype:"category",dposition:"bottom"}})),(e.scales.yAxes||[]).map((function(t){return{options:t,dtype:"linear",dposition:"left"}})))),e.scale&&i.push({options:e.scale,dtype:"radialLinear",isDefault:!0,dposition:"chartArea"}),V.each(i,(function(e){var i=e.options,r=i.id,o=Ye(i.type,e.dtype);$e(i.position)!==$e(e.dposition)&&(i.position=e.dposition),a[r]=!0;var s=null;if(r in n&&n[r].type===o)(s=n[r]).options=i,s.ctx=t.ctx,s.chart=t;else{var l=Oe.getScaleConstructor(o);if(!l)return;s=new l({id:r,type:o,options:i,ctx:t.ctx,chart:t}),n[s.id]=s}s.mergeTicksOptions(),e.isDefault&&(t.scale=s)})),V.each(a,(function(t,e){t||delete n[e]})),t.scales=n,Oe.addScalesToLayout(this)},buildOrUpdateControllers:function(){var t,e,n=this,i=[],a=n.data.datasets;for(t=0,e=a.length;t<e;t++){var r=a[t],o=n.getDatasetMeta(t),s=r.type||n.config.type;if(o.type&&o.type!==s&&(n.destroyDatasetMeta(t),o=n.getDatasetMeta(t)),o.type=s,o.order=r.order||0,o.index=t,o.controller)o.controller.updateIndex(t),o.controller.linkScales();else{var l=$t[o.type];if(void 0===l)throw new Error('"'+o.type+'" is not a chart type.');o.controller=new l(n,t),i.push(o.controller)}}return i},resetElements:function(){var t=this;V.each(t.data.datasets,(function(e,n){t.getDatasetMeta(n).controller.reset()}),t)},reset:function(){this.resetElements(),this.tooltip.initialize()},update:function(t){var e,n,i=this;if(t&&"object"==typeof t||(t={duration:t,lazy:arguments[1]}),Ke(i),Le._invalidate(i),!1!==Le.notify(i,"beforeUpdate")){i.tooltip._data=i.data;var a=i.buildOrUpdateControllers();for(e=0,n=i.data.datasets.length;e<n;e++)i.getDatasetMeta(e).controller.buildOrUpdateElements();i.updateLayout(),i.options.animation&&i.options.animation.duration&&V.each(a,(function(t){t.reset()})),i.updateDatasets(),i.tooltip.initialize(),i.lastActive=[],Le.notify(i,"afterUpdate"),i._layers.sort(Je("z","_idx")),i._bufferedRender?i._bufferedRequest={duration:t.duration,easing:t.easing,lazy:t.lazy}:i.render(t)}},updateLayout:function(){var t=this;!1!==Le.notify(t,"beforeLayout")&&(ge.update(this,this.width,this.height),t._layers=[],V.each(t.boxes,(function(e){e._configure&&e._configure(),t._layers.push.apply(t._layers,e._layers())}),t),t._layers.forEach((function(t,e){t._idx=e})),Le.notify(t,"afterScaleUpdate"),Le.notify(t,"afterLayout"))},updateDatasets:function(){if(!1!==Le.notify(this,"beforeDatasetsUpdate")){for(var t=0,e=this.data.datasets.length;t<e;++t)this.updateDataset(t);Le.notify(this,"afterDatasetsUpdate")}},updateDataset:function(t){var e=this.getDatasetMeta(t),n={meta:e,index:t};!1!==Le.notify(this,"beforeDatasetUpdate",[n])&&(e.controller._update(),Le.notify(this,"afterDatasetUpdate",[n]))},render:function(t){var e=this;t&&"object"==typeof t||(t={duration:t,lazy:arguments[1]});var n=e.options.animation,i=Ye(t.duration,n&&n.duration),a=t.lazy;if(!1!==Le.notify(e,"beforeRender")){var r=function(t){Le.notify(e,"afterRender"),V.callback(n&&n.onComplete,[t],e)};if(n&&i){var o=new Z({numSteps:i/16.66,easing:t.easing||n.easing,render:function(t,e){var n=V.easing.effects[e.easing],i=e.currentStep,a=i/e.numSteps;t.draw(n(a),a,i)},onAnimationProgress:n.onProgress,onAnimationComplete:r});$.addAnimation(e,o,i,a)}else e.draw(),r(new Z({numSteps:0,chart:e}));return e}},draw:function(t){var e,n,i=this;if(i.clear(),V.isNullOrUndef(t)&&(t=1),i.transition(t),!(i.width<=0||i.height<=0)&&!1!==Le.notify(i,"beforeDraw",[t])){for(n=i._layers,e=0;e<n.length&&n[e].z<=0;++e)n[e].draw(i.chartArea);for(i.drawDatasets(t);e<n.length;++e)n[e].draw(i.chartArea);i._drawTooltip(t),Le.notify(i,"afterDraw",[t])}},transition:function(t){for(var e=0,n=(this.data.datasets||[]).length;e<n;++e)this.isDatasetVisible(e)&&this.getDatasetMeta(e).controller.transition(t);this.tooltip.transition(t)},_getSortedDatasetMetas:function(t){var e,n,i=[];for(e=0,n=(this.data.datasets||[]).length;e<n;++e)t&&!this.isDatasetVisible(e)||i.push(this.getDatasetMeta(e));return i.sort(Je("order","index")),i},_getSortedVisibleDatasetMetas:function(){return this._getSortedDatasetMetas(!0)},drawDatasets:function(t){var e,n;if(!1!==Le.notify(this,"beforeDatasetsDraw",[t])){for(n=(e=this._getSortedVisibleDatasetMetas()).length-1;n>=0;--n)this.drawDataset(e[n],t);Le.notify(this,"afterDatasetsDraw",[t])}},drawDataset:function(t,e){var n={meta:t,index:t.index,easingValue:e};!1!==Le.notify(this,"beforeDatasetDraw",[n])&&(t.controller.draw(e),Le.notify(this,"afterDatasetDraw",[n]))},_drawTooltip:function(t){var e=this.tooltip,n={tooltip:e,easingValue:t};!1!==Le.notify(this,"beforeTooltipDraw",[n])&&(e.draw(),Le.notify(this,"afterTooltipDraw",[n]))},getElementAtEvent:function(t){return ae.modes.single(this,t)},getElementsAtEvent:function(t){return ae.modes.label(this,t,{intersect:!0})},getElementsAtXAxis:function(t){return ae.modes["x-axis"](this,t,{intersect:!0})},getElementsAtEventForMode:function(t,e,n){var i=ae.modes[e];return"function"==typeof i?i(this,t,n):[]},getDatasetAtEvent:function(t){return ae.modes.dataset(this,t,{intersect:!0})},getDatasetMeta:function(t){var e=this.data.datasets[t];e._meta||(e._meta={});var n=e._meta[this.id];return n||(n=e._meta[this.id]={type:null,data:[],dataset:null,controller:null,hidden:null,xAxisID:null,yAxisID:null,order:e.order||0,index:t}),n},getVisibleDatasetCount:function(){for(var t=0,e=0,n=this.data.datasets.length;e<n;++e)this.isDatasetVisible(e)&&t++;return t},isDatasetVisible:function(t){var e=this.getDatasetMeta(t);return"boolean"==typeof e.hidden?!e.hidden:!this.data.datasets[t].hidden},generateLegend:function(){return this.options.legendCallback(this)},destroyDatasetMeta:function(t){var e=this.id,n=this.data.datasets[t],i=n._meta&&n._meta[e];i&&(i.controller.destroy(),delete n._meta[e])},destroy:function(){var t,e,n=this,i=n.canvas;for(n.stop(),t=0,e=n.data.datasets.length;t<e;++t)n.destroyDatasetMeta(t);i&&(n.unbindEvents(),V.canvas.clear(n),Fe.releaseContext(n.ctx),n.canvas=null,n.ctx=null),Le.notify(n,"destroy"),delete Qe.instances[n.id]},toBase64Image:function(){return this.canvas.toDataURL.apply(this.canvas,arguments)},initToolTip:function(){var t=this;t.tooltip=new Ue({_chart:t,_chartInstance:t,_data:t.data,_options:t.options.tooltips},t)},bindEvents:function(){var t=this,e=t._listeners={},n=function(){t.eventHandler.apply(t,arguments)};V.each(t.options.events,(function(i){Fe.addEventListener(t,i,n),e[i]=n})),t.options.responsive&&(n=function(){t.resize()},Fe.addEventListener(t,"resize",n),e.resize=n)},unbindEvents:function(){var t=this,e=t._listeners;e&&(delete t._listeners,V.each(e,(function(e,n){Fe.removeEventListener(t,n,e)})))},updateHoverStyle:function(t,e,n){var i,a,r,o=n?"set":"remove";for(a=0,r=t.length;a<r;++a)(i=t[a])&&this.getDatasetMeta(i._datasetIndex).controller[o+"HoverStyle"](i);"dataset"===e&&this.getDatasetMeta(t[0]._datasetIndex).controller["_"+o+"DatasetHoverStyle"]()},eventHandler:function(t){var e=this,n=e.tooltip;if(!1!==Le.notify(e,"beforeEvent",[t])){e._bufferedRender=!0,e._bufferedRequest=null;var i=e.handleEvent(t);n&&(i=n._start?n.handleEvent(t):i|n.handleEvent(t)),Le.notify(e,"afterEvent",[t]);var a=e._bufferedRequest;return a?e.render(a):i&&!e.animating&&(e.stop(),e.render({duration:e.options.hover.animationDuration,lazy:!0})),e._bufferedRender=!1,e._bufferedRequest=null,e}},handleEvent:function(t){var e,n=this,i=n.options||{},a=i.hover;return n.lastActive=n.lastActive||[],"mouseout"===t.type?n.active=[]:n.active=n.getElementsAtEventForMode(t,a.mode,a),V.callback(i.onHover||i.hover.onHover,[t.native,n.active],n),"mouseup"!==t.type&&"click"!==t.type||i.onClick&&i.onClick.call(n,t.native,n.active),n.lastActive.length&&n.updateHoverStyle(n.lastActive,a.mode,!1),n.active.length&&a.mode&&n.updateHoverStyle(n.active,a.mode,!0),e=!V.arrayEquals(n.active,n.lastActive),n.lastActive=n.active,e}}),Qe.instances={};var tn=Qe;Qe.Controller=Qe,Qe.types={},V.configMerge=Xe,V.scaleMerge=Ge;function en(){throw new Error("This method is not implemented: either no adapter can be found or an incomplete integration was provided.")}function nn(t){this.options=t||{}}V.extend(nn.prototype,{formats:en,parse:en,format:en,add:en,diff:en,startOf:en,endOf:en,_create:function(t){return t}}),nn.override=function(t){V.extend(nn.prototype,t)};var an={_date:nn},rn={formatters:{values:function(t){return V.isArray(t)?t:""+t},linear:function(t,e,n){var i=n.length>3?n[2]-n[1]:n[1]-n[0];Math.abs(i)>1&&t!==Math.floor(t)&&(i=t-Math.floor(t));var a=V.log10(Math.abs(i)),r="";if(0!==t)if(Math.max(Math.abs(n[0]),Math.abs(n[n.length-1]))<1e-4){var o=V.log10(Math.abs(t)),s=Math.floor(o)-Math.floor(a);s=Math.max(Math.min(s,20),0),r=t.toExponential(s)}else{var l=-1*Math.floor(a);l=Math.max(Math.min(l,20),0),r=t.toFixed(l)}else r="0";return r},logarithmic:function(t,e,n){var i=t/Math.pow(10,Math.floor(V.log10(t)));return 0===t?"0":1===i||2===i||5===i||0===e||e===n.length-1?t.toExponential():""}}},on=V.isArray,sn=V.isNullOrUndef,ln=V.valueOrDefault,un=V.valueAtIndexOrDefault;function dn(t,e,n){var i,a=t.getTicks().length,r=Math.min(e,a-1),o=t.getPixelForTick(r),s=t._startPixel,l=t._endPixel;if(!(n&&(i=1===a?Math.max(o-s,l-o):0===e?(t.getPixelForTick(1)-o)/2:(o-t.getPixelForTick(r-1))/2,(o+=r<e?i:-i)<s-1e-6||o>l+1e-6)))return o}function hn(t,e,n,i){var a,r,o,s,l,u,d,h,c,f,g,p,m,v=n.length,b=[],x=[],y=[];for(a=0;a<v;++a){if(s=n[a].label,l=n[a].major?e.major:e.minor,t.font=u=l.string,d=i[u]=i[u]||{data:{},gc:[]},h=l.lineHeight,c=f=0,sn(s)||on(s)){if(on(s))for(r=0,o=s.length;r<o;++r)g=s[r],sn(g)||on(g)||(c=V.measureText(t,d.data,d.gc,c,g),f+=h)}else c=V.measureText(t,d.data,d.gc,c,s),f=h;b.push(c),x.push(f),y.push(h/2)}function _(t){return{width:b[t]||0,height:x[t]||0,offset:y[t]||0}}return function(t,e){V.each(t,(function(t){var n,i=t.gc,a=i.length/2;if(a>e){for(n=0;n<a;++n)delete t.data[i[n]];i.splice(0,a)}}))}(i,v),p=b.indexOf(Math.max.apply(null,b)),m=x.indexOf(Math.max.apply(null,x)),{first:_(0),last:_(v-1),widest:_(p),highest:_(m)}}function cn(t){return t.drawTicks?t.tickMarkLength:0}function fn(t){var e,n;return t.display?(e=V.options._parseFont(t),n=V.options.toPadding(t.padding),e.lineHeight+n.height):0}function gn(t,e){return V.extend(V.options._parseFont({fontFamily:ln(e.fontFamily,t.fontFamily),fontSize:ln(e.fontSize,t.fontSize),fontStyle:ln(e.fontStyle,t.fontStyle),lineHeight:ln(e.lineHeight,t.lineHeight)}),{color:V.options.resolve([e.fontColor,t.fontColor,z.global.defaultFontColor])})}function pn(t){var e=gn(t,t.minor);return{minor:e,major:t.major.enabled?gn(t,t.major):e}}function mn(t){var e,n,i,a=[];for(n=0,i=t.length;n<i;++n)void 0!==(e=t[n])._index&&a.push(e);return a}function vn(t,e,n,i){var a,r,o,s,l=ln(n,0),u=Math.min(ln(i,t.length),t.length),d=0;for(e=Math.ceil(e),i&&(e=(a=i-n)/Math.floor(a/e)),s=l;s<0;)d++,s=Math.round(l+d*e);for(r=Math.max(l,0);r<u;r++)o=t[r],r===s?(o._index=r,d++,s=Math.round(l+d*e)):delete o.label}z._set("scale",{display:!0,position:"left",offset:!1,gridLines:{display:!0,color:"rgba(0,0,0,0.1)",lineWidth:1,drawBorder:!0,drawOnChartArea:!0,drawTicks:!0,tickMarkLength:10,zeroLineWidth:1,zeroLineColor:"rgba(0,0,0,0.25)",zeroLineBorderDash:[],zeroLineBorderDashOffset:0,offsetGridLines:!1,borderDash:[],borderDashOffset:0},scaleLabel:{display:!1,labelString:"",padding:{top:4,bottom:4}},ticks:{beginAtZero:!1,minRotation:0,maxRotation:50,mirror:!1,padding:0,reverse:!1,display:!0,autoSkip:!0,autoSkipPadding:0,labelOffset:0,callback:rn.formatters.values,minor:{},major:{}}});var bn=X.extend({zeroLineIndex:0,getPadding:function(){return{left:this.paddingLeft||0,top:this.paddingTop||0,right:this.paddingRight||0,bottom:this.paddingBottom||0}},getTicks:function(){return this._ticks},_getLabels:function(){var t=this.chart.data;return this.options.labels||(this.isHorizontal()?t.xLabels:t.yLabels)||t.labels||[]},mergeTicksOptions:function(){},beforeUpdate:function(){V.callback(this.options.beforeUpdate,[this])},update:function(t,e,n){var i,a,r,o,s,l=this,u=l.options.ticks,d=u.sampleSize;if(l.beforeUpdate(),l.maxWidth=t,l.maxHeight=e,l.margins=V.extend({left:0,right:0,top:0,bottom:0},n),l._ticks=null,l.ticks=null,l._labelSizes=null,l._maxLabelLines=0,l.longestLabelWidth=0,l.longestTextCache=l.longestTextCache||{},l._gridLineItems=null,l._labelItems=null,l.beforeSetDimensions(),l.setDimensions(),l.afterSetDimensions(),l.beforeDataLimits(),l.determineDataLimits(),l.afterDataLimits(),l.beforeBuildTicks(),o=l.buildTicks()||[],(!(o=l.afterBuildTicks(o)||o)||!o.length)&&l.ticks)for(o=[],i=0,a=l.ticks.length;i<a;++i)o.push({value:l.ticks[i],major:!1});return l._ticks=o,s=d<o.length,r=l._convertTicksToLabels(s?function(t,e){for(var n=[],i=t.length/e,a=0,r=t.length;a<r;a+=i)n.push(t[Math.floor(a)]);return n}(o,d):o),l._configure(),l.beforeCalculateTickRotation(),l.calculateTickRotation(),l.afterCalculateTickRotation(),l.beforeFit(),l.fit(),l.afterFit(),l._ticksToDraw=u.display&&(u.autoSkip||"auto"===u.source)?l._autoSkip(o):o,s&&(r=l._convertTicksToLabels(l._ticksToDraw)),l.ticks=r,l.afterUpdate(),l.minSize},_configure:function(){var t,e,n=this,i=n.options.ticks.reverse;n.isHorizontal()?(t=n.left,e=n.right):(t=n.top,e=n.bottom,i=!i),n._startPixel=t,n._endPixel=e,n._reversePixels=i,n._length=e-t},afterUpdate:function(){V.callback(this.options.afterUpdate,[this])},beforeSetDimensions:function(){V.callback(this.options.beforeSetDimensions,[this])},setDimensions:function(){var t=this;t.isHorizontal()?(t.width=t.maxWidth,t.left=0,t.right=t.width):(t.height=t.maxHeight,t.top=0,t.bottom=t.height),t.paddingLeft=0,t.paddingTop=0,t.paddingRight=0,t.paddingBottom=0},afterSetDimensions:function(){V.callback(this.options.afterSetDimensions,[this])},beforeDataLimits:function(){V.callback(this.options.beforeDataLimits,[this])},determineDataLimits:V.noop,afterDataLimits:function(){V.callback(this.options.afterDataLimits,[this])},beforeBuildTicks:function(){V.callback(this.options.beforeBuildTicks,[this])},buildTicks:V.noop,afterBuildTicks:function(t){var e=this;return on(t)&&t.length?V.callback(e.options.afterBuildTicks,[e,t]):(e.ticks=V.callback(e.options.afterBuildTicks,[e,e.ticks])||e.ticks,t)},beforeTickToLabelConversion:function(){V.callback(this.options.beforeTickToLabelConversion,[this])},convertTicksToLabels:function(){var t=this.options.ticks;this.ticks=this.ticks.map(t.userCallback||t.callback,this)},afterTickToLabelConversion:function(){V.callback(this.options.afterTickToLabelConversion,[this])},beforeCalculateTickRotation:function(){V.callback(this.options.beforeCalculateTickRotation,[this])},calculateTickRotation:function(){var t,e,n,i,a,r,o,s=this,l=s.options,u=l.ticks,d=s.getTicks().length,h=u.minRotation||0,c=u.maxRotation,f=h;!s._isVisible()||!u.display||h>=c||d<=1||!s.isHorizontal()?s.labelRotation=h:(e=(t=s._getLabelSizes()).widest.width,n=t.highest.height-t.highest.offset,i=Math.min(s.maxWidth,s.chart.width-e),e+6>(a=l.offset?s.maxWidth/d:i/(d-1))&&(a=i/(d-(l.offset?.5:1)),r=s.maxHeight-cn(l.gridLines)-u.padding-fn(l.scaleLabel),o=Math.sqrt(e*e+n*n),f=V.toDegrees(Math.min(Math.asin(Math.min((t.highest.height+6)/a,1)),Math.asin(Math.min(r/o,1))-Math.asin(n/o))),f=Math.max(h,Math.min(c,f))),s.labelRotation=f)},afterCalculateTickRotation:function(){V.callback(this.options.afterCalculateTickRotation,[this])},beforeFit:function(){V.callback(this.options.beforeFit,[this])},fit:function(){var t=this,e=t.minSize={width:0,height:0},n=t.chart,i=t.options,a=i.ticks,r=i.scaleLabel,o=i.gridLines,s=t._isVisible(),l="bottom"===i.position,u=t.isHorizontal();if(u?e.width=t.maxWidth:s&&(e.width=cn(o)+fn(r)),u?s&&(e.height=cn(o)+fn(r)):e.height=t.maxHeight,a.display&&s){var d=pn(a),h=t._getLabelSizes(),c=h.first,f=h.last,g=h.widest,p=h.highest,m=.4*d.minor.lineHeight,v=a.padding;if(u){var b=0!==t.labelRotation,x=V.toRadians(t.labelRotation),y=Math.cos(x),_=Math.sin(x),k=_*g.width+y*(p.height-(b?p.offset:0))+(b?0:m);e.height=Math.min(t.maxHeight,e.height+k+v);var w,M,S=t.getPixelForTick(0)-t.left,C=t.right-t.getPixelForTick(t.getTicks().length-1);b?(w=l?y*c.width+_*c.offset:_*(c.height-c.offset),M=l?_*(f.height-f.offset):y*f.width+_*f.offset):(w=c.width/2,M=f.width/2),t.paddingLeft=Math.max((w-S)*t.width/(t.width-S),0)+3,t.paddingRight=Math.max((M-C)*t.width/(t.width-C),0)+3}else{var P=a.mirror?0:g.width+v+m;e.width=Math.min(t.maxWidth,e.width+P),t.paddingTop=c.height/2,t.paddingBottom=f.height/2}}t.handleMargins(),u?(t.width=t._length=n.width-t.margins.left-t.margins.right,t.height=e.height):(t.width=e.width,t.height=t._length=n.height-t.margins.top-t.margins.bottom)},handleMargins:function(){var t=this;t.margins&&(t.margins.left=Math.max(t.paddingLeft,t.margins.left),t.margins.top=Math.max(t.paddingTop,t.margins.top),t.margins.right=Math.max(t.paddingRight,t.margins.right),t.margins.bottom=Math.max(t.paddingBottom,t.margins.bottom))},afterFit:function(){V.callback(this.options.afterFit,[this])},isHorizontal:function(){var t=this.options.position;return"top"===t||"bottom"===t},isFullWidth:function(){return this.options.fullWidth},getRightValue:function(t){if(sn(t))return NaN;if(("number"==typeof t||t instanceof Number)&&!isFinite(t))return NaN;if(t)if(this.isHorizontal()){if(void 0!==t.x)return this.getRightValue(t.x)}else if(void 0!==t.y)return this.getRightValue(t.y);return t},_convertTicksToLabels:function(t){var e,n,i,a=this;for(a.ticks=t.map((function(t){return t.value})),a.beforeTickToLabelConversion(),e=a.convertTicksToLabels(t)||a.ticks,a.afterTickToLabelConversion(),n=0,i=t.length;n<i;++n)t[n].label=e[n];return e},_getLabelSizes:function(){var t=this,e=t._labelSizes;return e||(t._labelSizes=e=hn(t.ctx,pn(t.options.ticks),t.getTicks(),t.longestTextCache),t.longestLabelWidth=e.widest.width),e},_parseValue:function(t){var e,n,i,a;return on(t)?(e=+this.getRightValue(t[0]),n=+this.getRightValue(t[1]),i=Math.min(e,n),a=Math.max(e,n)):(e=void 0,n=t=+this.getRightValue(t),i=t,a=t),{min:i,max:a,start:e,end:n}},_getScaleLabel:function(t){var e=this._parseValue(t);return void 0!==e.start?"["+e.start+", "+e.end+"]":+this.getRightValue(t)},getLabelForIndex:V.noop,getPixelForValue:V.noop,getValueForPixel:V.noop,getPixelForTick:function(t){var e=this.options.offset,n=this._ticks.length,i=1/Math.max(n-(e?0:1),1);return t<0||t>n-1?null:this.getPixelForDecimal(t*i+(e?i/2:0))},getPixelForDecimal:function(t){return this._reversePixels&&(t=1-t),this._startPixel+t*this._length},getDecimalForPixel:function(t){var e=(t-this._startPixel)/this._length;return this._reversePixels?1-e:e},getBasePixel:function(){return this.getPixelForValue(this.getBaseValue())},getBaseValue:function(){var t=this.min,e=this.max;return this.beginAtZero?0:t<0&&e<0?e:t>0&&e>0?t:0},_autoSkip:function(t){var e,n,i,a,r=this.options.ticks,o=this._length,s=r.maxTicksLimit||o/this._tickSize()+1,l=r.major.enabled?function(t){var e,n,i=[];for(e=0,n=t.length;e<n;e++)t[e].major&&i.push(e);return i}(t):[],u=l.length,d=l[0],h=l[u-1];if(u>s)return function(t,e,n){var i,a,r=0,o=e[0];for(n=Math.ceil(n),i=0;i<t.length;i++)a=t[i],i===o?(a._index=i,o=e[++r*n]):delete a.label}(t,l,u/s),mn(t);if(i=function(t,e,n,i){var a,r,o,s,l=function(t){var e,n,i=t.length;if(i<2)return!1;for(n=t[0],e=1;e<i;++e)if(t[e]-t[e-1]!==n)return!1;return n}(t),u=(e.length-1)/i;if(!l)return Math.max(u,1);for(o=0,s=(a=V.math._factorize(l)).length-1;o<s;o++)if((r=a[o])>u)return r;return Math.max(u,1)}(l,t,0,s),u>0){for(e=0,n=u-1;e<n;e++)vn(t,i,l[e],l[e+1]);return a=u>1?(h-d)/(u-1):null,vn(t,i,V.isNullOrUndef(a)?0:d-a,d),vn(t,i,h,V.isNullOrUndef(a)?t.length:h+a),mn(t)}return vn(t,i),mn(t)},_tickSize:function(){var t=this.options.ticks,e=V.toRadians(this.labelRotation),n=Math.abs(Math.cos(e)),i=Math.abs(Math.sin(e)),a=this._getLabelSizes(),r=t.autoSkipPadding||0,o=a?a.widest.width+r:0,s=a?a.highest.height+r:0;return this.isHorizontal()?s*n>o*i?o/n:s/i:s*i<o*n?s/n:o/i},_isVisible:function(){var t,e,n,i=this.chart,a=this.options.display;if("auto"!==a)return!!a;for(t=0,e=i.data.datasets.length;t<e;++t)if(i.isDatasetVisible(t)&&((n=i.getDatasetMeta(t)).xAxisID===this.id||n.yAxisID===this.id))return!0;return!1},_computeGridLineItems:function(t){var e,n,i,a,r,o,s,l,u,d,h,c,f,g,p,m,v,b=this,x=b.chart,y=b.options,_=y.gridLines,k=y.position,w=_.offsetGridLines,M=b.isHorizontal(),S=b._ticksToDraw,C=S.length+(w?1:0),P=cn(_),A=[],D=_.drawBorder?un(_.lineWidth,0,0):0,T=D/2,I=V._alignPixel,F=function(t){return I(x,t,D)};for("top"===k?(e=F(b.bottom),s=b.bottom-P,u=e-T,h=F(t.top)+T,f=t.bottom):"bottom"===k?(e=F(b.top),h=t.top,f=F(t.bottom)-T,s=e+T,u=b.top+P):"left"===k?(e=F(b.right),o=b.right-P,l=e-T,d=F(t.left)+T,c=t.right):(e=F(b.left),d=t.left,c=F(t.right)-T,o=e+T,l=b.left+P),n=0;n<C;++n)i=S[n]||{},sn(i.label)&&n<S.length||(n===b.zeroLineIndex&&y.offset===w?(g=_.zeroLineWidth,p=_.zeroLineColor,m=_.zeroLineBorderDash||[],v=_.zeroLineBorderDashOffset||0):(g=un(_.lineWidth,n,1),p=un(_.color,n,"rgba(0,0,0,0.1)"),m=_.borderDash||[],v=_.borderDashOffset||0),void 0!==(a=dn(b,i._index||n,w))&&(r=I(x,a,g),M?o=l=d=c=r:s=u=h=f=r,A.push({tx1:o,ty1:s,tx2:l,ty2:u,x1:d,y1:h,x2:c,y2:f,width:g,color:p,borderDash:m,borderDashOffset:v})));return A.ticksLength=C,A.borderValue=e,A},_computeLabelItems:function(){var t,e,n,i,a,r,o,s,l,u,d,h,c=this,f=c.options,g=f.ticks,p=f.position,m=g.mirror,v=c.isHorizontal(),b=c._ticksToDraw,x=pn(g),y=g.padding,_=cn(f.gridLines),k=-V.toRadians(c.labelRotation),w=[];for("top"===p?(r=c.bottom-_-y,o=k?"left":"center"):"bottom"===p?(r=c.top+_+y,o=k?"right":"center"):"left"===p?(a=c.right-(m?0:_)-y,o=m?"left":"right"):(a=c.left+(m?0:_)+y,o=m?"right":"left"),t=0,e=b.length;t<e;++t)i=(n=b[t]).label,sn(i)||(s=c.getPixelForTick(n._index||t)+g.labelOffset,u=(l=n.major?x.major:x.minor).lineHeight,d=on(i)?i.length:1,v?(a=s,h="top"===p?((k?1:.5)-d)*u:(k?0:.5)*u):(r=s,h=(1-d)*u/2),w.push({x:a,y:r,rotation:k,label:i,font:l,textOffset:h,textAlign:o}));return w},_drawGrid:function(t){var e=this,n=e.options.gridLines;if(n.display){var i,a,r,o,s,l=e.ctx,u=e.chart,d=V._alignPixel,h=n.drawBorder?un(n.lineWidth,0,0):0,c=e._gridLineItems||(e._gridLineItems=e._computeGridLineItems(t));for(r=0,o=c.length;r<o;++r)i=(s=c[r]).width,a=s.color,i&&a&&(l.save(),l.lineWidth=i,l.strokeStyle=a,l.setLineDash&&(l.setLineDash(s.borderDash),l.lineDashOffset=s.borderDashOffset),l.beginPath(),n.drawTicks&&(l.moveTo(s.tx1,s.ty1),l.lineTo(s.tx2,s.ty2)),n.drawOnChartArea&&(l.moveTo(s.x1,s.y1),l.lineTo(s.x2,s.y2)),l.stroke(),l.restore());if(h){var f,g,p,m,v=h,b=un(n.lineWidth,c.ticksLength-1,1),x=c.borderValue;e.isHorizontal()?(f=d(u,e.left,v)-v/2,g=d(u,e.right,b)+b/2,p=m=x):(p=d(u,e.top,v)-v/2,m=d(u,e.bottom,b)+b/2,f=g=x),l.lineWidth=h,l.strokeStyle=un(n.color,0),l.beginPath(),l.moveTo(f,p),l.lineTo(g,m),l.stroke()}}},_drawLabels:function(){var t=this;if(t.options.ticks.display){var e,n,i,a,r,o,s,l,u=t.ctx,d=t._labelItems||(t._labelItems=t._computeLabelItems());for(e=0,i=d.length;e<i;++e){if(o=(r=d[e]).font,u.save(),u.translate(r.x,r.y),u.rotate(r.rotation),u.font=o.string,u.fillStyle=o.color,u.textBaseline="middle",u.textAlign=r.textAlign,s=r.label,l=r.textOffset,on(s))for(n=0,a=s.length;n<a;++n)u.fillText(""+s[n],0,l),l+=o.lineHeight;else u.fillText(s,0,l);u.restore()}}},_drawTitle:function(){var t=this,e=t.ctx,n=t.options,i=n.scaleLabel;if(i.display){var a,r,o=ln(i.fontColor,z.global.defaultFontColor),s=V.options._parseFont(i),l=V.options.toPadding(i.padding),u=s.lineHeight/2,d=n.position,h=0;if(t.isHorizontal())a=t.left+t.width/2,r="bottom"===d?t.bottom-u-l.bottom:t.top+u+l.top;else{var c="left"===d;a=c?t.left+u+l.top:t.right-u-l.top,r=t.top+t.height/2,h=c?-.5*Math.PI:.5*Math.PI}e.save(),e.translate(a,r),e.rotate(h),e.textAlign="center",e.textBaseline="middle",e.fillStyle=o,e.font=s.string,e.fillText(i.labelString,0,0),e.restore()}},draw:function(t){this._isVisible()&&(this._drawGrid(t),this._drawTitle(),this._drawLabels())},_layers:function(){var t=this,e=t.options,n=e.ticks&&e.ticks.z||0,i=e.gridLines&&e.gridLines.z||0;return t._isVisible()&&n!==i&&t.draw===t._draw?[{z:i,draw:function(){t._drawGrid.apply(t,arguments),t._drawTitle.apply(t,arguments)}},{z:n,draw:function(){t._drawLabels.apply(t,arguments)}}]:[{z:n,draw:function(){t.draw.apply(t,arguments)}}]},_getMatchingVisibleMetas:function(t){var e=this,n=e.isHorizontal();return e.chart._getSortedVisibleDatasetMetas().filter((function(i){return(!t||i.type===t)&&(n?i.xAxisID===e.id:i.yAxisID===e.id)}))}});bn.prototype._draw=bn.prototype.draw;var xn=bn,yn=V.isNullOrUndef,_n=xn.extend({determineDataLimits:function(){var t,e=this,n=e._getLabels(),i=e.options.ticks,a=i.min,r=i.max,o=0,s=n.length-1;void 0!==a&&(t=n.indexOf(a))>=0&&(o=t),void 0!==r&&(t=n.indexOf(r))>=0&&(s=t),e.minIndex=o,e.maxIndex=s,e.min=n[o],e.max=n[s]},buildTicks:function(){var t=this._getLabels(),e=this.minIndex,n=this.maxIndex;this.ticks=0===e&&n===t.length-1?t:t.slice(e,n+1)},getLabelForIndex:function(t,e){var n=this.chart;return n.getDatasetMeta(e).controller._getValueScaleId()===this.id?this.getRightValue(n.data.datasets[e].data[t]):this._getLabels()[t]},_configure:function(){var t=this,e=t.options.offset,n=t.ticks;xn.prototype._configure.call(t),t.isHorizontal()||(t._reversePixels=!t._reversePixels),n&&(t._startValue=t.minIndex-(e?.5:0),t._valueRange=Math.max(n.length-(e?0:1),1))},getPixelForValue:function(t,e,n){var i,a,r,o=this;return yn(e)||yn(n)||(t=o.chart.data.datasets[n].data[e]),yn(t)||(i=o.isHorizontal()?t.x:t.y),(void 0!==i||void 0!==t&&isNaN(e))&&(a=o._getLabels(),t=V.valueOrDefault(i,t),e=-1!==(r=a.indexOf(t))?r:e,isNaN(e)&&(e=t)),o.getPixelForDecimal((e-o._startValue)/o._valueRange)},getPixelForTick:function(t){var e=this.ticks;return t<0||t>e.length-1?null:this.getPixelForValue(e[t],t+this.minIndex)},getValueForPixel:function(t){var e=Math.round(this._startValue+this.getDecimalForPixel(t)*this._valueRange);return Math.min(Math.max(e,0),this.ticks.length-1)},getBasePixel:function(){return this.bottom}}),kn={position:"bottom"};_n._defaults=kn;var wn=V.noop,Mn=V.isNullOrUndef;var Sn=xn.extend({getRightValue:function(t){return"string"==typeof t?+t:xn.prototype.getRightValue.call(this,t)},handleTickRangeOptions:function(){var t=this,e=t.options.ticks;if(e.beginAtZero){var n=V.sign(t.min),i=V.sign(t.max);n<0&&i<0?t.max=0:n>0&&i>0&&(t.min=0)}var a=void 0!==e.min||void 0!==e.suggestedMin,r=void 0!==e.max||void 0!==e.suggestedMax;void 0!==e.min?t.min=e.min:void 0!==e.suggestedMin&&(null===t.min?t.min=e.suggestedMin:t.min=Math.min(t.min,e.suggestedMin)),void 0!==e.max?t.max=e.max:void 0!==e.suggestedMax&&(null===t.max?t.max=e.suggestedMax:t.max=Math.max(t.max,e.suggestedMax)),a!==r&&t.min>=t.max&&(a?t.max=t.min+1:t.min=t.max-1),t.min===t.max&&(t.max++,e.beginAtZero||t.min--)},getTickLimit:function(){var t,e=this.options.ticks,n=e.stepSize,i=e.maxTicksLimit;return n?t=Math.ceil(this.max/n)-Math.floor(this.min/n)+1:(t=this._computeTickLimit(),i=i||11),i&&(t=Math.min(i,t)),t},_computeTickLimit:function(){return Number.POSITIVE_INFINITY},handleDirectionalChanges:wn,buildTicks:function(){var t=this,e=t.options.ticks,n=t.getTickLimit(),i={maxTicks:n=Math.max(2,n),min:e.min,max:e.max,precision:e.precision,stepSize:V.valueOrDefault(e.fixedStepSize,e.stepSize)},a=t.ticks=function(t,e){var n,i,a,r,o=[],s=t.stepSize,l=s||1,u=t.maxTicks-1,d=t.min,h=t.max,c=t.precision,f=e.min,g=e.max,p=V.niceNum((g-f)/u/l)*l;if(p<1e-14&&Mn(d)&&Mn(h))return[f,g];(r=Math.ceil(g/p)-Math.floor(f/p))>u&&(p=V.niceNum(r*p/u/l)*l),s||Mn(c)?n=Math.pow(10,V._decimalPlaces(p)):(n=Math.pow(10,c),p=Math.ceil(p*n)/n),i=Math.floor(f/p)*p,a=Math.ceil(g/p)*p,s&&(!Mn(d)&&V.almostWhole(d/p,p/1e3)&&(i=d),!Mn(h)&&V.almostWhole(h/p,p/1e3)&&(a=h)),r=(a-i)/p,r=V.almostEquals(r,Math.round(r),p/1e3)?Math.round(r):Math.ceil(r),i=Math.round(i*n)/n,a=Math.round(a*n)/n,o.push(Mn(d)?i:d);for(var m=1;m<r;++m)o.push(Math.round((i+m*p)*n)/n);return o.push(Mn(h)?a:h),o}(i,t);t.handleDirectionalChanges(),t.max=V.max(a),t.min=V.min(a),e.reverse?(a.reverse(),t.start=t.max,t.end=t.min):(t.start=t.min,t.end=t.max)},convertTicksToLabels:function(){var t=this;t.ticksAsNumbers=t.ticks.slice(),t.zeroLineIndex=t.ticks.indexOf(0),xn.prototype.convertTicksToLabels.call(t)},_configure:function(){var t,e=this,n=e.getTicks(),i=e.min,a=e.max;xn.prototype._configure.call(e),e.options.offset&&n.length&&(i-=t=(a-i)/Math.max(n.length-1,1)/2,a+=t),e._startValue=i,e._endValue=a,e._valueRange=a-i}}),Cn={position:"left",ticks:{callback:rn.formatters.linear}};function Pn(t,e,n,i){var a,r,o=t.options,s=function(t,e,n){var i=[n.type,void 0===e&&void 0===n.stack?n.index:"",n.stack].join(".");return void 0===t[i]&&(t[i]={pos:[],neg:[]}),t[i]}(e,o.stacked,n),l=s.pos,u=s.neg,d=i.length;for(a=0;a<d;++a)r=t._parseValue(i[a]),isNaN(r.min)||isNaN(r.max)||n.data[a].hidden||(l[a]=l[a]||0,u[a]=u[a]||0,o.relativePoints?l[a]=100:r.min<0||r.max<0?u[a]+=r.min:l[a]+=r.max)}function An(t,e,n){var i,a,r=n.length;for(i=0;i<r;++i)a=t._parseValue(n[i]),isNaN(a.min)||isNaN(a.max)||e.data[i].hidden||(t.min=Math.min(t.min,a.min),t.max=Math.max(t.max,a.max))}var Dn=Sn.extend({determineDataLimits:function(){var t,e,n,i,a=this,r=a.options,o=a.chart.data.datasets,s=a._getMatchingVisibleMetas(),l=r.stacked,u={},d=s.length;if(a.min=Number.POSITIVE_INFINITY,a.max=Number.NEGATIVE_INFINITY,void 0===l)for(t=0;!l&&t<d;++t)l=void 0!==(e=s[t]).stack;for(t=0;t<d;++t)n=o[(e=s[t]).index].data,l?Pn(a,u,e,n):An(a,e,n);V.each(u,(function(t){i=t.pos.concat(t.neg),a.min=Math.min(a.min,V.min(i)),a.max=Math.max(a.max,V.max(i))})),a.min=V.isFinite(a.min)&&!isNaN(a.min)?a.min:0,a.max=V.isFinite(a.max)&&!isNaN(a.max)?a.max:1,a.handleTickRangeOptions()},_computeTickLimit:function(){var t;return this.isHorizontal()?Math.ceil(this.width/40):(t=V.options._parseFont(this.options.ticks),Math.ceil(this.height/t.lineHeight))},handleDirectionalChanges:function(){this.isHorizontal()||this.ticks.reverse()},getLabelForIndex:function(t,e){return this._getScaleLabel(this.chart.data.datasets[e].data[t])},getPixelForValue:function(t){return this.getPixelForDecimal((+this.getRightValue(t)-this._startValue)/this._valueRange)},getValueForPixel:function(t){return this._startValue+this.getDecimalForPixel(t)*this._valueRange},getPixelForTick:function(t){var e=this.ticksAsNumbers;return t<0||t>e.length-1?null:this.getPixelForValue(e[t])}}),Tn=Cn;Dn._defaults=Tn;var In=V.valueOrDefault,Fn=V.math.log10;var Ln={position:"left",ticks:{callback:rn.formatters.logarithmic}};function On(t,e){return V.isFinite(t)&&t>=0?t:e}var Rn=xn.extend({determineDataLimits:function(){var t,e,n,i,a,r,o=this,s=o.options,l=o.chart,u=l.data.datasets,d=o.isHorizontal();function h(t){return d?t.xAxisID===o.id:t.yAxisID===o.id}o.min=Number.POSITIVE_INFINITY,o.max=Number.NEGATIVE_INFINITY,o.minNotZero=Number.POSITIVE_INFINITY;var c=s.stacked;if(void 0===c)for(t=0;t<u.length;t++)if(e=l.getDatasetMeta(t),l.isDatasetVisible(t)&&h(e)&&void 0!==e.stack){c=!0;break}if(s.stacked||c){var f={};for(t=0;t<u.length;t++){var g=[(e=l.getDatasetMeta(t)).type,void 0===s.stacked&&void 0===e.stack?t:"",e.stack].join(".");if(l.isDatasetVisible(t)&&h(e))for(void 0===f[g]&&(f[g]=[]),a=0,r=(i=u[t].data).length;a<r;a++){var p=f[g];n=o._parseValue(i[a]),isNaN(n.min)||isNaN(n.max)||e.data[a].hidden||n.min<0||n.max<0||(p[a]=p[a]||0,p[a]+=n.max)}}V.each(f,(function(t){if(t.length>0){var e=V.min(t),n=V.max(t);o.min=Math.min(o.min,e),o.max=Math.max(o.max,n)}}))}else for(t=0;t<u.length;t++)if(e=l.getDatasetMeta(t),l.isDatasetVisible(t)&&h(e))for(a=0,r=(i=u[t].data).length;a<r;a++)n=o._parseValue(i[a]),isNaN(n.min)||isNaN(n.max)||e.data[a].hidden||n.min<0||n.max<0||(o.min=Math.min(n.min,o.min),o.max=Math.max(n.max,o.max),0!==n.min&&(o.minNotZero=Math.min(n.min,o.minNotZero)));o.min=V.isFinite(o.min)?o.min:null,o.max=V.isFinite(o.max)?o.max:null,o.minNotZero=V.isFinite(o.minNotZero)?o.minNotZero:null,this.handleTickRangeOptions()},handleTickRangeOptions:function(){var t=this,e=t.options.ticks;t.min=On(e.min,t.min),t.max=On(e.max,t.max),t.min===t.max&&(0!==t.min&&null!==t.min?(t.min=Math.pow(10,Math.floor(Fn(t.min))-1),t.max=Math.pow(10,Math.floor(Fn(t.max))+1)):(t.min=1,t.max=10)),null===t.min&&(t.min=Math.pow(10,Math.floor(Fn(t.max))-1)),null===t.max&&(t.max=0!==t.min?Math.pow(10,Math.floor(Fn(t.min))+1):10),null===t.minNotZero&&(t.min>0?t.minNotZero=t.min:t.max<1?t.minNotZero=Math.pow(10,Math.floor(Fn(t.max))):t.minNotZero=1)},buildTicks:function(){var t=this,e=t.options.ticks,n=!t.isHorizontal(),i={min:On(e.min),max:On(e.max)},a=t.ticks=function(t,e){var n,i,a=[],r=In(t.min,Math.pow(10,Math.floor(Fn(e.min)))),o=Math.floor(Fn(e.max)),s=Math.ceil(e.max/Math.pow(10,o));0===r?(n=Math.floor(Fn(e.minNotZero)),i=Math.floor(e.minNotZero/Math.pow(10,n)),a.push(r),r=i*Math.pow(10,n)):(n=Math.floor(Fn(r)),i=Math.floor(r/Math.pow(10,n)));var l=n<0?Math.pow(10,Math.abs(n)):1;do{a.push(r),10===++i&&(i=1,l=++n>=0?1:l),r=Math.round(i*Math.pow(10,n)*l)/l}while(n<o||n===o&&i<s);var u=In(t.max,r);return a.push(u),a}(i,t);t.max=V.max(a),t.min=V.min(a),e.reverse?(n=!n,t.start=t.max,t.end=t.min):(t.start=t.min,t.end=t.max),n&&a.reverse()},convertTicksToLabels:function(){this.tickValues=this.ticks.slice(),xn.prototype.convertTicksToLabels.call(this)},getLabelForIndex:function(t,e){return this._getScaleLabel(this.chart.data.datasets[e].data[t])},getPixelForTick:function(t){var e=this.tickValues;return t<0||t>e.length-1?null:this.getPixelForValue(e[t])},_getFirstTickValue:function(t){var e=Math.floor(Fn(t));return Math.floor(t/Math.pow(10,e))*Math.pow(10,e)},_configure:function(){var t=this,e=t.min,n=0;xn.prototype._configure.call(t),0===e&&(e=t._getFirstTickValue(t.minNotZero),n=In(t.options.ticks.fontSize,z.global.defaultFontSize)/t._length),t._startValue=Fn(e),t._valueOffset=n,t._valueRange=(Fn(t.max)-Fn(e))/(1-n)},getPixelForValue:function(t){var e=this,n=0;return(t=+e.getRightValue(t))>e.min&&t>0&&(n=(Fn(t)-e._startValue)/e._valueRange+e._valueOffset),e.getPixelForDecimal(n)},getValueForPixel:function(t){var e=this,n=e.getDecimalForPixel(t);return 0===n&&0===e.min?0:Math.pow(10,e._startValue+(n-e._valueOffset)*e._valueRange)}}),zn=Ln;Rn._defaults=zn;var Nn=V.valueOrDefault,Bn=V.valueAtIndexOrDefault,En=V.options.resolve,Wn={display:!0,animate:!0,position:"chartArea",angleLines:{display:!0,color:"rgba(0,0,0,0.1)",lineWidth:1,borderDash:[],borderDashOffset:0},gridLines:{circular:!1},ticks:{showLabelBackdrop:!0,backdropColor:"rgba(255,255,255,0.75)",backdropPaddingY:2,backdropPaddingX:2,callback:rn.formatters.linear},pointLabels:{display:!0,fontSize:10,callback:function(t){return t}}};function Vn(t){var e=t.ticks;return e.display&&t.display?Nn(e.fontSize,z.global.defaultFontSize)+2*e.backdropPaddingY:0}function Hn(t,e,n,i,a){return t===i||t===a?{start:e-n/2,end:e+n/2}:t<i||t>a?{start:e-n,end:e}:{start:e,end:e+n}}function jn(t){return 0===t||180===t?"center":t<180?"left":"right"}function qn(t,e,n,i){var a,r,o=n.y+i/2;if(V.isArray(e))for(a=0,r=e.length;a<r;++a)t.fillText(e[a],n.x,o),o+=i;else t.fillText(e,n.x,o)}function Un(t,e,n){90===t||270===t?n.y-=e.h/2:(t>270||t<90)&&(n.y-=e.h)}function Yn(t){return V.isNumber(t)?t:0}var Gn=Sn.extend({setDimensions:function(){var t=this;t.width=t.maxWidth,t.height=t.maxHeight,t.paddingTop=Vn(t.options)/2,t.xCenter=Math.floor(t.width/2),t.yCenter=Math.floor((t.height-t.paddingTop)/2),t.drawingArea=Math.min(t.height-t.paddingTop,t.width)/2},determineDataLimits:function(){var t=this,e=t.chart,n=Number.POSITIVE_INFINITY,i=Number.NEGATIVE_INFINITY;V.each(e.data.datasets,(function(a,r){if(e.isDatasetVisible(r)){var o=e.getDatasetMeta(r);V.each(a.data,(function(e,a){var r=+t.getRightValue(e);isNaN(r)||o.data[a].hidden||(n=Math.min(r,n),i=Math.max(r,i))}))}})),t.min=n===Number.POSITIVE_INFINITY?0:n,t.max=i===Number.NEGATIVE_INFINITY?0:i,t.handleTickRangeOptions()},_computeTickLimit:function(){return Math.ceil(this.drawingArea/Vn(this.options))},convertTicksToLabels:function(){var t=this;Sn.prototype.convertTicksToLabels.call(t),t.pointLabels=t.chart.data.labels.map((function(){var e=V.callback(t.options.pointLabels.callback,arguments,t);return e||0===e?e:""}))},getLabelForIndex:function(t,e){return+this.getRightValue(this.chart.data.datasets[e].data[t])},fit:function(){var t=this.options;t.display&&t.pointLabels.display?function(t){var e,n,i,a=V.options._parseFont(t.options.pointLabels),r={l:0,r:t.width,t:0,b:t.height-t.paddingTop},o={};t.ctx.font=a.string,t._pointLabelSizes=[];var s,l,u,d=t.chart.data.labels.length;for(e=0;e<d;e++){i=t.getPointPosition(e,t.drawingArea+5),s=t.ctx,l=a.lineHeight,u=t.pointLabels[e],n=V.isArray(u)?{w:V.longestText(s,s.font,u),h:u.length*l}:{w:s.measureText(u).width,h:l},t._pointLabelSizes[e]=n;var h=t.getIndexAngle(e),c=V.toDegrees(h)%360,f=Hn(c,i.x,n.w,0,180),g=Hn(c,i.y,n.h,90,270);f.start<r.l&&(r.l=f.start,o.l=h),f.end>r.r&&(r.r=f.end,o.r=h),g.start<r.t&&(r.t=g.start,o.t=h),g.end>r.b&&(r.b=g.end,o.b=h)}t.setReductions(t.drawingArea,r,o)}(this):this.setCenterPoint(0,0,0,0)},setReductions:function(t,e,n){var i=this,a=e.l/Math.sin(n.l),r=Math.max(e.r-i.width,0)/Math.sin(n.r),o=-e.t/Math.cos(n.t),s=-Math.max(e.b-(i.height-i.paddingTop),0)/Math.cos(n.b);a=Yn(a),r=Yn(r),o=Yn(o),s=Yn(s),i.drawingArea=Math.min(Math.floor(t-(a+r)/2),Math.floor(t-(o+s)/2)),i.setCenterPoint(a,r,o,s)},setCenterPoint:function(t,e,n,i){var a=this,r=a.width-e-a.drawingArea,o=t+a.drawingArea,s=n+a.drawingArea,l=a.height-a.paddingTop-i-a.drawingArea;a.xCenter=Math.floor((o+r)/2+a.left),a.yCenter=Math.floor((s+l)/2+a.top+a.paddingTop)},getIndexAngle:function(t){var e=this.chart,n=(t*(360/e.data.labels.length)+((e.options||{}).startAngle||0))%360;return(n<0?n+360:n)*Math.PI*2/360},getDistanceFromCenterForValue:function(t){var e=this;if(V.isNullOrUndef(t))return NaN;var n=e.drawingArea/(e.max-e.min);return e.options.ticks.reverse?(e.max-t)*n:(t-e.min)*n},getPointPosition:function(t,e){var n=this.getIndexAngle(t)-Math.PI/2;return{x:Math.cos(n)*e+this.xCenter,y:Math.sin(n)*e+this.yCenter}},getPointPositionForValue:function(t,e){return this.getPointPosition(t,this.getDistanceFromCenterForValue(e))},getBasePosition:function(t){var e=this.min,n=this.max;return this.getPointPositionForValue(t||0,this.beginAtZero?0:e<0&&n<0?n:e>0&&n>0?e:0)},_drawGrid:function(){var t,e,n,i=this,a=i.ctx,r=i.options,o=r.gridLines,s=r.angleLines,l=Nn(s.lineWidth,o.lineWidth),u=Nn(s.color,o.color);if(r.pointLabels.display&&function(t){var e=t.ctx,n=t.options,i=n.pointLabels,a=Vn(n),r=t.getDistanceFromCenterForValue(n.ticks.reverse?t.min:t.max),o=V.options._parseFont(i);e.save(),e.font=o.string,e.textBaseline="middle";for(var s=t.chart.data.labels.length-1;s>=0;s--){var l=0===s?a/2:0,u=t.getPointPosition(s,r+l+5),d=Bn(i.fontColor,s,z.global.defaultFontColor);e.fillStyle=d;var h=t.getIndexAngle(s),c=V.toDegrees(h);e.textAlign=jn(c),Un(c,t._pointLabelSizes[s],u),qn(e,t.pointLabels[s],u,o.lineHeight)}e.restore()}(i),o.display&&V.each(i.ticks,(function(t,n){0!==n&&(e=i.getDistanceFromCenterForValue(i.ticksAsNumbers[n]),function(t,e,n,i){var a,r=t.ctx,o=e.circular,s=t.chart.data.labels.length,l=Bn(e.color,i-1),u=Bn(e.lineWidth,i-1);if((o||s)&&l&&u){if(r.save(),r.strokeStyle=l,r.lineWidth=u,r.setLineDash&&(r.setLineDash(e.borderDash||[]),r.lineDashOffset=e.borderDashOffset||0),r.beginPath(),o)r.arc(t.xCenter,t.yCenter,n,0,2*Math.PI);else{a=t.getPointPosition(0,n),r.moveTo(a.x,a.y);for(var d=1;d<s;d++)a=t.getPointPosition(d,n),r.lineTo(a.x,a.y)}r.closePath(),r.stroke(),r.restore()}}(i,o,e,n))})),s.display&&l&&u){for(a.save(),a.lineWidth=l,a.strokeStyle=u,a.setLineDash&&(a.setLineDash(En([s.borderDash,o.borderDash,[]])),a.lineDashOffset=En([s.borderDashOffset,o.borderDashOffset,0])),t=i.chart.data.labels.length-1;t>=0;t--)e=i.getDistanceFromCenterForValue(r.ticks.reverse?i.min:i.max),n=i.getPointPosition(t,e),a.beginPath(),a.moveTo(i.xCenter,i.yCenter),a.lineTo(n.x,n.y),a.stroke();a.restore()}},_drawLabels:function(){var t=this,e=t.ctx,n=t.options.ticks;if(n.display){var i,a,r=t.getIndexAngle(0),o=V.options._parseFont(n),s=Nn(n.fontColor,z.global.defaultFontColor);e.save(),e.font=o.string,e.translate(t.xCenter,t.yCenter),e.rotate(r),e.textAlign="center",e.textBaseline="middle",V.each(t.ticks,(function(r,l){(0!==l||n.reverse)&&(i=t.getDistanceFromCenterForValue(t.ticksAsNumbers[l]),n.showLabelBackdrop&&(a=e.measureText(r).width,e.fillStyle=n.backdropColor,e.fillRect(-a/2-n.backdropPaddingX,-i-o.size/2-n.backdropPaddingY,a+2*n.backdropPaddingX,o.size+2*n.backdropPaddingY)),e.fillStyle=s,e.fillText(r,0,-i))})),e.restore()}},_drawTitle:V.noop}),Xn=Wn;Gn._defaults=Xn;var Kn=V._deprecated,Zn=V.options.resolve,$n=V.valueOrDefault,Jn=Number.MIN_SAFE_INTEGER||-9007199254740991,Qn=Number.MAX_SAFE_INTEGER||9007199254740991,ti={millisecond:{common:!0,size:1,steps:1e3},second:{common:!0,size:1e3,steps:60},minute:{common:!0,size:6e4,steps:60},hour:{common:!0,size:36e5,steps:24},day:{common:!0,size:864e5,steps:30},week:{common:!1,size:6048e5,steps:4},month:{common:!0,size:2628e6,steps:12},quarter:{common:!1,size:7884e6,steps:4},year:{common:!0,size:3154e7}},ei=Object.keys(ti);function ni(t,e){return t-e}function ii(t){return V.valueOrDefault(t.time.min,t.ticks.min)}function ai(t){return V.valueOrDefault(t.time.max,t.ticks.max)}function ri(t,e,n,i){var a=function(t,e,n){for(var i,a,r,o=0,s=t.length-1;o>=0&&o<=s;){if(a=t[(i=o+s>>1)-1]||null,r=t[i],!a)return{lo:null,hi:r};if(r[e]<n)o=i+1;else{if(!(a[e]>n))return{lo:a,hi:r};s=i-1}}return{lo:r,hi:null}}(t,e,n),r=a.lo?a.hi?a.lo:t[t.length-2]:t[0],o=a.lo?a.hi?a.hi:t[t.length-1]:t[1],s=o[e]-r[e],l=s?(n-r[e])/s:0,u=(o[i]-r[i])*l;return r[i]+u}function oi(t,e){var n=t._adapter,i=t.options.time,a=i.parser,r=a||i.format,o=e;return"function"==typeof a&&(o=a(o)),V.isFinite(o)||(o="string"==typeof r?n.parse(o,r):n.parse(o)),null!==o?+o:(a||"function"!=typeof r||(o=r(e),V.isFinite(o)||(o=n.parse(o))),o)}function si(t,e){if(V.isNullOrUndef(e))return null;var n=t.options.time,i=oi(t,t.getRightValue(e));return null===i?i:(n.round&&(i=+t._adapter.startOf(i,n.round)),i)}function li(t,e,n,i){var a,r,o,s=ei.length;for(a=ei.indexOf(t);a<s-1;++a)if(o=(r=ti[ei[a]]).steps?r.steps:Qn,r.common&&Math.ceil((n-e)/(o*r.size))<=i)return ei[a];return ei[s-1]}function ui(t,e,n){var i,a,r=[],o={},s=e.length;for(i=0;i<s;++i)o[a=e[i]]=i,r.push({value:a,major:!1});return 0!==s&&n?function(t,e,n,i){var a,r,o=t._adapter,s=+o.startOf(e[0].value,i),l=e[e.length-1].value;for(a=s;a<=l;a=+o.add(a,1,i))(r=n[a])>=0&&(e[r].major=!0);return e}(t,r,o,n):r}var di=xn.extend({initialize:function(){this.mergeTicksOptions(),xn.prototype.initialize.call(this)},update:function(){var t=this,e=t.options,n=e.time||(e.time={}),i=t._adapter=new an._date(e.adapters.date);return Kn("time scale",n.format,"time.format","time.parser"),Kn("time scale",n.min,"time.min","ticks.min"),Kn("time scale",n.max,"time.max","ticks.max"),V.mergeIf(n.displayFormats,i.formats()),xn.prototype.update.apply(t,arguments)},getRightValue:function(t){return t&&void 0!==t.t&&(t=t.t),xn.prototype.getRightValue.call(this,t)},determineDataLimits:function(){var t,e,n,i,a,r,o,s=this,l=s.chart,u=s._adapter,d=s.options,h=d.time.unit||"day",c=Qn,f=Jn,g=[],p=[],m=[],v=s._getLabels();for(t=0,n=v.length;t<n;++t)m.push(si(s,v[t]));for(t=0,n=(l.data.datasets||[]).length;t<n;++t)if(l.isDatasetVisible(t))if(a=l.data.datasets[t].data,V.isObject(a[0]))for(p[t]=[],e=0,i=a.length;e<i;++e)r=si(s,a[e]),g.push(r),p[t][e]=r;else p[t]=m.slice(0),o||(g=g.concat(m),o=!0);else p[t]=[];m.length&&(c=Math.min(c,m[0]),f=Math.max(f,m[m.length-1])),g.length&&(g=n>1?function(t){var e,n,i,a={},r=[];for(e=0,n=t.length;e<n;++e)a[i=t[e]]||(a[i]=!0,r.push(i));return r}(g).sort(ni):g.sort(ni),c=Math.min(c,g[0]),f=Math.max(f,g[g.length-1])),c=si(s,ii(d))||c,f=si(s,ai(d))||f,c=c===Qn?+u.startOf(Date.now(),h):c,f=f===Jn?+u.endOf(Date.now(),h)+1:f,s.min=Math.min(c,f),s.max=Math.max(c+1,f),s._table=[],s._timestamps={data:g,datasets:p,labels:m}},buildTicks:function(){var t,e,n,i=this,a=i.min,r=i.max,o=i.options,s=o.ticks,l=o.time,u=i._timestamps,d=[],h=i.getLabelCapacity(a),c=s.source,f=o.distribution;for(u="data"===c||"auto"===c&&"series"===f?u.data:"labels"===c?u.labels:function(t,e,n,i){var a,r=t._adapter,o=t.options,s=o.time,l=s.unit||li(s.minUnit,e,n,i),u=Zn([s.stepSize,s.unitStepSize,1]),d="week"===l&&s.isoWeekday,h=e,c=[];if(d&&(h=+r.startOf(h,"isoWeek",d)),h=+r.startOf(h,d?"day":l),r.diff(n,e,l)>1e5*u)throw e+" and "+n+" are too far apart with stepSize of "+u+" "+l;for(a=h;a<n;a=+r.add(a,u,l))c.push(a);return a!==n&&"ticks"!==o.bounds||c.push(a),c}(i,a,r,h),"ticks"===o.bounds&&u.length&&(a=u[0],r=u[u.length-1]),a=si(i,ii(o))||a,r=si(i,ai(o))||r,t=0,e=u.length;t<e;++t)(n=u[t])>=a&&n<=r&&d.push(n);return i.min=a,i.max=r,i._unit=l.unit||(s.autoSkip?li(l.minUnit,i.min,i.max,h):function(t,e,n,i,a){var r,o;for(r=ei.length-1;r>=ei.indexOf(n);r--)if(o=ei[r],ti[o].common&&t._adapter.diff(a,i,o)>=e-1)return o;return ei[n?ei.indexOf(n):0]}(i,d.length,l.minUnit,i.min,i.max)),i._majorUnit=s.major.enabled&&"year"!==i._unit?function(t){for(var e=ei.indexOf(t)+1,n=ei.length;e<n;++e)if(ti[ei[e]].common)return ei[e]}(i._unit):void 0,i._table=function(t,e,n,i){if("linear"===i||!t.length)return[{time:e,pos:0},{time:n,pos:1}];var a,r,o,s,l,u=[],d=[e];for(a=0,r=t.length;a<r;++a)(s=t[a])>e&&s<n&&d.push(s);for(d.push(n),a=0,r=d.length;a<r;++a)l=d[a+1],o=d[a-1],s=d[a],void 0!==o&&void 0!==l&&Math.round((l+o)/2)===s||u.push({time:s,pos:a/(r-1)});return u}(i._timestamps.data,a,r,f),i._offsets=function(t,e,n,i,a){var r,o,s=0,l=0;return a.offset&&e.length&&(r=ri(t,"time",e[0],"pos"),s=1===e.length?1-r:(ri(t,"time",e[1],"pos")-r)/2,o=ri(t,"time",e[e.length-1],"pos"),l=1===e.length?o:(o-ri(t,"time",e[e.length-2],"pos"))/2),{start:s,end:l,factor:1/(s+1+l)}}(i._table,d,0,0,o),s.reverse&&d.reverse(),ui(i,d,i._majorUnit)},getLabelForIndex:function(t,e){var n=this,i=n._adapter,a=n.chart.data,r=n.options.time,o=a.labels&&t<a.labels.length?a.labels[t]:"",s=a.datasets[e].data[t];return V.isObject(s)&&(o=n.getRightValue(s)),r.tooltipFormat?i.format(oi(n,o),r.tooltipFormat):"string"==typeof o?o:i.format(oi(n,o),r.displayFormats.datetime)},tickFormatFunction:function(t,e,n,i){var a=this._adapter,r=this.options,o=r.time.displayFormats,s=o[this._unit],l=this._majorUnit,u=o[l],d=n[e],h=r.ticks,c=l&&u&&d&&d.major,f=a.format(t,i||(c?u:s)),g=c?h.major:h.minor,p=Zn([g.callback,g.userCallback,h.callback,h.userCallback]);return p?p(f,e,n):f},convertTicksToLabels:function(t){var e,n,i=[];for(e=0,n=t.length;e<n;++e)i.push(this.tickFormatFunction(t[e].value,e,t));return i},getPixelForOffset:function(t){var e=this._offsets,n=ri(this._table,"time",t,"pos");return this.getPixelForDecimal((e.start+n)*e.factor)},getPixelForValue:function(t,e,n){var i=null;if(void 0!==e&&void 0!==n&&(i=this._timestamps.datasets[n][e]),null===i&&(i=si(this,t)),null!==i)return this.getPixelForOffset(i)},getPixelForTick:function(t){var e=this.getTicks();return t>=0&&t<e.length?this.getPixelForOffset(e[t].value):null},getValueForPixel:function(t){var e=this._offsets,n=this.getDecimalForPixel(t)/e.factor-e.end,i=ri(this._table,"pos",n,"time");return this._adapter._create(i)},_getLabelSize:function(t){var e=this.options.ticks,n=this.ctx.measureText(t).width,i=V.toRadians(this.isHorizontal()?e.maxRotation:e.minRotation),a=Math.cos(i),r=Math.sin(i),o=$n(e.fontSize,z.global.defaultFontSize);return{w:n*a+o*r,h:n*r+o*a}},getLabelWidth:function(t){return this._getLabelSize(t).w},getLabelCapacity:function(t){var e=this,n=e.options.time,i=n.displayFormats,a=i[n.unit]||i.millisecond,r=e.tickFormatFunction(t,0,ui(e,[t],e._majorUnit),a),o=e._getLabelSize(r),s=Math.floor(e.isHorizontal()?e.width/o.w:e.height/o.h);return e.options.offset&&s--,s>0?s:1}}),hi={position:"bottom",distribution:"linear",bounds:"data",adapters:{},time:{parser:!1,unit:!1,round:!1,displayFormat:!1,isoWeekday:!1,minUnit:"millisecond",displayFormats:{}},ticks:{autoSkip:!1,source:"auto",major:{enabled:!1}}};di._defaults=hi;var ci={category:_n,linear:Dn,logarithmic:Rn,radialLinear:Gn,time:di},fi={datetime:"MMM D, YYYY, h:mm:ss a",millisecond:"h:mm:ss.SSS a",second:"h:mm:ss a",minute:"h:mm a",hour:"hA",day:"MMM D",week:"ll",month:"MMM YYYY",quarter:"[Q]Q - YYYY",year:"YYYY"};an._date.override("function"==typeof t?{_id:"moment",formats:function(){return fi},parse:function(e,n){return"string"==typeof e&&"string"==typeof n?e=t(e,n):e instanceof t||(e=t(e)),e.isValid()?e.valueOf():null},format:function(e,n){return t(e).format(n)},add:function(e,n,i){return t(e).add(n,i).valueOf()},diff:function(e,n,i){return t(e).diff(t(n),i)},startOf:function(e,n,i){return e=t(e),"isoWeek"===n?e.isoWeekday(i).valueOf():e.startOf(n).valueOf()},endOf:function(e,n){return t(e).endOf(n).valueOf()},_create:function(e){return t(e)}}:{}),z._set("global",{plugins:{filler:{propagate:!0}}});var gi={dataset:function(t){var e=t.fill,n=t.chart,i=n.getDatasetMeta(e),a=i&&n.isDatasetVisible(e)&&i.dataset._children||[],r=a.length||0;return r?function(t,e){return e<r&&a[e]._view||null}:null},boundary:function(t){var e=t.boundary,n=e?e.x:null,i=e?e.y:null;return V.isArray(e)?function(t,n){return e[n]}:function(t){return{x:null===n?t.x:n,y:null===i?t.y:i}}}};function pi(t,e,n){var i,a=t._model||{},r=a.fill;if(void 0===r&&(r=!!a.backgroundColor),!1===r||null===r)return!1;if(!0===r)return"origin";if(i=parseFloat(r,10),isFinite(i)&&Math.floor(i)===i)return"-"!==r[0]&&"+"!==r[0]||(i=e+i),!(i===e||i<0||i>=n)&&i;switch(r){case"bottom":return"start";case"top":return"end";case"zero":return"origin";case"origin":case"start":case"end":return r;default:return!1}}function mi(t){return(t.el._scale||{}).getPointPositionForValue?function(t){var e,n,i,a,r,o=t.el._scale,s=o.options,l=o.chart.data.labels.length,u=t.fill,d=[];if(!l)return null;for(e=s.ticks.reverse?o.max:o.min,n=s.ticks.reverse?o.min:o.max,i=o.getPointPositionForValue(0,e),a=0;a<l;++a)r="start"===u||"end"===u?o.getPointPositionForValue(a,"start"===u?e:n):o.getBasePosition(a),s.gridLines.circular&&(r.cx=i.x,r.cy=i.y,r.angle=o.getIndexAngle(a)-Math.PI/2),d.push(r);return d}(t):function(t){var e,n=t.el._model||{},i=t.el._scale||{},a=t.fill,r=null;if(isFinite(a))return null;if("start"===a?r=void 0===n.scaleBottom?i.bottom:n.scaleBottom:"end"===a?r=void 0===n.scaleTop?i.top:n.scaleTop:void 0!==n.scaleZero?r=n.scaleZero:i.getBasePixel&&(r=i.getBasePixel()),null!=r){if(void 0!==r.x&&void 0!==r.y)return r;if(V.isFinite(r))return{x:(e=i.isHorizontal())?r:null,y:e?null:r}}return null}(t)}function vi(t,e,n){var i,a=t[e].fill,r=[e];if(!n)return a;for(;!1!==a&&-1===r.indexOf(a);){if(!isFinite(a))return a;if(!(i=t[a]))return!1;if(i.visible)return a;r.push(a),a=i.fill}return!1}function bi(t){var e=t.fill,n="dataset";return!1===e?null:(isFinite(e)||(n="boundary"),gi[n](t))}function xi(t){return t&&!t.skip}function yi(t,e,n,i,a){var r,o,s,l;if(i&&a){for(t.moveTo(e[0].x,e[0].y),r=1;r<i;++r)V.canvas.lineTo(t,e[r-1],e[r]);if(void 0===n[0].angle)for(t.lineTo(n[a-1].x,n[a-1].y),r=a-1;r>0;--r)V.canvas.lineTo(t,n[r],n[r-1],!0);else for(o=n[0].cx,s=n[0].cy,l=Math.sqrt(Math.pow(n[0].x-o,2)+Math.pow(n[0].y-s,2)),r=a-1;r>0;--r)t.arc(o,s,l,n[r].angle,n[r-1].angle,!0)}}function _i(t,e,n,i,a,r){var o,s,l,u,d,h,c,f,g=e.length,p=i.spanGaps,m=[],v=[],b=0,x=0;for(t.beginPath(),o=0,s=g;o<s;++o)d=n(u=e[l=o%g]._view,l,i),h=xi(u),c=xi(d),r&&void 0===f&&h&&(s=g+(f=o+1)),h&&c?(b=m.push(u),x=v.push(d)):b&&x&&(p?(h&&m.push(u),c&&v.push(d)):(yi(t,m,v,b,x),b=x=0,m=[],v=[]));yi(t,m,v,b,x),t.closePath(),t.fillStyle=a,t.fill()}var ki={id:"filler",afterDatasetsUpdate:function(t,e){var n,i,a,r,o=(t.data.datasets||[]).length,s=e.propagate,l=[];for(i=0;i<o;++i)r=null,(a=(n=t.getDatasetMeta(i)).dataset)&&a._model&&a instanceof _t.Line&&(r={visible:t.isDatasetVisible(i),fill:pi(a,i,o),chart:t,el:a}),n.$filler=r,l.push(r);for(i=0;i<o;++i)(r=l[i])&&(r.fill=vi(l,i,s),r.boundary=mi(r),r.mapper=bi(r))},beforeDatasetsDraw:function(t){var e,n,i,a,r,o,s,l=t._getSortedVisibleDatasetMetas(),u=t.ctx;for(n=l.length-1;n>=0;--n)(e=l[n].$filler)&&e.visible&&(a=(i=e.el)._view,r=i._children||[],o=e.mapper,s=a.backgroundColor||z.global.defaultColor,o&&s&&r.length&&(V.canvas.clipArea(u,t.chartArea),_i(u,r,o,a,s,i._loop),V.canvas.unclipArea(u)))}},wi=V.rtl.getRtlAdapter,Mi=V.noop,Si=V.valueOrDefault;function Ci(t,e){return t.usePointStyle&&t.boxWidth>e?e:t.boxWidth}z._set("global",{legend:{display:!0,position:"top",align:"center",fullWidth:!0,reverse:!1,weight:1e3,onClick:function(t,e){var n=e.datasetIndex,i=this.chart,a=i.getDatasetMeta(n);a.hidden=null===a.hidden?!i.data.datasets[n].hidden:null,i.update()},onHover:null,onLeave:null,labels:{boxWidth:40,padding:10,generateLabels:function(t){var e=t.data.datasets,n=t.options.legend||{},i=n.labels&&n.labels.usePointStyle;return t._getSortedDatasetMetas().map((function(n){var a=n.controller.getStyle(i?0:void 0);return{text:e[n.index].label,fillStyle:a.backgroundColor,hidden:!t.isDatasetVisible(n.index),lineCap:a.borderCapStyle,lineDash:a.borderDash,lineDashOffset:a.borderDashOffset,lineJoin:a.borderJoinStyle,lineWidth:a.borderWidth,strokeStyle:a.borderColor,pointStyle:a.pointStyle,rotation:a.rotation,datasetIndex:n.index}}),this)}}},legendCallback:function(t){var e,n,i,a=document.createElement("ul"),r=t.data.datasets;for(a.setAttribute("class",t.id+"-legend"),e=0,n=r.length;e<n;e++)(i=a.appendChild(document.createElement("li"))).appendChild(document.createElement("span")).style.backgroundColor=r[e].backgroundColor,r[e].label&&i.appendChild(document.createTextNode(r[e].label));return a.outerHTML}});var Pi=X.extend({initialize:function(t){V.extend(this,t),this.legendHitBoxes=[],this._hoveredItem=null,this.doughnutMode=!1},beforeUpdate:Mi,update:function(t,e,n){var i=this;return i.beforeUpdate(),i.maxWidth=t,i.maxHeight=e,i.margins=n,i.beforeSetDimensions(),i.setDimensions(),i.afterSetDimensions(),i.beforeBuildLabels(),i.buildLabels(),i.afterBuildLabels(),i.beforeFit(),i.fit(),i.afterFit(),i.afterUpdate(),i.minSize},afterUpdate:Mi,beforeSetDimensions:Mi,setDimensions:function(){var t=this;t.isHorizontal()?(t.width=t.maxWidth,t.left=0,t.right=t.width):(t.height=t.maxHeight,t.top=0,t.bottom=t.height),t.paddingLeft=0,t.paddingTop=0,t.paddingRight=0,t.paddingBottom=0,t.minSize={width:0,height:0}},afterSetDimensions:Mi,beforeBuildLabels:Mi,buildLabels:function(){var t=this,e=t.options.labels||{},n=V.callback(e.generateLabels,[t.chart],t)||[];e.filter&&(n=n.filter((function(n){return e.filter(n,t.chart.data)}))),t.options.reverse&&n.reverse(),t.legendItems=n},afterBuildLabels:Mi,beforeFit:Mi,fit:function(){var t=this,e=t.options,n=e.labels,i=e.display,a=t.ctx,r=V.options._parseFont(n),o=r.size,s=t.legendHitBoxes=[],l=t.minSize,u=t.isHorizontal();if(u?(l.width=t.maxWidth,l.height=i?10:0):(l.width=i?10:0,l.height=t.maxHeight),i){if(a.font=r.string,u){var d=t.lineWidths=[0],h=0;a.textAlign="left",a.textBaseline="middle",V.each(t.legendItems,(function(t,e){var i=Ci(n,o)+o/2+a.measureText(t.text).width;(0===e||d[d.length-1]+i+2*n.padding>l.width)&&(h+=o+n.padding,d[d.length-(e>0?0:1)]=0),s[e]={left:0,top:0,width:i,height:o},d[d.length-1]+=i+n.padding})),l.height+=h}else{var c=n.padding,f=t.columnWidths=[],g=t.columnHeights=[],p=n.padding,m=0,v=0;V.each(t.legendItems,(function(t,e){var i=Ci(n,o)+o/2+a.measureText(t.text).width;e>0&&v+o+2*c>l.height&&(p+=m+n.padding,f.push(m),g.push(v),m=0,v=0),m=Math.max(m,i),v+=o+c,s[e]={left:0,top:0,width:i,height:o}})),p+=m,f.push(m),g.push(v),l.width+=p}t.width=l.width,t.height=l.height}else t.width=l.width=t.height=l.height=0},afterFit:Mi,isHorizontal:function(){return"top"===this.options.position||"bottom"===this.options.position},draw:function(){var t=this,e=t.options,n=e.labels,i=z.global,a=i.defaultColor,r=i.elements.line,o=t.height,s=t.columnHeights,l=t.width,u=t.lineWidths;if(e.display){var d,h=wi(e.rtl,t.left,t.minSize.width),c=t.ctx,f=Si(n.fontColor,i.defaultFontColor),g=V.options._parseFont(n),p=g.size;c.textAlign=h.textAlign("left"),c.textBaseline="middle",c.lineWidth=.5,c.strokeStyle=f,c.fillStyle=f,c.font=g.string;var m=Ci(n,p),v=t.legendHitBoxes,b=function(t,i){switch(e.align){case"start":return n.padding;case"end":return t-i;default:return(t-i+n.padding)/2}},x=t.isHorizontal();d=x?{x:t.left+b(l,u[0]),y:t.top+n.padding,line:0}:{x:t.left+n.padding,y:t.top+b(o,s[0]),line:0},V.rtl.overrideTextDirection(t.ctx,e.textDirection);var y=p+n.padding;V.each(t.legendItems,(function(e,i){var f=c.measureText(e.text).width,g=m+p/2+f,_=d.x,k=d.y;h.setWidth(t.minSize.width),x?i>0&&_+g+n.padding>t.left+t.minSize.width&&(k=d.y+=y,d.line++,_=d.x=t.left+b(l,u[d.line])):i>0&&k+y>t.top+t.minSize.height&&(_=d.x=_+t.columnWidths[d.line]+n.padding,d.line++,k=d.y=t.top+b(o,s[d.line]));var w=h.x(_);!function(t,e,i){if(!(isNaN(m)||m<=0)){c.save();var o=Si(i.lineWidth,r.borderWidth);if(c.fillStyle=Si(i.fillStyle,a),c.lineCap=Si(i.lineCap,r.borderCapStyle),c.lineDashOffset=Si(i.lineDashOffset,r.borderDashOffset),c.lineJoin=Si(i.lineJoin,r.borderJoinStyle),c.lineWidth=o,c.strokeStyle=Si(i.strokeStyle,a),c.setLineDash&&c.setLineDash(Si(i.lineDash,r.borderDash)),n&&n.usePointStyle){var s=m*Math.SQRT2/2,l=h.xPlus(t,m/2),u=e+p/2;V.canvas.drawPoint(c,i.pointStyle,s,l,u,i.rotation)}else c.fillRect(h.leftForLtr(t,m),e,m,p),0!==o&&c.strokeRect(h.leftForLtr(t,m),e,m,p);c.restore()}}(w,k,e),v[i].left=h.leftForLtr(w,v[i].width),v[i].top=k,function(t,e,n,i){var a=p/2,r=h.xPlus(t,m+a),o=e+a;c.fillText(n.text,r,o),n.hidden&&(c.beginPath(),c.lineWidth=2,c.moveTo(r,o),c.lineTo(h.xPlus(r,i),o),c.stroke())}(w,k,e,f),x?d.x+=g+n.padding:d.y+=y})),V.rtl.restoreTextDirection(t.ctx,e.textDirection)}},_getLegendItemAt:function(t,e){var n,i,a,r=this;if(t>=r.left&&t<=r.right&&e>=r.top&&e<=r.bottom)for(a=r.legendHitBoxes,n=0;n<a.length;++n)if(t>=(i=a[n]).left&&t<=i.left+i.width&&e>=i.top&&e<=i.top+i.height)return r.legendItems[n];return null},handleEvent:function(t){var e,n=this,i=n.options,a="mouseup"===t.type?"click":t.type;if("mousemove"===a){if(!i.onHover&&!i.onLeave)return}else{if("click"!==a)return;if(!i.onClick)return}e=n._getLegendItemAt(t.x,t.y),"click"===a?e&&i.onClick&&i.onClick.call(n,t.native,e):(i.onLeave&&e!==n._hoveredItem&&(n._hoveredItem&&i.onLeave.call(n,t.native,n._hoveredItem),n._hoveredItem=e),i.onHover&&e&&i.onHover.call(n,t.native,e))}});function Ai(t,e){var n=new Pi({ctx:t.ctx,options:e,chart:t});ge.configure(t,n,e),ge.addBox(t,n),t.legend=n}var Di={id:"legend",_element:Pi,beforeInit:function(t){var e=t.options.legend;e&&Ai(t,e)},beforeUpdate:function(t){var e=t.options.legend,n=t.legend;e?(V.mergeIf(e,z.global.legend),n?(ge.configure(t,n,e),n.options=e):Ai(t,e)):n&&(ge.removeBox(t,n),delete t.legend)},afterEvent:function(t,e){var n=t.legend;n&&n.handleEvent(e)}},Ti=V.noop;z._set("global",{title:{display:!1,fontStyle:"bold",fullWidth:!0,padding:10,position:"top",text:"",weight:2e3}});var Ii=X.extend({initialize:function(t){V.extend(this,t),this.legendHitBoxes=[]},beforeUpdate:Ti,update:function(t,e,n){var i=this;return i.beforeUpdate(),i.maxWidth=t,i.maxHeight=e,i.margins=n,i.beforeSetDimensions(),i.setDimensions(),i.afterSetDimensions(),i.beforeBuildLabels(),i.buildLabels(),i.afterBuildLabels(),i.beforeFit(),i.fit(),i.afterFit(),i.afterUpdate(),i.minSize},afterUpdate:Ti,beforeSetDimensions:Ti,setDimensions:function(){var t=this;t.isHorizontal()?(t.width=t.maxWidth,t.left=0,t.right=t.width):(t.height=t.maxHeight,t.top=0,t.bottom=t.height),t.paddingLeft=0,t.paddingTop=0,t.paddingRight=0,t.paddingBottom=0,t.minSize={width:0,height:0}},afterSetDimensions:Ti,beforeBuildLabels:Ti,buildLabels:Ti,afterBuildLabels:Ti,beforeFit:Ti,fit:function(){var t,e=this,n=e.options,i=e.minSize={},a=e.isHorizontal();n.display?(t=(V.isArray(n.text)?n.text.length:1)*V.options._parseFont(n).lineHeight+2*n.padding,e.width=i.width=a?e.maxWidth:t,e.height=i.height=a?t:e.maxHeight):e.width=i.width=e.height=i.height=0},afterFit:Ti,isHorizontal:function(){var t=this.options.position;return"top"===t||"bottom"===t},draw:function(){var t=this,e=t.ctx,n=t.options;if(n.display){var i,a,r,o=V.options._parseFont(n),s=o.lineHeight,l=s/2+n.padding,u=0,d=t.top,h=t.left,c=t.bottom,f=t.right;e.fillStyle=V.valueOrDefault(n.fontColor,z.global.defaultFontColor),e.font=o.string,t.isHorizontal()?(a=h+(f-h)/2,r=d+l,i=f-h):(a="left"===n.position?h+l:f-l,r=d+(c-d)/2,i=c-d,u=Math.PI*("left"===n.position?-.5:.5)),e.save(),e.translate(a,r),e.rotate(u),e.textAlign="center",e.textBaseline="middle";var g=n.text;if(V.isArray(g))for(var p=0,m=0;m<g.length;++m)e.fillText(g[m],0,p,i),p+=s;else e.fillText(g,0,0,i);e.restore()}}});function Fi(t,e){var n=new Ii({ctx:t.ctx,options:e,chart:t});ge.configure(t,n,e),ge.addBox(t,n),t.titleBlock=n}var Li={},Oi=ki,Ri=Di,zi={id:"title",_element:Ii,beforeInit:function(t){var e=t.options.title;e&&Fi(t,e)},beforeUpdate:function(t){var e=t.options.title,n=t.titleBlock;e?(V.mergeIf(e,z.global.title),n?(ge.configure(t,n,e),n.options=e):Fi(t,e)):n&&(ge.removeBox(t,n),delete t.titleBlock)}};for(var Ni in Li.filler=Oi,Li.legend=Ri,Li.title=zi,tn.helpers=V,function(){function t(t,e,n){var i;return"string"==typeof t?(i=parseInt(t,10),-1!==t.indexOf("%")&&(i=i/100*e.parentNode[n])):i=t,i}function e(t){return null!=t&&"none"!==t}function n(n,i,a){var r=document.defaultView,o=V._getParentNode(n),s=r.getComputedStyle(n)[i],l=r.getComputedStyle(o)[i],u=e(s),d=e(l),h=Number.POSITIVE_INFINITY;return u||d?Math.min(u?t(s,n,a):h,d?t(l,o,a):h):"none"}V.where=function(t,e){if(V.isArray(t)&&Array.prototype.filter)return t.filter(e);var n=[];return V.each(t,(function(t){e(t)&&n.push(t)})),n},V.findIndex=Array.prototype.findIndex?function(t,e,n){return t.findIndex(e,n)}:function(t,e,n){n=void 0===n?t:n;for(var i=0,a=t.length;i<a;++i)if(e.call(n,t[i],i,t))return i;return-1},V.findNextWhere=function(t,e,n){V.isNullOrUndef(n)&&(n=-1);for(var i=n+1;i<t.length;i++){var a=t[i];if(e(a))return a}},V.findPreviousWhere=function(t,e,n){V.isNullOrUndef(n)&&(n=t.length);for(var i=n-1;i>=0;i--){var a=t[i];if(e(a))return a}},V.isNumber=function(t){return!isNaN(parseFloat(t))&&isFinite(t)},V.almostEquals=function(t,e,n){return Math.abs(t-e)<n},V.almostWhole=function(t,e){var n=Math.round(t);return n-e<=t&&n+e>=t},V.max=function(t){return t.reduce((function(t,e){return isNaN(e)?t:Math.max(t,e)}),Number.NEGATIVE_INFINITY)},V.min=function(t){return t.reduce((function(t,e){return isNaN(e)?t:Math.min(t,e)}),Number.POSITIVE_INFINITY)},V.sign=Math.sign?function(t){return Math.sign(t)}:function(t){return 0===(t=+t)||isNaN(t)?t:t>0?1:-1},V.toRadians=function(t){return t*(Math.PI/180)},V.toDegrees=function(t){return t*(180/Math.PI)},V._decimalPlaces=function(t){if(V.isFinite(t)){for(var e=1,n=0;Math.round(t*e)/e!==t;)e*=10,n++;return n}},V.getAngleFromPoint=function(t,e){var n=e.x-t.x,i=e.y-t.y,a=Math.sqrt(n*n+i*i),r=Math.atan2(i,n);return r<-.5*Math.PI&&(r+=2*Math.PI),{angle:r,distance:a}},V.distanceBetweenPoints=function(t,e){return Math.sqrt(Math.pow(e.x-t.x,2)+Math.pow(e.y-t.y,2))},V.aliasPixel=function(t){return t%2==0?0:.5},V._alignPixel=function(t,e,n){var i=t.currentDevicePixelRatio,a=n/2;return Math.round((e-a)*i)/i+a},V.splineCurve=function(t,e,n,i){var a=t.skip?e:t,r=e,o=n.skip?e:n,s=Math.sqrt(Math.pow(r.x-a.x,2)+Math.pow(r.y-a.y,2)),l=Math.sqrt(Math.pow(o.x-r.x,2)+Math.pow(o.y-r.y,2)),u=s/(s+l),d=l/(s+l),h=i*(u=isNaN(u)?0:u),c=i*(d=isNaN(d)?0:d);return{previous:{x:r.x-h*(o.x-a.x),y:r.y-h*(o.y-a.y)},next:{x:r.x+c*(o.x-a.x),y:r.y+c*(o.y-a.y)}}},V.EPSILON=Number.EPSILON||1e-14,V.splineCurveMonotone=function(t){var e,n,i,a,r,o,s,l,u,d=(t||[]).map((function(t){return{model:t._model,deltaK:0,mK:0}})),h=d.length;for(e=0;e<h;++e)if(!(i=d[e]).model.skip){if(n=e>0?d[e-1]:null,(a=e<h-1?d[e+1]:null)&&!a.model.skip){var c=a.model.x-i.model.x;i.deltaK=0!==c?(a.model.y-i.model.y)/c:0}!n||n.model.skip?i.mK=i.deltaK:!a||a.model.skip?i.mK=n.deltaK:this.sign(n.deltaK)!==this.sign(i.deltaK)?i.mK=0:i.mK=(n.deltaK+i.deltaK)/2}for(e=0;e<h-1;++e)i=d[e],a=d[e+1],i.model.skip||a.model.skip||(V.almostEquals(i.deltaK,0,this.EPSILON)?i.mK=a.mK=0:(r=i.mK/i.deltaK,o=a.mK/i.deltaK,(l=Math.pow(r,2)+Math.pow(o,2))<=9||(s=3/Math.sqrt(l),i.mK=r*s*i.deltaK,a.mK=o*s*i.deltaK)));for(e=0;e<h;++e)(i=d[e]).model.skip||(n=e>0?d[e-1]:null,a=e<h-1?d[e+1]:null,n&&!n.model.skip&&(u=(i.model.x-n.model.x)/3,i.model.controlPointPreviousX=i.model.x-u,i.model.controlPointPreviousY=i.model.y-u*i.mK),a&&!a.model.skip&&(u=(a.model.x-i.model.x)/3,i.model.controlPointNextX=i.model.x+u,i.model.controlPointNextY=i.model.y+u*i.mK))},V.nextItem=function(t,e,n){return n?e>=t.length-1?t[0]:t[e+1]:e>=t.length-1?t[t.length-1]:t[e+1]},V.previousItem=function(t,e,n){return n?e<=0?t[t.length-1]:t[e-1]:e<=0?t[0]:t[e-1]},V.niceNum=function(t,e){var n=Math.floor(V.log10(t)),i=t/Math.pow(10,n);return(e?i<1.5?1:i<3?2:i<7?5:10:i<=1?1:i<=2?2:i<=5?5:10)*Math.pow(10,n)},V.requestAnimFrame="undefined"==typeof window?function(t){t()}:window.requestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimationFrame||window.msRequestAnimationFrame||function(t){return window.setTimeout(t,1e3/60)},V.getRelativePosition=function(t,e){var n,i,a=t.originalEvent||t,r=t.target||t.srcElement,o=r.getBoundingClientRect(),s=a.touches;s&&s.length>0?(n=s[0].clientX,i=s[0].clientY):(n=a.clientX,i=a.clientY);var l=parseFloat(V.getStyle(r,"padding-left")),u=parseFloat(V.getStyle(r,"padding-top")),d=parseFloat(V.getStyle(r,"padding-right")),h=parseFloat(V.getStyle(r,"padding-bottom")),c=o.right-o.left-l-d,f=o.bottom-o.top-u-h;return{x:n=Math.round((n-o.left-l)/c*r.width/e.currentDevicePixelRatio),y:i=Math.round((i-o.top-u)/f*r.height/e.currentDevicePixelRatio)}},V.getConstraintWidth=function(t){return n(t,"max-width","clientWidth")},V.getConstraintHeight=function(t){return n(t,"max-height","clientHeight")},V._calculatePadding=function(t,e,n){return(e=V.getStyle(t,e)||"0").indexOf("%")>-1?n*parseInt(e,10)/100:parseInt(e,10)},V._getParentNode=function(t){var e=t.parentNode;return e&&"[object ShadowRoot]"===e.toString()&&(e=e.host),e},V.getMaximumWidth=function(t){var e=V._getParentNode(t);if(!e)return t.clientWidth;var n=e.clientWidth,i=n-V._calculatePadding(e,"padding-left",n)-V._calculatePadding(e,"padding-right",n),a=V.getConstraintWidth(t);return isNaN(a)?i:Math.min(i,a)},V.getMaximumHeight=function(t){var e=V._getParentNode(t);if(!e)return t.clientHeight;var n=e.clientHeight,i=n-V._calculatePadding(e,"padding-top",n)-V._calculatePadding(e,"padding-bottom",n),a=V.getConstraintHeight(t);return isNaN(a)?i:Math.min(i,a)},V.getStyle=function(t,e){return t.currentStyle?t.currentStyle[e]:document.defaultView.getComputedStyle(t,null).getPropertyValue(e)},V.retinaScale=function(t,e){var n=t.currentDevicePixelRatio=e||"undefined"!=typeof window&&window.devicePixelRatio||1;if(1!==n){var i=t.canvas,a=t.height,r=t.width;i.height=a*n,i.width=r*n,t.ctx.scale(n,n),i.style.height||i.style.width||(i.style.height=a+"px",i.style.width=r+"px")}},V.fontString=function(t,e,n){return e+" "+t+"px "+n},V.longestText=function(t,e,n,i){var a=(i=i||{}).data=i.data||{},r=i.garbageCollect=i.garbageCollect||[];i.font!==e&&(a=i.data={},r=i.garbageCollect=[],i.font=e),t.font=e;var o,s,l,u,d,h=0,c=n.length;for(o=0;o<c;o++)if(null!=(u=n[o])&&!0!==V.isArray(u))h=V.measureText(t,a,r,h,u);else if(V.isArray(u))for(s=0,l=u.length;s<l;s++)null==(d=u[s])||V.isArray(d)||(h=V.measureText(t,a,r,h,d));var f=r.length/2;if(f>n.length){for(o=0;o<f;o++)delete a[r[o]];r.splice(0,f)}return h},V.measureText=function(t,e,n,i,a){var r=e[a];return r||(r=e[a]=t.measureText(a).width,n.push(a)),r>i&&(i=r),i},V.numberOfLabelLines=function(t){var e=1;return V.each(t,(function(t){V.isArray(t)&&t.length>e&&(e=t.length)})),e},V.color=k?function(t){return t instanceof CanvasGradient&&(t=z.global.defaultColor),k(t)}:function(t){return console.error("Color.js not found!"),t},V.getHoverColor=function(t){return t instanceof CanvasPattern||t instanceof CanvasGradient?t:V.color(t).saturate(.5).darken(.1).rgbString()}}(),tn._adapters=an,tn.Animation=Z,tn.animationService=$,tn.controllers=$t,tn.DatasetController=nt,tn.defaults=z,tn.Element=X,tn.elements=_t,tn.Interaction=ae,tn.layouts=ge,tn.platform=Fe,tn.plugins=Le,tn.Scale=xn,tn.scaleService=Oe,tn.Ticks=rn,tn.Tooltip=Ue,tn.helpers.each(ci,(function(t,e){tn.scaleService.registerScaleType(e,t,t._defaults)})),Li)Li.hasOwnProperty(Ni)&&tn.plugins.register(Li[Ni]);tn.platform.initialize();var Bi=tn;return"undefined"!=typeof window&&(window.Chart=tn),tn.Chart=tn,tn.Legend=Li.legend._element,tn.Title=Li.title._element,tn.pluginService=tn.plugins,tn.PluginBase=tn.Element.extend({}),tn.canvasHelpers=tn.helpers.canvas,tn.layoutService=tn.layouts,tn.LinearScaleBase=Sn,tn.helpers.each(["Bar","Bubble","Doughnut","Line","PolarArea","Radar","Scatter"],(function(t){tn[t]=function(e,n){return new tn(e,tn.helpers.merge(n||{},{type:t.charAt(0).toLowerCase()+t.slice(1)}))}})),Bi}));

@@ -1,9554 +0,0 @@ 

- !function() {

-   var d3 = {

-     version: "3.5.17"

-   };

-   var d3_arraySlice = [].slice, d3_array = function(list) {

-     return d3_arraySlice.call(list);

-   };

-   var d3_document = this.document;

-   function d3_documentElement(node) {

-     return node && (node.ownerDocument || node.document || node).documentElement;

-   }

-   function d3_window(node) {

-     return node && (node.ownerDocument && node.ownerDocument.defaultView || node.document && node || node.defaultView);

-   }

-   if (d3_document) {

-     try {

-       d3_array(d3_document.documentElement.childNodes)[0].nodeType;

-     } catch (e) {

-       d3_array = function(list) {

-         var i = list.length, array = new Array(i);

-         while (i--) array[i] = list[i];

-         return array;

-       };

-     }

-   }

-   if (!Date.now) Date.now = function() {

-     return +new Date();

-   };

-   if (d3_document) {

-     try {

-       d3_document.createElement("DIV").style.setProperty("opacity", 0, "");

-     } catch (error) {

-       var d3_element_prototype = this.Element.prototype, d3_element_setAttribute = d3_element_prototype.setAttribute, d3_element_setAttributeNS = d3_element_prototype.setAttributeNS, d3_style_prototype = this.CSSStyleDeclaration.prototype, d3_style_setProperty = d3_style_prototype.setProperty;

-       d3_element_prototype.setAttribute = function(name, value) {

-         d3_element_setAttribute.call(this, name, value + "");

-       };

-       d3_element_prototype.setAttributeNS = function(space, local, value) {

-         d3_element_setAttributeNS.call(this, space, local, value + "");

-       };

-       d3_style_prototype.setProperty = function(name, value, priority) {

-         d3_style_setProperty.call(this, name, value + "", priority);

-       };

-     }

-   }

-   d3.ascending = d3_ascending;

-   function d3_ascending(a, b) {

-     return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;

-   }

-   d3.descending = function(a, b) {

-     return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;

-   };

-   d3.min = function(array, f) {

-     var i = -1, n = array.length, a, b;

-     if (arguments.length === 1) {

-       while (++i < n) if ((b = array[i]) != null && b >= b) {

-         a = b;

-         break;

-       }

-       while (++i < n) if ((b = array[i]) != null && a > b) a = b;

-     } else {

-       while (++i < n) if ((b = f.call(array, array[i], i)) != null && b >= b) {

-         a = b;

-         break;

-       }

-       while (++i < n) if ((b = f.call(array, array[i], i)) != null && a > b) a = b;

-     }

-     return a;

-   };

-   d3.max = function(array, f) {

-     var i = -1, n = array.length, a, b;

-     if (arguments.length === 1) {

-       while (++i < n) if ((b = array[i]) != null && b >= b) {

-         a = b;

-         break;

-       }

-       while (++i < n) if ((b = array[i]) != null && b > a) a = b;

-     } else {

-       while (++i < n) if ((b = f.call(array, array[i], i)) != null && b >= b) {

-         a = b;

-         break;

-       }

-       while (++i < n) if ((b = f.call(array, array[i], i)) != null && b > a) a = b;

-     }

-     return a;

-   };

-   d3.extent = function(array, f) {

-     var i = -1, n = array.length, a, b, c;

-     if (arguments.length === 1) {

-       while (++i < n) if ((b = array[i]) != null && b >= b) {

-         a = c = b;

-         break;

-       }

-       while (++i < n) if ((b = array[i]) != null) {

-         if (a > b) a = b;

-         if (c < b) c = b;

-       }

-     } else {

-       while (++i < n) if ((b = f.call(array, array[i], i)) != null && b >= b) {

-         a = c = b;

-         break;

-       }

-       while (++i < n) if ((b = f.call(array, array[i], i)) != null) {

-         if (a > b) a = b;

-         if (c < b) c = b;

-       }

-     }

-     return [ a, c ];

-   };

-   function d3_number(x) {

-     return x === null ? NaN : +x;

-   }

-   function d3_numeric(x) {

-     return !isNaN(x);

-   }

-   d3.sum = function(array, f) {

-     var s = 0, n = array.length, a, i = -1;

-     if (arguments.length === 1) {

-       while (++i < n) if (d3_numeric(a = +array[i])) s += a;

-     } else {

-       while (++i < n) if (d3_numeric(a = +f.call(array, array[i], i))) s += a;

-     }

-     return s;

-   };

-   d3.mean = function(array, f) {

-     var s = 0, n = array.length, a, i = -1, j = n;

-     if (arguments.length === 1) {

-       while (++i < n) if (d3_numeric(a = d3_number(array[i]))) s += a; else --j;

-     } else {

-       while (++i < n) if (d3_numeric(a = d3_number(f.call(array, array[i], i)))) s += a; else --j;

-     }

-     if (j) return s / j;

-   };

-   d3.quantile = function(values, p) {

-     var H = (values.length - 1) * p + 1, h = Math.floor(H), v = +values[h - 1], e = H - h;

-     return e ? v + e * (values[h] - v) : v;

-   };

-   d3.median = function(array, f) {

-     var numbers = [], n = array.length, a, i = -1;

-     if (arguments.length === 1) {

-       while (++i < n) if (d3_numeric(a = d3_number(array[i]))) numbers.push(a);

-     } else {

-       while (++i < n) if (d3_numeric(a = d3_number(f.call(array, array[i], i)))) numbers.push(a);

-     }

-     if (numbers.length) return d3.quantile(numbers.sort(d3_ascending), .5);

-   };

-   d3.variance = function(array, f) {

-     var n = array.length, m = 0, a, d, s = 0, i = -1, j = 0;

-     if (arguments.length === 1) {

-       while (++i < n) {

-         if (d3_numeric(a = d3_number(array[i]))) {

-           d = a - m;

-           m += d / ++j;

-           s += d * (a - m);

-         }

-       }

-     } else {

-       while (++i < n) {

-         if (d3_numeric(a = d3_number(f.call(array, array[i], i)))) {

-           d = a - m;

-           m += d / ++j;

-           s += d * (a - m);

-         }

-       }

-     }

-     if (j > 1) return s / (j - 1);

-   };

-   d3.deviation = function() {

-     var v = d3.variance.apply(this, arguments);

-     return v ? Math.sqrt(v) : v;

-   };

-   function d3_bisector(compare) {

-     return {

-       left: function(a, x, lo, hi) {

-         if (arguments.length < 3) lo = 0;

-         if (arguments.length < 4) hi = a.length;

-         while (lo < hi) {

-           var mid = lo + hi >>> 1;

-           if (compare(a[mid], x) < 0) lo = mid + 1; else hi = mid;

-         }

-         return lo;

-       },

-       right: function(a, x, lo, hi) {

-         if (arguments.length < 3) lo = 0;

-         if (arguments.length < 4) hi = a.length;

-         while (lo < hi) {

-           var mid = lo + hi >>> 1;

-           if (compare(a[mid], x) > 0) hi = mid; else lo = mid + 1;

-         }

-         return lo;

-       }

-     };

-   }

-   var d3_bisect = d3_bisector(d3_ascending);

-   d3.bisectLeft = d3_bisect.left;

-   d3.bisect = d3.bisectRight = d3_bisect.right;

-   d3.bisector = function(f) {

-     return d3_bisector(f.length === 1 ? function(d, x) {

-       return d3_ascending(f(d), x);

-     } : f);

-   };

-   d3.shuffle = function(array, i0, i1) {

-     if ((m = arguments.length) < 3) {

-       i1 = array.length;

-       if (m < 2) i0 = 0;

-     }

-     var m = i1 - i0, t, i;

-     while (m) {

-       i = Math.random() * m-- | 0;

-       t = array[m + i0], array[m + i0] = array[i + i0], array[i + i0] = t;

-     }

-     return array;

-   };

-   d3.permute = function(array, indexes) {

-     var i = indexes.length, permutes = new Array(i);

-     while (i--) permutes[i] = array[indexes[i]];

-     return permutes;

-   };

-   d3.pairs = function(array) {

-     var i = 0, n = array.length - 1, p0, p1 = array[0], pairs = new Array(n < 0 ? 0 : n);

-     while (i < n) pairs[i] = [ p0 = p1, p1 = array[++i] ];

-     return pairs;

-   };

-   d3.transpose = function(matrix) {

-     if (!(n = matrix.length)) return [];

-     for (var i = -1, m = d3.min(matrix, d3_transposeLength), transpose = new Array(m); ++i < m; ) {

-       for (var j = -1, n, row = transpose[i] = new Array(n); ++j < n; ) {

-         row[j] = matrix[j][i];

-       }

-     }

-     return transpose;

-   };

-   function d3_transposeLength(d) {

-     return d.length;

-   }

-   d3.zip = function() {

-     return d3.transpose(arguments);

-   };

-   d3.keys = function(map) {

-     var keys = [];

-     for (var key in map) keys.push(key);

-     return keys;

-   };

-   d3.values = function(map) {

-     var values = [];

-     for (var key in map) values.push(map[key]);

-     return values;

-   };

-   d3.entries = function(map) {

-     var entries = [];

-     for (var key in map) entries.push({

-       key: key,

-       value: map[key]

-     });

-     return entries;

-   };

-   d3.merge = function(arrays) {

-     var n = arrays.length, m, i = -1, j = 0, merged, array;

-     while (++i < n) j += arrays[i].length;

-     merged = new Array(j);

-     while (--n >= 0) {

-       array = arrays[n];

-       m = array.length;

-       while (--m >= 0) {

-         merged[--j] = array[m];

-       }

-     }

-     return merged;

-   };

-   var abs = Math.abs;

-   d3.range = function(start, stop, step) {

-     if (arguments.length < 3) {

-       step = 1;

-       if (arguments.length < 2) {

-         stop = start;

-         start = 0;

-       }

-     }

-     if ((stop - start) / step === Infinity) throw new Error("infinite range");

-     var range = [], k = d3_range_integerScale(abs(step)), i = -1, j;

-     start *= k, stop *= k, step *= k;

-     if (step < 0) while ((j = start + step * ++i) > stop) range.push(j / k); else while ((j = start + step * ++i) < stop) range.push(j / k);

-     return range;

-   };

-   function d3_range_integerScale(x) {

-     var k = 1;

-     while (x * k % 1) k *= 10;

-     return k;

-   }

-   function d3_class(ctor, properties) {

-     for (var key in properties) {

-       Object.defineProperty(ctor.prototype, key, {

-         value: properties[key],

-         enumerable: false

-       });

-     }

-   }

-   d3.map = function(object, f) {

-     var map = new d3_Map();

-     if (object instanceof d3_Map) {

-       object.forEach(function(key, value) {

-         map.set(key, value);

-       });

-     } else if (Array.isArray(object)) {

-       var i = -1, n = object.length, o;

-       if (arguments.length === 1) while (++i < n) map.set(i, object[i]); else while (++i < n) map.set(f.call(object, o = object[i], i), o);

-     } else {

-       for (var key in object) map.set(key, object[key]);

-     }

-     return map;

-   };

-   function d3_Map() {

-     this._ = Object.create(null);

-   }

-   var d3_map_proto = "__proto__", d3_map_zero = "\x00";

-   d3_class(d3_Map, {

-     has: d3_map_has,

-     get: function(key) {

-       return this._[d3_map_escape(key)];

-     },

-     set: function(key, value) {

-       return this._[d3_map_escape(key)] = value;

-     },

-     remove: d3_map_remove,

-     keys: d3_map_keys,

-     values: function() {

-       var values = [];

-       for (var key in this._) values.push(this._[key]);

-       return values;

-     },

-     entries: function() {

-       var entries = [];

-       for (var key in this._) entries.push({

-         key: d3_map_unescape(key),

-         value: this._[key]

-       });

-       return entries;

-     },

-     size: d3_map_size,

-     empty: d3_map_empty,

-     forEach: function(f) {

-       for (var key in this._) f.call(this, d3_map_unescape(key), this._[key]);

-     }

-   });

-   function d3_map_escape(key) {

-     return (key += "") === d3_map_proto || key[0] === d3_map_zero ? d3_map_zero + key : key;

-   }

-   function d3_map_unescape(key) {

-     return (key += "")[0] === d3_map_zero ? key.slice(1) : key;

-   }

-   function d3_map_has(key) {

-     return d3_map_escape(key) in this._;

-   }

-   function d3_map_remove(key) {

-     return (key = d3_map_escape(key)) in this._ && delete this._[key];

-   }

-   function d3_map_keys() {

-     var keys = [];

-     for (var key in this._) keys.push(d3_map_unescape(key));

-     return keys;

-   }

-   function d3_map_size() {

-     var size = 0;

-     for (var key in this._) ++size;

-     return size;

-   }

-   function d3_map_empty() {

-     for (var key in this._) return false;

-     return true;

-   }

-   d3.nest = function() {

-     var nest = {}, keys = [], sortKeys = [], sortValues, rollup;

-     function map(mapType, array, depth) {

-       if (depth >= keys.length) return rollup ? rollup.call(nest, array) : sortValues ? array.sort(sortValues) : array;

-       var i = -1, n = array.length, key = keys[depth++], keyValue, object, setter, valuesByKey = new d3_Map(), values;

-       while (++i < n) {

-         if (values = valuesByKey.get(keyValue = key(object = array[i]))) {

-           values.push(object);

-         } else {

-           valuesByKey.set(keyValue, [ object ]);

-         }

-       }

-       if (mapType) {

-         object = mapType();

-         setter = function(keyValue, values) {

-           object.set(keyValue, map(mapType, values, depth));

-         };

-       } else {

-         object = {};

-         setter = function(keyValue, values) {

-           object[keyValue] = map(mapType, values, depth);

-         };

-       }

-       valuesByKey.forEach(setter);

-       return object;

-     }

-     function entries(map, depth) {

-       if (depth >= keys.length) return map;

-       var array = [], sortKey = sortKeys[depth++];

-       map.forEach(function(key, keyMap) {

-         array.push({

-           key: key,

-           values: entries(keyMap, depth)

-         });

-       });

-       return sortKey ? array.sort(function(a, b) {

-         return sortKey(a.key, b.key);

-       }) : array;

-     }

-     nest.map = function(array, mapType) {

-       return map(mapType, array, 0);

-     };

-     nest.entries = function(array) {

-       return entries(map(d3.map, array, 0), 0);

-     };

-     nest.key = function(d) {

-       keys.push(d);

-       return nest;

-     };

-     nest.sortKeys = function(order) {

-       sortKeys[keys.length - 1] = order;

-       return nest;

-     };

-     nest.sortValues = function(order) {

-       sortValues = order;

-       return nest;

-     };

-     nest.rollup = function(f) {

-       rollup = f;

-       return nest;

-     };

-     return nest;

-   };

-   d3.set = function(array) {

-     var set = new d3_Set();

-     if (array) for (var i = 0, n = array.length; i < n; ++i) set.add(array[i]);

-     return set;

-   };

-   function d3_Set() {

-     this._ = Object.create(null);

-   }

-   d3_class(d3_Set, {

-     has: d3_map_has,

-     add: function(key) {

-       this._[d3_map_escape(key += "")] = true;

-       return key;

-     },

-     remove: d3_map_remove,

-     values: d3_map_keys,

-     size: d3_map_size,

-     empty: d3_map_empty,

-     forEach: function(f) {

-       for (var key in this._) f.call(this, d3_map_unescape(key));

-     }

-   });

-   d3.behavior = {};

-   function d3_identity(d) {

-     return d;

-   }

-   d3.rebind = function(target, source) {

-     var i = 1, n = arguments.length, method;

-     while (++i < n) target[method = arguments[i]] = d3_rebind(target, source, source[method]);

-     return target;

-   };

-   function d3_rebind(target, source, method) {

-     return function() {

-       var value = method.apply(source, arguments);

-       return value === source ? target : value;

-     };

-   }

-   function d3_vendorSymbol(object, name) {

-     if (name in object) return name;

-     name = name.charAt(0).toUpperCase() + name.slice(1);

-     for (var i = 0, n = d3_vendorPrefixes.length; i < n; ++i) {

-       var prefixName = d3_vendorPrefixes[i] + name;

-       if (prefixName in object) return prefixName;

-     }

-   }

-   var d3_vendorPrefixes = [ "webkit", "ms", "moz", "Moz", "o", "O" ];

-   function d3_noop() {}

-   d3.dispatch = function() {

-     var dispatch = new d3_dispatch(), i = -1, n = arguments.length;

-     while (++i < n) dispatch[arguments[i]] = d3_dispatch_event(dispatch);

-     return dispatch;

-   };

-   function d3_dispatch() {}

-   d3_dispatch.prototype.on = function(type, listener) {

-     var i = type.indexOf("."), name = "";

-     if (i >= 0) {

-       name = type.slice(i + 1);

-       type = type.slice(0, i);

-     }

-     if (type) return arguments.length < 2 ? this[type].on(name) : this[type].on(name, listener);

-     if (arguments.length === 2) {

-       if (listener == null) for (type in this) {

-         if (this.hasOwnProperty(type)) this[type].on(name, null);

-       }

-       return this;

-     }

-   };

-   function d3_dispatch_event(dispatch) {

-     var listeners = [], listenerByName = new d3_Map();

-     function event() {

-       var z = listeners, i = -1, n = z.length, l;

-       while (++i < n) if (l = z[i].on) l.apply(this, arguments);

-       return dispatch;

-     }

-     event.on = function(name, listener) {

-       var l = listenerByName.get(name), i;

-       if (arguments.length < 2) return l && l.on;

-       if (l) {

-         l.on = null;

-         listeners = listeners.slice(0, i = listeners.indexOf(l)).concat(listeners.slice(i + 1));

-         listenerByName.remove(name);

-       }

-       if (listener) listeners.push(listenerByName.set(name, {

-         on: listener

-       }));

-       return dispatch;

-     };

-     return event;

-   }

-   d3.event = null;

-   function d3_eventPreventDefault() {

-     d3.event.preventDefault();

-   }

-   function d3_eventSource() {

-     var e = d3.event, s;

-     while (s = e.sourceEvent) e = s;

-     return e;

-   }

-   function d3_eventDispatch(target) {

-     var dispatch = new d3_dispatch(), i = 0, n = arguments.length;

-     while (++i < n) dispatch[arguments[i]] = d3_dispatch_event(dispatch);

-     dispatch.of = function(thiz, argumentz) {

-       return function(e1) {

-         try {

-           var e0 = e1.sourceEvent = d3.event;

-           e1.target = target;

-           d3.event = e1;

-           dispatch[e1.type].apply(thiz, argumentz);

-         } finally {

-           d3.event = e0;

-         }

-       };

-     };

-     return dispatch;

-   }

-   d3.requote = function(s) {

-     return s.replace(d3_requote_re, "\\$&");

-   };

-   var d3_requote_re = /[\\\^\$\*\+\?\|\[\]\(\)\.\{\}]/g;

-   var d3_subclass = {}.__proto__ ? function(object, prototype) {

-     object.__proto__ = prototype;

-   } : function(object, prototype) {

-     for (var property in prototype) object[property] = prototype[property];

-   };

-   function d3_selection(groups) {

-     d3_subclass(groups, d3_selectionPrototype);

-     return groups;

-   }

-   var d3_select = function(s, n) {

-     return n.querySelector(s);

-   }, d3_selectAll = function(s, n) {

-     return n.querySelectorAll(s);

-   }, d3_selectMatches = function(n, s) {

-     var d3_selectMatcher = n.matches || n[d3_vendorSymbol(n, "matchesSelector")];

-     d3_selectMatches = function(n, s) {

-       return d3_selectMatcher.call(n, s);

-     };

-     return d3_selectMatches(n, s);

-   };

-   if (typeof Sizzle === "function") {

-     d3_select = function(s, n) {

-       return Sizzle(s, n)[0] || null;

-     };

-     d3_selectAll = Sizzle;

-     d3_selectMatches = Sizzle.matchesSelector;

-   }

-   d3.selection = function() {

-     return d3.select(d3_document.documentElement);

-   };

-   var d3_selectionPrototype = d3.selection.prototype = [];

-   d3_selectionPrototype.select = function(selector) {

-     var subgroups = [], subgroup, subnode, group, node;

-     selector = d3_selection_selector(selector);

-     for (var j = -1, m = this.length; ++j < m; ) {

-       subgroups.push(subgroup = []);

-       subgroup.parentNode = (group = this[j]).parentNode;

-       for (var i = -1, n = group.length; ++i < n; ) {

-         if (node = group[i]) {

-           subgroup.push(subnode = selector.call(node, node.__data__, i, j));

-           if (subnode && "__data__" in node) subnode.__data__ = node.__data__;

-         } else {

-           subgroup.push(null);

-         }

-       }

-     }

-     return d3_selection(subgroups);

-   };

-   function d3_selection_selector(selector) {

-     return typeof selector === "function" ? selector : function() {

-       return d3_select(selector, this);

-     };

-   }

-   d3_selectionPrototype.selectAll = function(selector) {

-     var subgroups = [], subgroup, node;

-     selector = d3_selection_selectorAll(selector);

-     for (var j = -1, m = this.length; ++j < m; ) {

-       for (var group = this[j], i = -1, n = group.length; ++i < n; ) {

-         if (node = group[i]) {

-           subgroups.push(subgroup = d3_array(selector.call(node, node.__data__, i, j)));

-           subgroup.parentNode = node;

-         }

-       }

-     }

-     return d3_selection(subgroups);

-   };

-   function d3_selection_selectorAll(selector) {

-     return typeof selector === "function" ? selector : function() {

-       return d3_selectAll(selector, this);

-     };

-   }

-   var d3_nsXhtml = "http://www.w3.org/1999/xhtml";

-   var d3_nsPrefix = {

-     svg: "http://www.w3.org/2000/svg",

-     xhtml: d3_nsXhtml,

-     xlink: "http://www.w3.org/1999/xlink",

-     xml: "http://www.w3.org/XML/1998/namespace",

-     xmlns: "http://www.w3.org/2000/xmlns/"

-   };

-   d3.ns = {

-     prefix: d3_nsPrefix,

-     qualify: function(name) {

-       var i = name.indexOf(":"), prefix = name;

-       if (i >= 0 && (prefix = name.slice(0, i)) !== "xmlns") name = name.slice(i + 1);

-       return d3_nsPrefix.hasOwnProperty(prefix) ? {

-         space: d3_nsPrefix[prefix],

-         local: name

-       } : name;

-     }

-   };

-   d3_selectionPrototype.attr = function(name, value) {

-     if (arguments.length < 2) {

-       if (typeof name === "string") {

-         var node = this.node();

-         name = d3.ns.qualify(name);

-         return name.local ? node.getAttributeNS(name.space, name.local) : node.getAttribute(name);

-       }

-       for (value in name) this.each(d3_selection_attr(value, name[value]));

-       return this;

-     }

-     return this.each(d3_selection_attr(name, value));

-   };

-   function d3_selection_attr(name, value) {

-     name = d3.ns.qualify(name);

-     function attrNull() {

-       this.removeAttribute(name);

-     }

-     function attrNullNS() {

-       this.removeAttributeNS(name.space, name.local);

-     }

-     function attrConstant() {

-       this.setAttribute(name, value);

-     }

-     function attrConstantNS() {

-       this.setAttributeNS(name.space, name.local, value);

-     }

-     function attrFunction() {

-       var x = value.apply(this, arguments);

-       if (x == null) this.removeAttribute(name); else this.setAttribute(name, x);

-     }

-     function attrFunctionNS() {

-       var x = value.apply(this, arguments);

-       if (x == null) this.removeAttributeNS(name.space, name.local); else this.setAttributeNS(name.space, name.local, x);

-     }

-     return value == null ? name.local ? attrNullNS : attrNull : typeof value === "function" ? name.local ? attrFunctionNS : attrFunction : name.local ? attrConstantNS : attrConstant;

-   }

-   function d3_collapse(s) {

-     return s.trim().replace(/\s+/g, " ");

-   }

-   d3_selectionPrototype.classed = function(name, value) {

-     if (arguments.length < 2) {

-       if (typeof name === "string") {

-         var node = this.node(), n = (name = d3_selection_classes(name)).length, i = -1;

-         if (value = node.classList) {

-           while (++i < n) if (!value.contains(name[i])) return false;

-         } else {

-           value = node.getAttribute("class");

-           while (++i < n) if (!d3_selection_classedRe(name[i]).test(value)) return false;

-         }

-         return true;

-       }

-       for (value in name) this.each(d3_selection_classed(value, name[value]));

-       return this;

-     }

-     return this.each(d3_selection_classed(name, value));

-   };

-   function d3_selection_classedRe(name) {

-     return new RegExp("(?:^|\\s+)" + d3.requote(name) + "(?:\\s+|$)", "g");

-   }

-   function d3_selection_classes(name) {

-     return (name + "").trim().split(/^|\s+/);

-   }

-   function d3_selection_classed(name, value) {

-     name = d3_selection_classes(name).map(d3_selection_classedName);

-     var n = name.length;

-     function classedConstant() {

-       var i = -1;

-       while (++i < n) name[i](this, value);

-     }

-     function classedFunction() {

-       var i = -1, x = value.apply(this, arguments);

-       while (++i < n) name[i](this, x);

-     }

-     return typeof value === "function" ? classedFunction : classedConstant;

-   }

-   function d3_selection_classedName(name) {

-     var re = d3_selection_classedRe(name);

-     return function(node, value) {

-       if (c = node.classList) return value ? c.add(name) : c.remove(name);

-       var c = node.getAttribute("class") || "";

-       if (value) {

-         re.lastIndex = 0;

-         if (!re.test(c)) node.setAttribute("class", d3_collapse(c + " " + name));

-       } else {

-         node.setAttribute("class", d3_collapse(c.replace(re, " ")));

-       }

-     };

-   }

-   d3_selectionPrototype.style = function(name, value, priority) {

-     var n = arguments.length;

-     if (n < 3) {

-       if (typeof name !== "string") {

-         if (n < 2) value = "";

-         for (priority in name) this.each(d3_selection_style(priority, name[priority], value));

-         return this;

-       }

-       if (n < 2) {

-         var node = this.node();

-         return d3_window(node).getComputedStyle(node, null).getPropertyValue(name);

-       }

-       priority = "";

-     }

-     return this.each(d3_selection_style(name, value, priority));

-   };

-   function d3_selection_style(name, value, priority) {

-     function styleNull() {

-       this.style.removeProperty(name);

-     }

-     function styleConstant() {

-       this.style.setProperty(name, value, priority);

-     }

-     function styleFunction() {

-       var x = value.apply(this, arguments);

-       if (x == null) this.style.removeProperty(name); else this.style.setProperty(name, x, priority);

-     }

-     return value == null ? styleNull : typeof value === "function" ? styleFunction : styleConstant;

-   }

-   d3_selectionPrototype.property = function(name, value) {

-     if (arguments.length < 2) {

-       if (typeof name === "string") return this.node()[name];

-       for (value in name) this.each(d3_selection_property(value, name[value]));

-       return this;

-     }

-     return this.each(d3_selection_property(name, value));

-   };

-   function d3_selection_property(name, value) {

-     function propertyNull() {

-       delete this[name];

-     }

-     function propertyConstant() {

-       this[name] = value;

-     }

-     function propertyFunction() {

-       var x = value.apply(this, arguments);

-       if (x == null) delete this[name]; else this[name] = x;

-     }

-     return value == null ? propertyNull : typeof value === "function" ? propertyFunction : propertyConstant;

-   }

-   d3_selectionPrototype.text = function(value) {

-     return arguments.length ? this.each(typeof value === "function" ? function() {

-       var v = value.apply(this, arguments);

-       this.textContent = v == null ? "" : v;

-     } : value == null ? function() {

-       this.textContent = "";

-     } : function() {

-       this.textContent = value;

-     }) : this.node().textContent;

-   };

-   d3_selectionPrototype.html = function(value) {

-     return arguments.length ? this.each(typeof value === "function" ? function() {

-       var v = value.apply(this, arguments);

-       this.innerHTML = v == null ? "" : v;

-     } : value == null ? function() {

-       this.innerHTML = "";

-     } : function() {

-       this.innerHTML = value;

-     }) : this.node().innerHTML;

-   };

-   d3_selectionPrototype.append = function(name) {

-     name = d3_selection_creator(name);

-     return this.select(function() {

-       return this.appendChild(name.apply(this, arguments));

-     });

-   };

-   function d3_selection_creator(name) {

-     function create() {

-       var document = this.ownerDocument, namespace = this.namespaceURI;

-       return namespace === d3_nsXhtml && document.documentElement.namespaceURI === d3_nsXhtml ? document.createElement(name) : document.createElementNS(namespace, name);

-     }

-     function createNS() {

-       return this.ownerDocument.createElementNS(name.space, name.local);

-     }

-     return typeof name === "function" ? name : (name = d3.ns.qualify(name)).local ? createNS : create;

-   }

-   d3_selectionPrototype.insert = function(name, before) {

-     name = d3_selection_creator(name);

-     before = d3_selection_selector(before);

-     return this.select(function() {

-       return this.insertBefore(name.apply(this, arguments), before.apply(this, arguments) || null);

-     });

-   };

-   d3_selectionPrototype.remove = function() {

-     return this.each(d3_selectionRemove);

-   };

-   function d3_selectionRemove() {

-     var parent = this.parentNode;

-     if (parent) parent.removeChild(this);

-   }

-   d3_selectionPrototype.data = function(value, key) {

-     var i = -1, n = this.length, group, node;

-     if (!arguments.length) {

-       value = new Array(n = (group = this[0]).length);

-       while (++i < n) {

-         if (node = group[i]) {

-           value[i] = node.__data__;

-         }

-       }

-       return value;

-     }

-     function bind(group, groupData) {

-       var i, n = group.length, m = groupData.length, n0 = Math.min(n, m), updateNodes = new Array(m), enterNodes = new Array(m), exitNodes = new Array(n), node, nodeData;

-       if (key) {

-         var nodeByKeyValue = new d3_Map(), keyValues = new Array(n), keyValue;

-         for (i = -1; ++i < n; ) {

-           if (node = group[i]) {

-             if (nodeByKeyValue.has(keyValue = key.call(node, node.__data__, i))) {

-               exitNodes[i] = node;

-             } else {

-               nodeByKeyValue.set(keyValue, node);

-             }

-             keyValues[i] = keyValue;

-           }

-         }

-         for (i = -1; ++i < m; ) {

-           if (!(node = nodeByKeyValue.get(keyValue = key.call(groupData, nodeData = groupData[i], i)))) {

-             enterNodes[i] = d3_selection_dataNode(nodeData);

-           } else if (node !== true) {

-             updateNodes[i] = node;

-             node.__data__ = nodeData;

-           }

-           nodeByKeyValue.set(keyValue, true);

-         }

-         for (i = -1; ++i < n; ) {

-           if (i in keyValues && nodeByKeyValue.get(keyValues[i]) !== true) {

-             exitNodes[i] = group[i];

-           }

-         }

-       } else {

-         for (i = -1; ++i < n0; ) {

-           node = group[i];

-           nodeData = groupData[i];

-           if (node) {

-             node.__data__ = nodeData;

-             updateNodes[i] = node;

-           } else {

-             enterNodes[i] = d3_selection_dataNode(nodeData);

-           }

-         }

-         for (;i < m; ++i) {

-           enterNodes[i] = d3_selection_dataNode(groupData[i]);

-         }

-         for (;i < n; ++i) {

-           exitNodes[i] = group[i];

-         }

-       }

-       enterNodes.update = updateNodes;

-       enterNodes.parentNode = updateNodes.parentNode = exitNodes.parentNode = group.parentNode;

-       enter.push(enterNodes);

-       update.push(updateNodes);

-       exit.push(exitNodes);

-     }

-     var enter = d3_selection_enter([]), update = d3_selection([]), exit = d3_selection([]);

-     if (typeof value === "function") {

-       while (++i < n) {

-         bind(group = this[i], value.call(group, group.parentNode.__data__, i));

-       }

-     } else {

-       while (++i < n) {

-         bind(group = this[i], value);

-       }

-     }

-     update.enter = function() {

-       return enter;

-     };

-     update.exit = function() {

-       return exit;

-     };

-     return update;

-   };

-   function d3_selection_dataNode(data) {

-     return {

-       __data__: data

-     };

-   }

-   d3_selectionPrototype.datum = function(value) {

-     return arguments.length ? this.property("__data__", value) : this.property("__data__");

-   };

-   d3_selectionPrototype.filter = function(filter) {

-     var subgroups = [], subgroup, group, node;

-     if (typeof filter !== "function") filter = d3_selection_filter(filter);

-     for (var j = 0, m = this.length; j < m; j++) {

-       subgroups.push(subgroup = []);

-       subgroup.parentNode = (group = this[j]).parentNode;

-       for (var i = 0, n = group.length; i < n; i++) {

-         if ((node = group[i]) && filter.call(node, node.__data__, i, j)) {

-           subgroup.push(node);

-         }

-       }

-     }

-     return d3_selection(subgroups);

-   };

-   function d3_selection_filter(selector) {

-     return function() {

-       return d3_selectMatches(this, selector);

-     };

-   }

-   d3_selectionPrototype.order = function() {

-     for (var j = -1, m = this.length; ++j < m; ) {

-       for (var group = this[j], i = group.length - 1, next = group[i], node; --i >= 0; ) {

-         if (node = group[i]) {

-           if (next && next !== node.nextSibling) next.parentNode.insertBefore(node, next);

-           next = node;

-         }

-       }

-     }

-     return this;

-   };

-   d3_selectionPrototype.sort = function(comparator) {

-     comparator = d3_selection_sortComparator.apply(this, arguments);

-     for (var j = -1, m = this.length; ++j < m; ) this[j].sort(comparator);

-     return this.order();

-   };

-   function d3_selection_sortComparator(comparator) {

-     if (!arguments.length) comparator = d3_ascending;

-     return function(a, b) {

-       return a && b ? comparator(a.__data__, b.__data__) : !a - !b;

-     };

-   }

-   d3_selectionPrototype.each = function(callback) {

-     return d3_selection_each(this, function(node, i, j) {

-       callback.call(node, node.__data__, i, j);

-     });

-   };

-   function d3_selection_each(groups, callback) {

-     for (var j = 0, m = groups.length; j < m; j++) {

-       for (var group = groups[j], i = 0, n = group.length, node; i < n; i++) {

-         if (node = group[i]) callback(node, i, j);

-       }

-     }

-     return groups;

-   }

-   d3_selectionPrototype.call = function(callback) {

-     var args = d3_array(arguments);

-     callback.apply(args[0] = this, args);

-     return this;

-   };

-   d3_selectionPrototype.empty = function() {

-     return !this.node();

-   };

-   d3_selectionPrototype.node = function() {

-     for (var j = 0, m = this.length; j < m; j++) {

-       for (var group = this[j], i = 0, n = group.length; i < n; i++) {

-         var node = group[i];

-         if (node) return node;

-       }

-     }

-     return null;

-   };

-   d3_selectionPrototype.size = function() {

-     var n = 0;

-     d3_selection_each(this, function() {

-       ++n;

-     });

-     return n;

-   };

-   function d3_selection_enter(selection) {

-     d3_subclass(selection, d3_selection_enterPrototype);

-     return selection;

-   }

-   var d3_selection_enterPrototype = [];

-   d3.selection.enter = d3_selection_enter;

-   d3.selection.enter.prototype = d3_selection_enterPrototype;

-   d3_selection_enterPrototype.append = d3_selectionPrototype.append;

-   d3_selection_enterPrototype.empty = d3_selectionPrototype.empty;

-   d3_selection_enterPrototype.node = d3_selectionPrototype.node;

-   d3_selection_enterPrototype.call = d3_selectionPrototype.call;

-   d3_selection_enterPrototype.size = d3_selectionPrototype.size;

-   d3_selection_enterPrototype.select = function(selector) {

-     var subgroups = [], subgroup, subnode, upgroup, group, node;

-     for (var j = -1, m = this.length; ++j < m; ) {

-       upgroup = (group = this[j]).update;

-       subgroups.push(subgroup = []);

-       subgroup.parentNode = group.parentNode;

-       for (var i = -1, n = group.length; ++i < n; ) {

-         if (node = group[i]) {

-           subgroup.push(upgroup[i] = subnode = selector.call(group.parentNode, node.__data__, i, j));

-           subnode.__data__ = node.__data__;

-         } else {

-           subgroup.push(null);

-         }

-       }

-     }

-     return d3_selection(subgroups);

-   };

-   d3_selection_enterPrototype.insert = function(name, before) {

-     if (arguments.length < 2) before = d3_selection_enterInsertBefore(this);

-     return d3_selectionPrototype.insert.call(this, name, before);

-   };

-   function d3_selection_enterInsertBefore(enter) {

-     var i0, j0;

-     return function(d, i, j) {

-       var group = enter[j].update, n = group.length, node;

-       if (j != j0) j0 = j, i0 = 0;

-       if (i >= i0) i0 = i + 1;

-       while (!(node = group[i0]) && ++i0 < n) ;

-       return node;

-     };

-   }

-   d3.select = function(node) {

-     var group;

-     if (typeof node === "string") {

-       group = [ d3_select(node, d3_document) ];

-       group.parentNode = d3_document.documentElement;

-     } else {

-       group = [ node ];

-       group.parentNode = d3_documentElement(node);

-     }

-     return d3_selection([ group ]);

-   };

-   d3.selectAll = function(nodes) {

-     var group;

-     if (typeof nodes === "string") {

-       group = d3_array(d3_selectAll(nodes, d3_document));

-       group.parentNode = d3_document.documentElement;

-     } else {

-       group = d3_array(nodes);

-       group.parentNode = null;

-     }

-     return d3_selection([ group ]);

-   };

-   d3_selectionPrototype.on = function(type, listener, capture) {

-     var n = arguments.length;

-     if (n < 3) {

-       if (typeof type !== "string") {

-         if (n < 2) listener = false;

-         for (capture in type) this.each(d3_selection_on(capture, type[capture], listener));

-         return this;

-       }

-       if (n < 2) return (n = this.node()["__on" + type]) && n._;

-       capture = false;

-     }

-     return this.each(d3_selection_on(type, listener, capture));

-   };

-   function d3_selection_on(type, listener, capture) {

-     var name = "__on" + type, i = type.indexOf("."), wrap = d3_selection_onListener;

-     if (i > 0) type = type.slice(0, i);

-     var filter = d3_selection_onFilters.get(type);

-     if (filter) type = filter, wrap = d3_selection_onFilter;

-     function onRemove() {

-       var l = this[name];

-       if (l) {

-         this.removeEventListener(type, l, l.$);

-         delete this[name];

-       }

-     }

-     function onAdd() {

-       var l = wrap(listener, d3_array(arguments));

-       onRemove.call(this);

-       this.addEventListener(type, this[name] = l, l.$ = capture);

-       l._ = listener;

-     }

-     function removeAll() {

-       var re = new RegExp("^__on([^.]+)" + d3.requote(type) + "$"), match;

-       for (var name in this) {

-         if (match = name.match(re)) {

-           var l = this[name];

-           this.removeEventListener(match[1], l, l.$);

-           delete this[name];

-         }

-       }

-     }

-     return i ? listener ? onAdd : onRemove : listener ? d3_noop : removeAll;

-   }

-   var d3_selection_onFilters = d3.map({

-     mouseenter: "mouseover",

-     mouseleave: "mouseout"

-   });

-   if (d3_document) {

-     d3_selection_onFilters.forEach(function(k) {

-       if ("on" + k in d3_document) d3_selection_onFilters.remove(k);

-     });

-   }

-   function d3_selection_onListener(listener, argumentz) {

-     return function(e) {

-       var o = d3.event;

-       d3.event = e;

-       argumentz[0] = this.__data__;

-       try {

-         listener.apply(this, argumentz);

-       } finally {

-         d3.event = o;

-       }

-     };

-   }

-   function d3_selection_onFilter(listener, argumentz) {

-     var l = d3_selection_onListener(listener, argumentz);

-     return function(e) {

-       var target = this, related = e.relatedTarget;

-       if (!related || related !== target && !(related.compareDocumentPosition(target) & 8)) {

-         l.call(target, e);

-       }

-     };

-   }

-   var d3_event_dragSelect, d3_event_dragId = 0;

-   function d3_event_dragSuppress(node) {

-     var name = ".dragsuppress-" + ++d3_event_dragId, click = "click" + name, w = d3.select(d3_window(node)).on("touchmove" + name, d3_eventPreventDefault).on("dragstart" + name, d3_eventPreventDefault).on("selectstart" + name, d3_eventPreventDefault);

-     if (d3_event_dragSelect == null) {

-       d3_event_dragSelect = "onselectstart" in node ? false : d3_vendorSymbol(node.style, "userSelect");

-     }

-     if (d3_event_dragSelect) {

-       var style = d3_documentElement(node).style, select = style[d3_event_dragSelect];

-       style[d3_event_dragSelect] = "none";

-     }

-     return function(suppressClick) {

-       w.on(name, null);

-       if (d3_event_dragSelect) style[d3_event_dragSelect] = select;

-       if (suppressClick) {

-         var off = function() {

-           w.on(click, null);

-         };

-         w.on(click, function() {

-           d3_eventPreventDefault();

-           off();

-         }, true);

-         setTimeout(off, 0);

-       }

-     };

-   }

-   d3.mouse = function(container) {

-     return d3_mousePoint(container, d3_eventSource());

-   };

-   var d3_mouse_bug44083 = this.navigator && /WebKit/.test(this.navigator.userAgent) ? -1 : 0;

-   function d3_mousePoint(container, e) {

-     if (e.changedTouches) e = e.changedTouches[0];

-     var svg = container.ownerSVGElement || container;

-     if (svg.createSVGPoint) {

-       var point = svg.createSVGPoint();

-       if (d3_mouse_bug44083 < 0) {

-         var window = d3_window(container);

-         if (window.scrollX || window.scrollY) {

-           svg = d3.select("body").append("svg").style({

-             position: "absolute",

-             top: 0,

-             left: 0,

-             margin: 0,

-             padding: 0,

-             border: "none"

-           }, "important");

-           var ctm = svg[0][0].getScreenCTM();

-           d3_mouse_bug44083 = !(ctm.f || ctm.e);

-           svg.remove();

-         }

-       }

-       if (d3_mouse_bug44083) point.x = e.pageX, point.y = e.pageY; else point.x = e.clientX,

-       point.y = e.clientY;

-       point = point.matrixTransform(container.getScreenCTM().inverse());

-       return [ point.x, point.y ];

-     }

-     var rect = container.getBoundingClientRect();

-     return [ e.clientX - rect.left - container.clientLeft, e.clientY - rect.top - container.clientTop ];

-   }

-   d3.touch = function(container, touches, identifier) {

-     if (arguments.length < 3) identifier = touches, touches = d3_eventSource().changedTouches;

-     if (touches) for (var i = 0, n = touches.length, touch; i < n; ++i) {

-       if ((touch = touches[i]).identifier === identifier) {

-         return d3_mousePoint(container, touch);

-       }

-     }

-   };

-   d3.behavior.drag = function() {

-     var event = d3_eventDispatch(drag, "drag", "dragstart", "dragend"), origin = null, mousedown = dragstart(d3_noop, d3.mouse, d3_window, "mousemove", "mouseup"), touchstart = dragstart(d3_behavior_dragTouchId, d3.touch, d3_identity, "touchmove", "touchend");

-     function drag() {

-       this.on("mousedown.drag", mousedown).on("touchstart.drag", touchstart);

-     }

-     function dragstart(id, position, subject, move, end) {

-       return function() {

-         var that = this, target = d3.event.target.correspondingElement || d3.event.target, parent = that.parentNode, dispatch = event.of(that, arguments), dragged = 0, dragId = id(), dragName = ".drag" + (dragId == null ? "" : "-" + dragId), dragOffset, dragSubject = d3.select(subject(target)).on(move + dragName, moved).on(end + dragName, ended), dragRestore = d3_event_dragSuppress(target), position0 = position(parent, dragId);

-         if (origin) {

-           dragOffset = origin.apply(that, arguments);

-           dragOffset = [ dragOffset.x - position0[0], dragOffset.y - position0[1] ];

-         } else {

-           dragOffset = [ 0, 0 ];

-         }

-         dispatch({

-           type: "dragstart"

-         });

-         function moved() {

-           var position1 = position(parent, dragId), dx, dy;

-           if (!position1) return;

-           dx = position1[0] - position0[0];

-           dy = position1[1] - position0[1];

-           dragged |= dx | dy;

-           position0 = position1;

-           dispatch({

-             type: "drag",

-             x: position1[0] + dragOffset[0],

-             y: position1[1] + dragOffset[1],

-             dx: dx,

-             dy: dy

-           });

-         }

-         function ended() {

-           if (!position(parent, dragId)) return;

-           dragSubject.on(move + dragName, null).on(end + dragName, null);

-           dragRestore(dragged);

-           dispatch({

-             type: "dragend"

-           });

-         }

-       };

-     }

-     drag.origin = function(x) {

-       if (!arguments.length) return origin;

-       origin = x;

-       return drag;

-     };

-     return d3.rebind(drag, event, "on");

-   };

-   function d3_behavior_dragTouchId() {

-     return d3.event.changedTouches[0].identifier;

-   }

-   d3.touches = function(container, touches) {

-     if (arguments.length < 2) touches = d3_eventSource().touches;

-     return touches ? d3_array(touches).map(function(touch) {

-       var point = d3_mousePoint(container, touch);

-       point.identifier = touch.identifier;

-       return point;

-     }) : [];

-   };

-   var ε = 1e-6, ε2 = ε * ε, π = Math.PI, τ = 2 * π, τε = τ - ε, halfπ = π / 2, d3_radians = π / 180, d3_degrees = 180 / π;

-   function d3_sgn(x) {

-     return x > 0 ? 1 : x < 0 ? -1 : 0;

-   }

-   function d3_cross2d(a, b, c) {

-     return (b[0] - a[0]) * (c[1] - a[1]) - (b[1] - a[1]) * (c[0] - a[0]);

-   }

-   function d3_acos(x) {

-     return x > 1 ? 0 : x < -1 ? π : Math.acos(x);

-   }

-   function d3_asin(x) {

-     return x > 1 ? halfπ : x < -1 ? -halfπ : Math.asin(x);

-   }

-   function d3_sinh(x) {

-     return ((x = Math.exp(x)) - 1 / x) / 2;

-   }

-   function d3_cosh(x) {

-     return ((x = Math.exp(x)) + 1 / x) / 2;

-   }

-   function d3_tanh(x) {

-     return ((x = Math.exp(2 * x)) - 1) / (x + 1);

-   }

-   function d3_haversin(x) {

-     return (x = Math.sin(x / 2)) * x;

-   }

-   var ρ = Math.SQRT2, ρ2 = 2, ρ4 = 4;

-   d3.interpolateZoom = function(p0, p1) {

-     var ux0 = p0[0], uy0 = p0[1], w0 = p0[2], ux1 = p1[0], uy1 = p1[1], w1 = p1[2], dx = ux1 - ux0, dy = uy1 - uy0, d2 = dx * dx + dy * dy, i, S;

-     if (d2 < ε2) {

-       S = Math.log(w1 / w0) / ρ;

-       i = function(t) {

-         return [ ux0 + t * dx, uy0 + t * dy, w0 * Math.exp(ρ * t * S) ];

-       };

-     } else {

-       var d1 = Math.sqrt(d2), b0 = (w1 * w1 - w0 * w0 + ρ4 * d2) / (2 * w0 * ρ2 * d1), b1 = (w1 * w1 - w0 * w0 - ρ4 * d2) / (2 * w1 * ρ2 * d1), r0 = Math.log(Math.sqrt(b0 * b0 + 1) - b0), r1 = Math.log(Math.sqrt(b1 * b1 + 1) - b1);

-       S = (r1 - r0) / ρ;

-       i = function(t) {

-         var s = t * S, coshr0 = d3_cosh(r0), u = w0 / (ρ2 * d1) * (coshr0 * d3_tanh(ρ * s + r0) - d3_sinh(r0));

-         return [ ux0 + u * dx, uy0 + u * dy, w0 * coshr0 / d3_cosh(ρ * s + r0) ];

-       };

-     }

-     i.duration = S * 1e3;

-     return i;

-   };

-   d3.behavior.zoom = function() {

-     var view = {

-       x: 0,

-       y: 0,

-       k: 1

-     }, translate0, center0, center, size = [ 960, 500 ], scaleExtent = d3_behavior_zoomInfinity, duration = 250, zooming = 0, mousedown = "mousedown.zoom", mousemove = "mousemove.zoom", mouseup = "mouseup.zoom", mousewheelTimer, touchstart = "touchstart.zoom", touchtime, event = d3_eventDispatch(zoom, "zoomstart", "zoom", "zoomend"), x0, x1, y0, y1;

-     if (!d3_behavior_zoomWheel) {

-       d3_behavior_zoomWheel = "onwheel" in d3_document ? (d3_behavior_zoomDelta = function() {

-         return -d3.event.deltaY * (d3.event.deltaMode ? 120 : 1);

-       }, "wheel") : "onmousewheel" in d3_document ? (d3_behavior_zoomDelta = function() {

-         return d3.event.wheelDelta;

-       }, "mousewheel") : (d3_behavior_zoomDelta = function() {

-         return -d3.event.detail;

-       }, "MozMousePixelScroll");

-     }

-     function zoom(g) {

-       g.on(mousedown, mousedowned).on(d3_behavior_zoomWheel + ".zoom", mousewheeled).on("dblclick.zoom", dblclicked).on(touchstart, touchstarted);

-     }

-     zoom.event = function(g) {

-       g.each(function() {

-         var dispatch = event.of(this, arguments), view1 = view;

-         if (d3_transitionInheritId) {

-           d3.select(this).transition().each("start.zoom", function() {

-             view = this.__chart__ || {

-               x: 0,

-               y: 0,

-               k: 1

-             };

-             zoomstarted(dispatch);

-           }).tween("zoom:zoom", function() {

-             var dx = size[0], dy = size[1], cx = center0 ? center0[0] : dx / 2, cy = center0 ? center0[1] : dy / 2, i = d3.interpolateZoom([ (cx - view.x) / view.k, (cy - view.y) / view.k, dx / view.k ], [ (cx - view1.x) / view1.k, (cy - view1.y) / view1.k, dx / view1.k ]);

-             return function(t) {

-               var l = i(t), k = dx / l[2];

-               this.__chart__ = view = {

-                 x: cx - l[0] * k,

-                 y: cy - l[1] * k,

-                 k: k

-               };

-               zoomed(dispatch);

-             };

-           }).each("interrupt.zoom", function() {

-             zoomended(dispatch);

-           }).each("end.zoom", function() {

-             zoomended(dispatch);

-           });

-         } else {

-           this.__chart__ = view;

-           zoomstarted(dispatch);

-           zoomed(dispatch);

-           zoomended(dispatch);

-         }

-       });

-     };

-     zoom.translate = function(_) {

-       if (!arguments.length) return [ view.x, view.y ];

-       view = {

-         x: +_[0],

-         y: +_[1],

-         k: view.k

-       };

-       rescale();

-       return zoom;

-     };

-     zoom.scale = function(_) {

-       if (!arguments.length) return view.k;

-       view = {

-         x: view.x,

-         y: view.y,

-         k: null

-       };

-       scaleTo(+_);

-       rescale();

-       return zoom;

-     };

-     zoom.scaleExtent = function(_) {

-       if (!arguments.length) return scaleExtent;

-       scaleExtent = _ == null ? d3_behavior_zoomInfinity : [ +_[0], +_[1] ];

-       return zoom;

-     };

-     zoom.center = function(_) {

-       if (!arguments.length) return center;

-       center = _ && [ +_[0], +_[1] ];

-       return zoom;

-     };

-     zoom.size = function(_) {

-       if (!arguments.length) return size;

-       size = _ && [ +_[0], +_[1] ];

-       return zoom;

-     };

-     zoom.duration = function(_) {

-       if (!arguments.length) return duration;

-       duration = +_;

-       return zoom;

-     };

-     zoom.x = function(z) {

-       if (!arguments.length) return x1;

-       x1 = z;

-       x0 = z.copy();

-       view = {

-         x: 0,

-         y: 0,

-         k: 1

-       };

-       return zoom;

-     };

-     zoom.y = function(z) {

-       if (!arguments.length) return y1;

-       y1 = z;

-       y0 = z.copy();

-       view = {

-         x: 0,

-         y: 0,

-         k: 1

-       };

-       return zoom;

-     };

-     function location(p) {

-       return [ (p[0] - view.x) / view.k, (p[1] - view.y) / view.k ];

-     }

-     function point(l) {

-       return [ l[0] * view.k + view.x, l[1] * view.k + view.y ];

-     }

-     function scaleTo(s) {

-       view.k = Math.max(scaleExtent[0], Math.min(scaleExtent[1], s));

-     }

-     function translateTo(p, l) {

-       l = point(l);

-       view.x += p[0] - l[0];

-       view.y += p[1] - l[1];

-     }

-     function zoomTo(that, p, l, k) {

-       that.__chart__ = {

-         x: view.x,

-         y: view.y,

-         k: view.k

-       };

-       scaleTo(Math.pow(2, k));

-       translateTo(center0 = p, l);

-       that = d3.select(that);

-       if (duration > 0) that = that.transition().duration(duration);

-       that.call(zoom.event);

-     }

-     function rescale() {

-       if (x1) x1.domain(x0.range().map(function(x) {

-         return (x - view.x) / view.k;

-       }).map(x0.invert));

-       if (y1) y1.domain(y0.range().map(function(y) {

-         return (y - view.y) / view.k;

-       }).map(y0.invert));

-     }

-     function zoomstarted(dispatch) {

-       if (!zooming++) dispatch({

-         type: "zoomstart"

-       });

-     }

-     function zoomed(dispatch) {

-       rescale();

-       dispatch({

-         type: "zoom",

-         scale: view.k,

-         translate: [ view.x, view.y ]

-       });

-     }

-     function zoomended(dispatch) {

-       if (!--zooming) dispatch({

-         type: "zoomend"

-       }), center0 = null;

-     }

-     function mousedowned() {

-       var that = this, dispatch = event.of(that, arguments), dragged = 0, subject = d3.select(d3_window(that)).on(mousemove, moved).on(mouseup, ended), location0 = location(d3.mouse(that)), dragRestore = d3_event_dragSuppress(that);

-       d3_selection_interrupt.call(that);

-       zoomstarted(dispatch);

-       function moved() {

-         dragged = 1;

-         translateTo(d3.mouse(that), location0);

-         zoomed(dispatch);

-       }

-       function ended() {

-         subject.on(mousemove, null).on(mouseup, null);

-         dragRestore(dragged);

-         zoomended(dispatch);

-       }

-     }

-     function touchstarted() {

-       var that = this, dispatch = event.of(that, arguments), locations0 = {}, distance0 = 0, scale0, zoomName = ".zoom-" + d3.event.changedTouches[0].identifier, touchmove = "touchmove" + zoomName, touchend = "touchend" + zoomName, targets = [], subject = d3.select(that), dragRestore = d3_event_dragSuppress(that);

-       started();

-       zoomstarted(dispatch);

-       subject.on(mousedown, null).on(touchstart, started);

-       function relocate() {

-         var touches = d3.touches(that);

-         scale0 = view.k;

-         touches.forEach(function(t) {

-           if (t.identifier in locations0) locations0[t.identifier] = location(t);

-         });

-         return touches;

-       }

-       function started() {

-         var target = d3.event.target;

-         d3.select(target).on(touchmove, moved).on(touchend, ended);

-         targets.push(target);

-         var changed = d3.event.changedTouches;

-         for (var i = 0, n = changed.length; i < n; ++i) {

-           locations0[changed[i].identifier] = null;

-         }

-         var touches = relocate(), now = Date.now();

-         if (touches.length === 1) {

-           if (now - touchtime < 500) {

-             var p = touches[0];

-             zoomTo(that, p, locations0[p.identifier], Math.floor(Math.log(view.k) / Math.LN2) + 1);

-             d3_eventPreventDefault();

-           }

-           touchtime = now;

-         } else if (touches.length > 1) {

-           var p = touches[0], q = touches[1], dx = p[0] - q[0], dy = p[1] - q[1];

-           distance0 = dx * dx + dy * dy;

-         }

-       }

-       function moved() {

-         var touches = d3.touches(that), p0, l0, p1, l1;

-         d3_selection_interrupt.call(that);

-         for (var i = 0, n = touches.length; i < n; ++i, l1 = null) {

-           p1 = touches[i];

-           if (l1 = locations0[p1.identifier]) {

-             if (l0) break;

-             p0 = p1, l0 = l1;

-           }

-         }

-         if (l1) {

-           var distance1 = (distance1 = p1[0] - p0[0]) * distance1 + (distance1 = p1[1] - p0[1]) * distance1, scale1 = distance0 && Math.sqrt(distance1 / distance0);

-           p0 = [ (p0[0] + p1[0]) / 2, (p0[1] + p1[1]) / 2 ];

-           l0 = [ (l0[0] + l1[0]) / 2, (l0[1] + l1[1]) / 2 ];

-           scaleTo(scale1 * scale0);

-         }

-         touchtime = null;

-         translateTo(p0, l0);

-         zoomed(dispatch);

-       }

-       function ended() {

-         if (d3.event.touches.length) {

-           var changed = d3.event.changedTouches;

-           for (var i = 0, n = changed.length; i < n; ++i) {

-             delete locations0[changed[i].identifier];

-           }

-           for (var identifier in locations0) {

-             return void relocate();

-           }

-         }

-         d3.selectAll(targets).on(zoomName, null);

-         subject.on(mousedown, mousedowned).on(touchstart, touchstarted);

-         dragRestore();

-         zoomended(dispatch);

-       }

-     }

-     function mousewheeled() {

-       var dispatch = event.of(this, arguments);

-       if (mousewheelTimer) clearTimeout(mousewheelTimer); else d3_selection_interrupt.call(this),

-       translate0 = location(center0 = center || d3.mouse(this)), zoomstarted(dispatch);

-       mousewheelTimer = setTimeout(function() {

-         mousewheelTimer = null;

-         zoomended(dispatch);

-       }, 50);

-       d3_eventPreventDefault();

-       scaleTo(Math.pow(2, d3_behavior_zoomDelta() * .002) * view.k);

-       translateTo(center0, translate0);

-       zoomed(dispatch);

-     }

-     function dblclicked() {

-       var p = d3.mouse(this), k = Math.log(view.k) / Math.LN2;

-       zoomTo(this, p, location(p), d3.event.shiftKey ? Math.ceil(k) - 1 : Math.floor(k) + 1);

-     }

-     return d3.rebind(zoom, event, "on");

-   };

-   var d3_behavior_zoomInfinity = [ 0, Infinity ], d3_behavior_zoomDelta, d3_behavior_zoomWheel;

-   d3.color = d3_color;

-   function d3_color() {}

-   d3_color.prototype.toString = function() {

-     return this.rgb() + "";

-   };

-   d3.hsl = d3_hsl;

-   function d3_hsl(h, s, l) {

-     return this instanceof d3_hsl ? void (this.h = +h, this.s = +s, this.l = +l) : arguments.length < 2 ? h instanceof d3_hsl ? new d3_hsl(h.h, h.s, h.l) : d3_rgb_parse("" + h, d3_rgb_hsl, d3_hsl) : new d3_hsl(h, s, l);

-   }

-   var d3_hslPrototype = d3_hsl.prototype = new d3_color();

-   d3_hslPrototype.brighter = function(k) {

-     k = Math.pow(.7, arguments.length ? k : 1);

-     return new d3_hsl(this.h, this.s, this.l / k);

-   };

-   d3_hslPrototype.darker = function(k) {

-     k = Math.pow(.7, arguments.length ? k : 1);

-     return new d3_hsl(this.h, this.s, k * this.l);

-   };

-   d3_hslPrototype.rgb = function() {

-     return d3_hsl_rgb(this.h, this.s, this.l);

-   };

-   function d3_hsl_rgb(h, s, l) {

-     var m1, m2;

-     h = isNaN(h) ? 0 : (h %= 360) < 0 ? h + 360 : h;

-     s = isNaN(s) ? 0 : s < 0 ? 0 : s > 1 ? 1 : s;

-     l = l < 0 ? 0 : l > 1 ? 1 : l;

-     m2 = l <= .5 ? l * (1 + s) : l + s - l * s;

-     m1 = 2 * l - m2;

-     function v(h) {

-       if (h > 360) h -= 360; else if (h < 0) h += 360;

-       if (h < 60) return m1 + (m2 - m1) * h / 60;

-       if (h < 180) return m2;

-       if (h < 240) return m1 + (m2 - m1) * (240 - h) / 60;

-       return m1;

-     }

-     function vv(h) {

-       return Math.round(v(h) * 255);

-     }

-     return new d3_rgb(vv(h + 120), vv(h), vv(h - 120));

-   }

-   d3.hcl = d3_hcl;

-   function d3_hcl(h, c, l) {

-     return this instanceof d3_hcl ? void (this.h = +h, this.c = +c, this.l = +l) : arguments.length < 2 ? h instanceof d3_hcl ? new d3_hcl(h.h, h.c, h.l) : h instanceof d3_lab ? d3_lab_hcl(h.l, h.a, h.b) : d3_lab_hcl((h = d3_rgb_lab((h = d3.rgb(h)).r, h.g, h.b)).l, h.a, h.b) : new d3_hcl(h, c, l);

-   }

-   var d3_hclPrototype = d3_hcl.prototype = new d3_color();

-   d3_hclPrototype.brighter = function(k) {

-     return new d3_hcl(this.h, this.c, Math.min(100, this.l + d3_lab_K * (arguments.length ? k : 1)));

-   };

-   d3_hclPrototype.darker = function(k) {

-     return new d3_hcl(this.h, this.c, Math.max(0, this.l - d3_lab_K * (arguments.length ? k : 1)));

-   };

-   d3_hclPrototype.rgb = function() {

-     return d3_hcl_lab(this.h, this.c, this.l).rgb();

-   };

-   function d3_hcl_lab(h, c, l) {

-     if (isNaN(h)) h = 0;

-     if (isNaN(c)) c = 0;

-     return new d3_lab(l, Math.cos(h *= d3_radians) * c, Math.sin(h) * c);

-   }

-   d3.lab = d3_lab;

-   function d3_lab(l, a, b) {

-     return this instanceof d3_lab ? void (this.l = +l, this.a = +a, this.b = +b) : arguments.length < 2 ? l instanceof d3_lab ? new d3_lab(l.l, l.a, l.b) : l instanceof d3_hcl ? d3_hcl_lab(l.h, l.c, l.l) : d3_rgb_lab((l = d3_rgb(l)).r, l.g, l.b) : new d3_lab(l, a, b);

-   }

-   var d3_lab_K = 18;

-   var d3_lab_X = .95047, d3_lab_Y = 1, d3_lab_Z = 1.08883;

-   var d3_labPrototype = d3_lab.prototype = new d3_color();

-   d3_labPrototype.brighter = function(k) {

-     return new d3_lab(Math.min(100, this.l + d3_lab_K * (arguments.length ? k : 1)), this.a, this.b);

-   };

-   d3_labPrototype.darker = function(k) {

-     return new d3_lab(Math.max(0, this.l - d3_lab_K * (arguments.length ? k : 1)), this.a, this.b);

-   };

-   d3_labPrototype.rgb = function() {

-     return d3_lab_rgb(this.l, this.a, this.b);

-   };

-   function d3_lab_rgb(l, a, b) {

-     var y = (l + 16) / 116, x = y + a / 500, z = y - b / 200;

-     x = d3_lab_xyz(x) * d3_lab_X;

-     y = d3_lab_xyz(y) * d3_lab_Y;

-     z = d3_lab_xyz(z) * d3_lab_Z;

-     return new d3_rgb(d3_xyz_rgb(3.2404542 * x - 1.5371385 * y - .4985314 * z), d3_xyz_rgb(-.969266 * x + 1.8760108 * y + .041556 * z), d3_xyz_rgb(.0556434 * x - .2040259 * y + 1.0572252 * z));

-   }

-   function d3_lab_hcl(l, a, b) {

-     return l > 0 ? new d3_hcl(Math.atan2(b, a) * d3_degrees, Math.sqrt(a * a + b * b), l) : new d3_hcl(NaN, NaN, l);

-   }

-   function d3_lab_xyz(x) {

-     return x > .206893034 ? x * x * x : (x - 4 / 29) / 7.787037;

-   }

-   function d3_xyz_lab(x) {

-     return x > .008856 ? Math.pow(x, 1 / 3) : 7.787037 * x + 4 / 29;

-   }

-   function d3_xyz_rgb(r) {

-     return Math.round(255 * (r <= .00304 ? 12.92 * r : 1.055 * Math.pow(r, 1 / 2.4) - .055));

-   }

-   d3.rgb = d3_rgb;

-   function d3_rgb(r, g, b) {

-     return this instanceof d3_rgb ? void (this.r = ~~r, this.g = ~~g, this.b = ~~b) : arguments.length < 2 ? r instanceof d3_rgb ? new d3_rgb(r.r, r.g, r.b) : d3_rgb_parse("" + r, d3_rgb, d3_hsl_rgb) : new d3_rgb(r, g, b);

-   }

-   function d3_rgbNumber(value) {

-     return new d3_rgb(value >> 16, value >> 8 & 255, value & 255);

-   }

-   function d3_rgbString(value) {

-     return d3_rgbNumber(value) + "";

-   }

-   var d3_rgbPrototype = d3_rgb.prototype = new d3_color();

-   d3_rgbPrototype.brighter = function(k) {

-     k = Math.pow(.7, arguments.length ? k : 1);

-     var r = this.r, g = this.g, b = this.b, i = 30;

-     if (!r && !g && !b) return new d3_rgb(i, i, i);

-     if (r && r < i) r = i;

-     if (g && g < i) g = i;

-     if (b && b < i) b = i;

-     return new d3_rgb(Math.min(255, r / k), Math.min(255, g / k), Math.min(255, b / k));

-   };

-   d3_rgbPrototype.darker = function(k) {

-     k = Math.pow(.7, arguments.length ? k : 1);

-     return new d3_rgb(k * this.r, k * this.g, k * this.b);

-   };

-   d3_rgbPrototype.hsl = function() {

-     return d3_rgb_hsl(this.r, this.g, this.b);

-   };

-   d3_rgbPrototype.toString = function() {

-     return "#" + d3_rgb_hex(this.r) + d3_rgb_hex(this.g) + d3_rgb_hex(this.b);

-   };

-   function d3_rgb_hex(v) {

-     return v < 16 ? "0" + Math.max(0, v).toString(16) : Math.min(255, v).toString(16);

-   }

-   function d3_rgb_parse(format, rgb, hsl) {

-     var r = 0, g = 0, b = 0, m1, m2, color;

-     m1 = /([a-z]+)\((.*)\)/.exec(format = format.toLowerCase());

-     if (m1) {

-       m2 = m1[2].split(",");

-       switch (m1[1]) {

-        case "hsl":

-         {

-           return hsl(parseFloat(m2[0]), parseFloat(m2[1]) / 100, parseFloat(m2[2]) / 100);

-         }

- 

-        case "rgb":

-         {

-           return rgb(d3_rgb_parseNumber(m2[0]), d3_rgb_parseNumber(m2[1]), d3_rgb_parseNumber(m2[2]));

-         }

-       }

-     }

-     if (color = d3_rgb_names.get(format)) {

-       return rgb(color.r, color.g, color.b);

-     }

-     if (format != null && format.charAt(0) === "#" && !isNaN(color = parseInt(format.slice(1), 16))) {

-       if (format.length === 4) {

-         r = (color & 3840) >> 4;

-         r = r >> 4 | r;

-         g = color & 240;

-         g = g >> 4 | g;

-         b = color & 15;

-         b = b << 4 | b;

-       } else if (format.length === 7) {

-         r = (color & 16711680) >> 16;

-         g = (color & 65280) >> 8;

-         b = color & 255;

-       }

-     }

-     return rgb(r, g, b);

-   }

-   function d3_rgb_hsl(r, g, b) {

-     var min = Math.min(r /= 255, g /= 255, b /= 255), max = Math.max(r, g, b), d = max - min, h, s, l = (max + min) / 2;

-     if (d) {

-       s = l < .5 ? d / (max + min) : d / (2 - max - min);

-       if (r == max) h = (g - b) / d + (g < b ? 6 : 0); else if (g == max) h = (b - r) / d + 2; else h = (r - g) / d + 4;

-       h *= 60;

-     } else {

-       h = NaN;

-       s = l > 0 && l < 1 ? 0 : h;

-     }

-     return new d3_hsl(h, s, l);

-   }

-   function d3_rgb_lab(r, g, b) {

-     r = d3_rgb_xyz(r);

-     g = d3_rgb_xyz(g);

-     b = d3_rgb_xyz(b);

-     var x = d3_xyz_lab((.4124564 * r + .3575761 * g + .1804375 * b) / d3_lab_X), y = d3_xyz_lab((.2126729 * r + .7151522 * g + .072175 * b) / d3_lab_Y), z = d3_xyz_lab((.0193339 * r + .119192 * g + .9503041 * b) / d3_lab_Z);

-     return d3_lab(116 * y - 16, 500 * (x - y), 200 * (y - z));

-   }

-   function d3_rgb_xyz(r) {

-     return (r /= 255) <= .04045 ? r / 12.92 : Math.pow((r + .055) / 1.055, 2.4);

-   }

-   function d3_rgb_parseNumber(c) {

-     var f = parseFloat(c);

-     return c.charAt(c.length - 1) === "%" ? Math.round(f * 2.55) : f;

-   }

-   var d3_rgb_names = d3.map({

-     aliceblue: 15792383,

-     antiquewhite: 16444375,

-     aqua: 65535,

-     aquamarine: 8388564,

-     azure: 15794175,

-     beige: 16119260,

-     bisque: 16770244,

-     black: 0,

-     blanchedalmond: 16772045,

-     blue: 255,

-     blueviolet: 9055202,

-     brown: 10824234,

-     burlywood: 14596231,

-     cadetblue: 6266528,

-     chartreuse: 8388352,

-     chocolate: 13789470,

-     coral: 16744272,

-     cornflowerblue: 6591981,

-     cornsilk: 16775388,

-     crimson: 14423100,

-     cyan: 65535,

-     darkblue: 139,

-     darkcyan: 35723,

-     darkgoldenrod: 12092939,

-     darkgray: 11119017,

-     darkgreen: 25600,

-     darkgrey: 11119017,

-     darkkhaki: 12433259,

-     darkmagenta: 9109643,

-     darkolivegreen: 5597999,

-     darkorange: 16747520,

-     darkorchid: 10040012,

-     darkred: 9109504,

-     darksalmon: 15308410,

-     darkseagreen: 9419919,

-     darkslateblue: 4734347,

-     darkslategray: 3100495,

-     darkslategrey: 3100495,

-     darkturquoise: 52945,

-     darkviolet: 9699539,

-     deeppink: 16716947,

-     deepskyblue: 49151,

-     dimgray: 6908265,

-     dimgrey: 6908265,

-     dodgerblue: 2003199,

-     firebrick: 11674146,

-     floralwhite: 16775920,

-     forestgreen: 2263842,

-     fuchsia: 16711935,

-     gainsboro: 14474460,

-     ghostwhite: 16316671,

-     gold: 16766720,

-     goldenrod: 14329120,

-     gray: 8421504,

-     green: 32768,

-     greenyellow: 11403055,

-     grey: 8421504,

-     honeydew: 15794160,

-     hotpink: 16738740,

-     indianred: 13458524,

-     indigo: 4915330,

-     ivory: 16777200,

-     khaki: 15787660,

-     lavender: 15132410,

-     lavenderblush: 16773365,

-     lawngreen: 8190976,

-     lemonchiffon: 16775885,

-     lightblue: 11393254,

-     lightcoral: 15761536,

-     lightcyan: 14745599,

-     lightgoldenrodyellow: 16448210,

-     lightgray: 13882323,

-     lightgreen: 9498256,

-     lightgrey: 13882323,

-     lightpink: 16758465,

-     lightsalmon: 16752762,

-     lightseagreen: 2142890,

-     lightskyblue: 8900346,

-     lightslategray: 7833753,

-     lightslategrey: 7833753,

-     lightsteelblue: 11584734,

-     lightyellow: 16777184,

-     lime: 65280,

-     limegreen: 3329330,

-     linen: 16445670,

-     magenta: 16711935,

-     maroon: 8388608,

-     mediumaquamarine: 6737322,

-     mediumblue: 205,

-     mediumorchid: 12211667,

-     mediumpurple: 9662683,

-     mediumseagreen: 3978097,

-     mediumslateblue: 8087790,

-     mediumspringgreen: 64154,

-     mediumturquoise: 4772300,

-     mediumvioletred: 13047173,

-     midnightblue: 1644912,

-     mintcream: 16121850,

-     mistyrose: 16770273,

-     moccasin: 16770229,

-     navajowhite: 16768685,

-     navy: 128,

-     oldlace: 16643558,

-     olive: 8421376,

-     olivedrab: 7048739,

-     orange: 16753920,

-     orangered: 16729344,

-     orchid: 14315734,

-     palegoldenrod: 15657130,

-     palegreen: 10025880,

-     paleturquoise: 11529966,

-     palevioletred: 14381203,

-     papayawhip: 16773077,

-     peachpuff: 16767673,

-     peru: 13468991,

-     pink: 16761035,

-     plum: 14524637,

-     powderblue: 11591910,

-     purple: 8388736,

-     rebeccapurple: 6697881,

-     red: 16711680,

-     rosybrown: 12357519,

-     royalblue: 4286945,

-     saddlebrown: 9127187,

-     salmon: 16416882,

-     sandybrown: 16032864,

-     seagreen: 3050327,

-     seashell: 16774638,

-     sienna: 10506797,

-     silver: 12632256,

-     skyblue: 8900331,

-     slateblue: 6970061,

-     slategray: 7372944,

-     slategrey: 7372944,

-     snow: 16775930,

-     springgreen: 65407,

-     steelblue: 4620980,

-     tan: 13808780,

-     teal: 32896,

-     thistle: 14204888,

-     tomato: 16737095,

-     turquoise: 4251856,

-     violet: 15631086,

-     wheat: 16113331,

-     white: 16777215,

-     whitesmoke: 16119285,

-     yellow: 16776960,

-     yellowgreen: 10145074

-   });

-   d3_rgb_names.forEach(function(key, value) {

-     d3_rgb_names.set(key, d3_rgbNumber(value));

-   });

-   function d3_functor(v) {

-     return typeof v === "function" ? v : function() {

-       return v;

-     };

-   }

-   d3.functor = d3_functor;

-   d3.xhr = d3_xhrType(d3_identity);

-   function d3_xhrType(response) {

-     return function(url, mimeType, callback) {

-       if (arguments.length === 2 && typeof mimeType === "function") callback = mimeType,

-       mimeType = null;

-       return d3_xhr(url, mimeType, response, callback);

-     };

-   }

-   function d3_xhr(url, mimeType, response, callback) {

-     var xhr = {}, dispatch = d3.dispatch("beforesend", "progress", "load", "error"), headers = {}, request = new XMLHttpRequest(), responseType = null;

-     if (this.XDomainRequest && !("withCredentials" in request) && /^(http(s)?:)?\/\//.test(url)) request = new XDomainRequest();

-     "onload" in request ? request.onload = request.onerror = respond : request.onreadystatechange = function() {

-       request.readyState > 3 && respond();

-     };

-     function respond() {

-       var status = request.status, result;

-       if (!status && d3_xhrHasResponse(request) || status >= 200 && status < 300 || status === 304) {

-         try {

-           result = response.call(xhr, request);

-         } catch (e) {

-           dispatch.error.call(xhr, e);

-           return;

-         }

-         dispatch.load.call(xhr, result);

-       } else {

-         dispatch.error.call(xhr, request);

-       }

-     }

-     request.onprogress = function(event) {

-       var o = d3.event;

-       d3.event = event;

-       try {

-         dispatch.progress.call(xhr, request);

-       } finally {

-         d3.event = o;

-       }

-     };

-     xhr.header = function(name, value) {

-       name = (name + "").toLowerCase();

-       if (arguments.length < 2) return headers[name];

-       if (value == null) delete headers[name]; else headers[name] = value + "";

-       return xhr;

-     };

-     xhr.mimeType = function(value) {

-       if (!arguments.length) return mimeType;

-       mimeType = value == null ? null : value + "";

-       return xhr;

-     };

-     xhr.responseType = function(value) {

-       if (!arguments.length) return responseType;

-       responseType = value;

-       return xhr;

-     };

-     xhr.response = function(value) {

-       response = value;

-       return xhr;

-     };

-     [ "get", "post" ].forEach(function(method) {

-       xhr[method] = function() {

-         return xhr.send.apply(xhr, [ method ].concat(d3_array(arguments)));

-       };

-     });

-     xhr.send = function(method, data, callback) {

-       if (arguments.length === 2 && typeof data === "function") callback = data, data = null;

-       request.open(method, url, true);

-       if (mimeType != null && !("accept" in headers)) headers["accept"] = mimeType + ",*/*";

-       if (request.setRequestHeader) for (var name in headers) request.setRequestHeader(name, headers[name]);

-       if (mimeType != null && request.overrideMimeType) request.overrideMimeType(mimeType);

-       if (responseType != null) request.responseType = responseType;

-       if (callback != null) xhr.on("error", callback).on("load", function(request) {

-         callback(null, request);

-       });

-       dispatch.beforesend.call(xhr, request);

-       request.send(data == null ? null : data);

-       return xhr;

-     };

-     xhr.abort = function() {

-       request.abort();

-       return xhr;

-     };

-     d3.rebind(xhr, dispatch, "on");

-     return callback == null ? xhr : xhr.get(d3_xhr_fixCallback(callback));

-   }

-   function d3_xhr_fixCallback(callback) {

-     return callback.length === 1 ? function(error, request) {

-       callback(error == null ? request : null);

-     } : callback;

-   }

-   function d3_xhrHasResponse(request) {

-     var type = request.responseType;

-     return type && type !== "text" ? request.response : request.responseText;

-   }

-   d3.dsv = function(delimiter, mimeType) {

-     var reFormat = new RegExp('["' + delimiter + "\n]"), delimiterCode = delimiter.charCodeAt(0);

-     function dsv(url, row, callback) {

-       if (arguments.length < 3) callback = row, row = null;

-       var xhr = d3_xhr(url, mimeType, row == null ? response : typedResponse(row), callback);

-       xhr.row = function(_) {

-         return arguments.length ? xhr.response((row = _) == null ? response : typedResponse(_)) : row;

-       };

-       return xhr;

-     }

-     function response(request) {

-       return dsv.parse(request.responseText);

-     }

-     function typedResponse(f) {

-       return function(request) {

-         return dsv.parse(request.responseText, f);

-       };

-     }

-     dsv.parse = function(text, f) {

-       var o;

-       return dsv.parseRows(text, function(row, i) {

-         if (o) return o(row, i - 1);

-         var a = new Function("d", "return {" + row.map(function(name, i) {

-           return JSON.stringify(name) + ": d[" + i + "]";

-         }).join(",") + "}");

-         o = f ? function(row, i) {

-           return f(a(row), i);

-         } : a;

-       });

-     };

-     dsv.parseRows = function(text, f) {

-       var EOL = {}, EOF = {}, rows = [], N = text.length, I = 0, n = 0, t, eol;

-       function token() {

-         if (I >= N) return EOF;

-         if (eol) return eol = false, EOL;

-         var j = I;

-         if (text.charCodeAt(j) === 34) {

-           var i = j;

-           while (i++ < N) {

-             if (text.charCodeAt(i) === 34) {

-               if (text.charCodeAt(i + 1) !== 34) break;

-               ++i;

-             }

-           }

-           I = i + 2;

-           var c = text.charCodeAt(i + 1);

-           if (c === 13) {

-             eol = true;

-             if (text.charCodeAt(i + 2) === 10) ++I;

-           } else if (c === 10) {

-             eol = true;

-           }

-           return text.slice(j + 1, i).replace(/""/g, '"');

-         }

-         while (I < N) {

-           var c = text.charCodeAt(I++), k = 1;

-           if (c === 10) eol = true; else if (c === 13) {

-             eol = true;

-             if (text.charCodeAt(I) === 10) ++I, ++k;

-           } else if (c !== delimiterCode) continue;

-           return text.slice(j, I - k);

-         }

-         return text.slice(j);

-       }

-       while ((t = token()) !== EOF) {

-         var a = [];

-         while (t !== EOL && t !== EOF) {

-           a.push(t);

-           t = token();

-         }

-         if (f && (a = f(a, n++)) == null) continue;

-         rows.push(a);

-       }

-       return rows;

-     };

-     dsv.format = function(rows) {

-       if (Array.isArray(rows[0])) return dsv.formatRows(rows);

-       var fieldSet = new d3_Set(), fields = [];

-       rows.forEach(function(row) {

-         for (var field in row) {

-           if (!fieldSet.has(field)) {

-             fields.push(fieldSet.add(field));

-           }

-         }

-       });

-       return [ fields.map(formatValue).join(delimiter) ].concat(rows.map(function(row) {

-         return fields.map(function(field) {

-           return formatValue(row[field]);

-         }).join(delimiter);

-       })).join("\n");

-     };

-     dsv.formatRows = function(rows) {

-       return rows.map(formatRow).join("\n");

-     };

-     function formatRow(row) {

-       return row.map(formatValue).join(delimiter);

-     }

-     function formatValue(text) {

-       return reFormat.test(text) ? '"' + text.replace(/\"/g, '""') + '"' : text;

-     }

-     return dsv;

-   };

-   d3.csv = d3.dsv(",", "text/csv");

-   d3.tsv = d3.dsv("	", "text/tab-separated-values");

-   var d3_timer_queueHead, d3_timer_queueTail, d3_timer_interval, d3_timer_timeout, d3_timer_frame = this[d3_vendorSymbol(this, "requestAnimationFrame")] || function(callback) {

-     setTimeout(callback, 17);

-   };

-   d3.timer = function() {

-     d3_timer.apply(this, arguments);

-   };

-   function d3_timer(callback, delay, then) {

-     var n = arguments.length;

-     if (n < 2) delay = 0;

-     if (n < 3) then = Date.now();

-     var time = then + delay, timer = {

-       c: callback,

-       t: time,

-       n: null

-     };

-     if (d3_timer_queueTail) d3_timer_queueTail.n = timer; else d3_timer_queueHead = timer;

-     d3_timer_queueTail = timer;

-     if (!d3_timer_interval) {

-       d3_timer_timeout = clearTimeout(d3_timer_timeout);

-       d3_timer_interval = 1;

-       d3_timer_frame(d3_timer_step);

-     }

-     return timer;

-   }

-   function d3_timer_step() {

-     var now = d3_timer_mark(), delay = d3_timer_sweep() - now;

-     if (delay > 24) {

-       if (isFinite(delay)) {

-         clearTimeout(d3_timer_timeout);

-         d3_timer_timeout = setTimeout(d3_timer_step, delay);

-       }

-       d3_timer_interval = 0;

-     } else {

-       d3_timer_interval = 1;

-       d3_timer_frame(d3_timer_step);

-     }

-   }

-   d3.timer.flush = function() {

-     d3_timer_mark();

-     d3_timer_sweep();

-   };

-   function d3_timer_mark() {

-     var now = Date.now(), timer = d3_timer_queueHead;

-     while (timer) {

-       if (now >= timer.t && timer.c(now - timer.t)) timer.c = null;

-       timer = timer.n;

-     }

-     return now;

-   }

-   function d3_timer_sweep() {

-     var t0, t1 = d3_timer_queueHead, time = Infinity;

-     while (t1) {

-       if (t1.c) {

-         if (t1.t < time) time = t1.t;

-         t1 = (t0 = t1).n;

-       } else {

-         t1 = t0 ? t0.n = t1.n : d3_timer_queueHead = t1.n;

-       }

-     }

-     d3_timer_queueTail = t0;

-     return time;

-   }

-   function d3_format_precision(x, p) {

-     return p - (x ? Math.ceil(Math.log(x) / Math.LN10) : 1);

-   }

-   d3.round = function(x, n) {

-     return n ? Math.round(x * (n = Math.pow(10, n))) / n : Math.round(x);

-   };

-   var d3_formatPrefixes = [ "y", "z", "a", "f", "p", "n", "µ", "m", "", "k", "M", "G", "T", "P", "E", "Z", "Y" ].map(d3_formatPrefix);

-   d3.formatPrefix = function(value, precision) {

-     var i = 0;

-     if (value = +value) {

-       if (value < 0) value *= -1;

-       if (precision) value = d3.round(value, d3_format_precision(value, precision));

-       i = 1 + Math.floor(1e-12 + Math.log(value) / Math.LN10);

-       i = Math.max(-24, Math.min(24, Math.floor((i - 1) / 3) * 3));

-     }

-     return d3_formatPrefixes[8 + i / 3];

-   };

-   function d3_formatPrefix(d, i) {

-     var k = Math.pow(10, abs(8 - i) * 3);

-     return {

-       scale: i > 8 ? function(d) {

-         return d / k;

-       } : function(d) {

-         return d * k;

-       },

-       symbol: d

-     };

-   }

-   function d3_locale_numberFormat(locale) {

-     var locale_decimal = locale.decimal, locale_thousands = locale.thousands, locale_grouping = locale.grouping, locale_currency = locale.currency, formatGroup = locale_grouping && locale_thousands ? function(value, width) {

-       var i = value.length, t = [], j = 0, g = locale_grouping[0], length = 0;

-       while (i > 0 && g > 0) {

-         if (length + g + 1 > width) g = Math.max(1, width - length);

-         t.push(value.substring(i -= g, i + g));

-         if ((length += g + 1) > width) break;

-         g = locale_grouping[j = (j + 1) % locale_grouping.length];

-       }

-       return t.reverse().join(locale_thousands);

-     } : d3_identity;

-     return function(specifier) {

-       var match = d3_format_re.exec(specifier), fill = match[1] || " ", align = match[2] || ">", sign = match[3] || "-", symbol = match[4] || "", zfill = match[5], width = +match[6], comma = match[7], precision = match[8], type = match[9], scale = 1, prefix = "", suffix = "", integer = false, exponent = true;

-       if (precision) precision = +precision.substring(1);

-       if (zfill || fill === "0" && align === "=") {

-         zfill = fill = "0";

-         align = "=";

-       }

-       switch (type) {

-        case "n":

-         comma = true;

-         type = "g";

-         break;

- 

-        case "%":

-         scale = 100;

-         suffix = "%";

-         type = "f";

-         break;

- 

-        case "p":

-         scale = 100;

-         suffix = "%";

-         type = "r";

-         break;

- 

-        case "b":

-        case "o":

-        case "x":

-        case "X":

-         if (symbol === "#") prefix = "0" + type.toLowerCase();

- 

-        case "c":

-         exponent = false;

- 

-        case "d":

-         integer = true;

-         precision = 0;

-         break;

- 

-        case "s":

-         scale = -1;

-         type = "r";

-         break;

-       }

-       if (symbol === "$") prefix = locale_currency[0], suffix = locale_currency[1];

-       if (type == "r" && !precision) type = "g";

-       if (precision != null) {

-         if (type == "g") precision = Math.max(1, Math.min(21, precision)); else if (type == "e" || type == "f") precision = Math.max(0, Math.min(20, precision));

-       }

-       type = d3_format_types.get(type) || d3_format_typeDefault;

-       var zcomma = zfill && comma;

-       return function(value) {

-         var fullSuffix = suffix;

-         if (integer && value % 1) return "";

-         var negative = value < 0 || value === 0 && 1 / value < 0 ? (value = -value, "-") : sign === "-" ? "" : sign;

-         if (scale < 0) {

-           var unit = d3.formatPrefix(value, precision);

-           value = unit.scale(value);

-           fullSuffix = unit.symbol + suffix;

-         } else {

-           value *= scale;

-         }

-         value = type(value, precision);

-         var i = value.lastIndexOf("."), before, after;

-         if (i < 0) {

-           var j = exponent ? value.lastIndexOf("e") : -1;

-           if (j < 0) before = value, after = ""; else before = value.substring(0, j), after = value.substring(j);

-         } else {

-           before = value.substring(0, i);

-           after = locale_decimal + value.substring(i + 1);

-         }

-         if (!zfill && comma) before = formatGroup(before, Infinity);

-         var length = prefix.length + before.length + after.length + (zcomma ? 0 : negative.length), padding = length < width ? new Array(length = width - length + 1).join(fill) : "";

-         if (zcomma) before = formatGroup(padding + before, padding.length ? width - after.length : Infinity);

-         negative += prefix;

-         value = before + after;

-         return (align === "<" ? negative + value + padding : align === ">" ? padding + negative + value : align === "^" ? padding.substring(0, length >>= 1) + negative + value + padding.substring(length) : negative + (zcomma ? value : padding + value)) + fullSuffix;

-       };

-     };

-   }

-   var d3_format_re = /(?:([^{])?([<>=^]))?([+\- ])?([$#])?(0)?(\d+)?(,)?(\.-?\d+)?([a-z%])?/i;

-   var d3_format_types = d3.map({

-     b: function(x) {

-       return x.toString(2);

-     },

-     c: function(x) {

-       return String.fromCharCode(x);

-     },

-     o: function(x) {

-       return x.toString(8);

-     },

-     x: function(x) {

-       return x.toString(16);

-     },

-     X: function(x) {

-       return x.toString(16).toUpperCase();

-     },

-     g: function(x, p) {

-       return x.toPrecision(p);

-     },

-     e: function(x, p) {

-       return x.toExponential(p);

-     },

-     f: function(x, p) {

-       return x.toFixed(p);

-     },

-     r: function(x, p) {

-       return (x = d3.round(x, d3_format_precision(x, p))).toFixed(Math.max(0, Math.min(20, d3_format_precision(x * (1 + 1e-15), p))));

-     }

-   });

-   function d3_format_typeDefault(x) {

-     return x + "";

-   }

-   var d3_time = d3.time = {}, d3_date = Date;

-   function d3_date_utc() {

-     this._ = new Date(arguments.length > 1 ? Date.UTC.apply(this, arguments) : arguments[0]);

-   }

-   d3_date_utc.prototype = {

-     getDate: function() {

-       return this._.getUTCDate();

-     },

-     getDay: function() {

-       return this._.getUTCDay();

-     },

-     getFullYear: function() {

-       return this._.getUTCFullYear();

-     },

-     getHours: function() {

-       return this._.getUTCHours();

-     },

-     getMilliseconds: function() {

-       return this._.getUTCMilliseconds();

-     },

-     getMinutes: function() {

-       return this._.getUTCMinutes();

-     },

-     getMonth: function() {

-       return this._.getUTCMonth();

-     },

-     getSeconds: function() {

-       return this._.getUTCSeconds();

-     },

-     getTime: function() {

-       return this._.getTime();

-     },

-     getTimezoneOffset: function() {

-       return 0;

-     },

-     valueOf: function() {

-       return this._.valueOf();

-     },

-     setDate: function() {

-       d3_time_prototype.setUTCDate.apply(this._, arguments);

-     },

-     setDay: function() {

-       d3_time_prototype.setUTCDay.apply(this._, arguments);

-     },

-     setFullYear: function() {

-       d3_time_prototype.setUTCFullYear.apply(this._, arguments);

-     },

-     setHours: function() {

-       d3_time_prototype.setUTCHours.apply(this._, arguments);

-     },

-     setMilliseconds: function() {

-       d3_time_prototype.setUTCMilliseconds.apply(this._, arguments);

-     },

-     setMinutes: function() {

-       d3_time_prototype.setUTCMinutes.apply(this._, arguments);

-     },

-     setMonth: function() {

-       d3_time_prototype.setUTCMonth.apply(this._, arguments);

-     },

-     setSeconds: function() {

-       d3_time_prototype.setUTCSeconds.apply(this._, arguments);

-     },

-     setTime: function() {

-       d3_time_prototype.setTime.apply(this._, arguments);

-     }

-   };

-   var d3_time_prototype = Date.prototype;

-   function d3_time_interval(local, step, number) {

-     function round(date) {

-       var d0 = local(date), d1 = offset(d0, 1);

-       return date - d0 < d1 - date ? d0 : d1;

-     }

-     function ceil(date) {

-       step(date = local(new d3_date(date - 1)), 1);

-       return date;

-     }

-     function offset(date, k) {

-       step(date = new d3_date(+date), k);

-       return date;

-     }

-     function range(t0, t1, dt) {

-       var time = ceil(t0), times = [];

-       if (dt > 1) {

-         while (time < t1) {

-           if (!(number(time) % dt)) times.push(new Date(+time));

-           step(time, 1);

-         }

-       } else {

-         while (time < t1) times.push(new Date(+time)), step(time, 1);

-       }

-       return times;

-     }

-     function range_utc(t0, t1, dt) {

-       try {

-         d3_date = d3_date_utc;

-         var utc = new d3_date_utc();

-         utc._ = t0;

-         return range(utc, t1, dt);

-       } finally {

-         d3_date = Date;

-       }

-     }

-     local.floor = local;

-     local.round = round;

-     local.ceil = ceil;

-     local.offset = offset;

-     local.range = range;

-     var utc = local.utc = d3_time_interval_utc(local);

-     utc.floor = utc;

-     utc.round = d3_time_interval_utc(round);

-     utc.ceil = d3_time_interval_utc(ceil);

-     utc.offset = d3_time_interval_utc(offset);

-     utc.range = range_utc;

-     return local;

-   }

-   function d3_time_interval_utc(method) {

-     return function(date, k) {

-       try {

-         d3_date = d3_date_utc;

-         var utc = new d3_date_utc();

-         utc._ = date;

-         return method(utc, k)._;

-       } finally {

-         d3_date = Date;

-       }

-     };

-   }

-   d3_time.year = d3_time_interval(function(date) {

-     date = d3_time.day(date);

-     date.setMonth(0, 1);

-     return date;

-   }, function(date, offset) {

-     date.setFullYear(date.getFullYear() + offset);

-   }, function(date) {

-     return date.getFullYear();

-   });

-   d3_time.years = d3_time.year.range;

-   d3_time.years.utc = d3_time.year.utc.range;

-   d3_time.day = d3_time_interval(function(date) {

-     var day = new d3_date(2e3, 0);

-     day.setFullYear(date.getFullYear(), date.getMonth(), date.getDate());

-     return day;

-   }, function(date, offset) {

-     date.setDate(date.getDate() + offset);

-   }, function(date) {

-     return date.getDate() - 1;

-   });

-   d3_time.days = d3_time.day.range;

-   d3_time.days.utc = d3_time.day.utc.range;

-   d3_time.dayOfYear = function(date) {

-     var year = d3_time.year(date);

-     return Math.floor((date - year - (date.getTimezoneOffset() - year.getTimezoneOffset()) * 6e4) / 864e5);

-   };

-   [ "sunday", "monday", "tuesday", "wednesday", "thursday", "friday", "saturday" ].forEach(function(day, i) {

-     i = 7 - i;

-     var interval = d3_time[day] = d3_time_interval(function(date) {

-       (date = d3_time.day(date)).setDate(date.getDate() - (date.getDay() + i) % 7);

-       return date;

-     }, function(date, offset) {

-       date.setDate(date.getDate() + Math.floor(offset) * 7);

-     }, function(date) {

-       var day = d3_time.year(date).getDay();

-       return Math.floor((d3_time.dayOfYear(date) + (day + i) % 7) / 7) - (day !== i);

-     });

-     d3_time[day + "s"] = interval.range;

-     d3_time[day + "s"].utc = interval.utc.range;

-     d3_time[day + "OfYear"] = function(date) {

-       var day = d3_time.year(date).getDay();

-       return Math.floor((d3_time.dayOfYear(date) + (day + i) % 7) / 7);

-     };

-   });

-   d3_time.week = d3_time.sunday;

-   d3_time.weeks = d3_time.sunday.range;

-   d3_time.weeks.utc = d3_time.sunday.utc.range;

-   d3_time.weekOfYear = d3_time.sundayOfYear;

-   function d3_locale_timeFormat(locale) {

-     var locale_dateTime = locale.dateTime, locale_date = locale.date, locale_time = locale.time, locale_periods = locale.periods, locale_days = locale.days, locale_shortDays = locale.shortDays, locale_months = locale.months, locale_shortMonths = locale.shortMonths;

-     function d3_time_format(template) {

-       var n = template.length;

-       function format(date) {

-         var string = [], i = -1, j = 0, c, p, f;

-         while (++i < n) {

-           if (template.charCodeAt(i) === 37) {

-             string.push(template.slice(j, i));

-             if ((p = d3_time_formatPads[c = template.charAt(++i)]) != null) c = template.charAt(++i);

-             if (f = d3_time_formats[c]) c = f(date, p == null ? c === "e" ? " " : "0" : p);

-             string.push(c);

-             j = i + 1;

-           }

-         }

-         string.push(template.slice(j, i));

-         return string.join("");

-       }

-       format.parse = function(string) {

-         var d = {

-           y: 1900,

-           m: 0,

-           d: 1,

-           H: 0,

-           M: 0,

-           S: 0,

-           L: 0,

-           Z: null

-         }, i = d3_time_parse(d, template, string, 0);

-         if (i != string.length) return null;

-         if ("p" in d) d.H = d.H % 12 + d.p * 12;

-         var localZ = d.Z != null && d3_date !== d3_date_utc, date = new (localZ ? d3_date_utc : d3_date)();

-         if ("j" in d) date.setFullYear(d.y, 0, d.j); else if ("W" in d || "U" in d) {

-           if (!("w" in d)) d.w = "W" in d ? 1 : 0;

-           date.setFullYear(d.y, 0, 1);

-           date.setFullYear(d.y, 0, "W" in d ? (d.w + 6) % 7 + d.W * 7 - (date.getDay() + 5) % 7 : d.w + d.U * 7 - (date.getDay() + 6) % 7);

-         } else date.setFullYear(d.y, d.m, d.d);

-         date.setHours(d.H + (d.Z / 100 | 0), d.M + d.Z % 100, d.S, d.L);

-         return localZ ? date._ : date;

-       };

-       format.toString = function() {

-         return template;

-       };

-       return format;

-     }

-     function d3_time_parse(date, template, string, j) {

-       var c, p, t, i = 0, n = template.length, m = string.length;

-       while (i < n) {

-         if (j >= m) return -1;

-         c = template.charCodeAt(i++);

-         if (c === 37) {

-           t = template.charAt(i++);

-           p = d3_time_parsers[t in d3_time_formatPads ? template.charAt(i++) : t];

-           if (!p || (j = p(date, string, j)) < 0) return -1;

-         } else if (c != string.charCodeAt(j++)) {

-           return -1;

-         }

-       }

-       return j;

-     }

-     d3_time_format.utc = function(template) {

-       var local = d3_time_format(template);

-       function format(date) {

-         try {

-           d3_date = d3_date_utc;

-           var utc = new d3_date();

-           utc._ = date;

-           return local(utc);

-         } finally {

-           d3_date = Date;

-         }

-       }

-       format.parse = function(string) {

-         try {

-           d3_date = d3_date_utc;

-           var date = local.parse(string);

-           return date && date._;

-         } finally {

-           d3_date = Date;

-         }

-       };

-       format.toString = local.toString;

-       return format;

-     };

-     d3_time_format.multi = d3_time_format.utc.multi = d3_time_formatMulti;

-     var d3_time_periodLookup = d3.map(), d3_time_dayRe = d3_time_formatRe(locale_days), d3_time_dayLookup = d3_time_formatLookup(locale_days), d3_time_dayAbbrevRe = d3_time_formatRe(locale_shortDays), d3_time_dayAbbrevLookup = d3_time_formatLookup(locale_shortDays), d3_time_monthRe = d3_time_formatRe(locale_months), d3_time_monthLookup = d3_time_formatLookup(locale_months), d3_time_monthAbbrevRe = d3_time_formatRe(locale_shortMonths), d3_time_monthAbbrevLookup = d3_time_formatLookup(locale_shortMonths);

-     locale_periods.forEach(function(p, i) {

-       d3_time_periodLookup.set(p.toLowerCase(), i);

-     });

-     var d3_time_formats = {

-       a: function(d) {

-         return locale_shortDays[d.getDay()];

-       },

-       A: function(d) {

-         return locale_days[d.getDay()];

-       },

-       b: function(d) {

-         return locale_shortMonths[d.getMonth()];

-       },

-       B: function(d) {

-         return locale_months[d.getMonth()];

-       },

-       c: d3_time_format(locale_dateTime),

-       d: function(d, p) {

-         return d3_time_formatPad(d.getDate(), p, 2);

-       },

-       e: function(d, p) {

-         return d3_time_formatPad(d.getDate(), p, 2);

-       },

-       H: function(d, p) {

-         return d3_time_formatPad(d.getHours(), p, 2);

-       },

-       I: function(d, p) {

-         return d3_time_formatPad(d.getHours() % 12 || 12, p, 2);

-       },

-       j: function(d, p) {

-         return d3_time_formatPad(1 + d3_time.dayOfYear(d), p, 3);

-       },

-       L: function(d, p) {

-         return d3_time_formatPad(d.getMilliseconds(), p, 3);

-       },

-       m: function(d, p) {

-         return d3_time_formatPad(d.getMonth() + 1, p, 2);

-       },

-       M: function(d, p) {

-         return d3_time_formatPad(d.getMinutes(), p, 2);

-       },

-       p: function(d) {

-         return locale_periods[+(d.getHours() >= 12)];

-       },

-       S: function(d, p) {

-         return d3_time_formatPad(d.getSeconds(), p, 2);

-       },

-       U: function(d, p) {

-         return d3_time_formatPad(d3_time.sundayOfYear(d), p, 2);

-       },

-       w: function(d) {

-         return d.getDay();

-       },

-       W: function(d, p) {

-         return d3_time_formatPad(d3_time.mondayOfYear(d), p, 2);

-       },

-       x: d3_time_format(locale_date),

-       X: d3_time_format(locale_time),

-       y: function(d, p) {

-         return d3_time_formatPad(d.getFullYear() % 100, p, 2);

-       },

-       Y: function(d, p) {

-         return d3_time_formatPad(d.getFullYear() % 1e4, p, 4);

-       },

-       Z: d3_time_zone,

-       "%": function() {

-         return "%";

-       }

-     };

-     var d3_time_parsers = {

-       a: d3_time_parseWeekdayAbbrev,

-       A: d3_time_parseWeekday,

-       b: d3_time_parseMonthAbbrev,

-       B: d3_time_parseMonth,

-       c: d3_time_parseLocaleFull,

-       d: d3_time_parseDay,

-       e: d3_time_parseDay,

-       H: d3_time_parseHour24,

-       I: d3_time_parseHour24,

-       j: d3_time_parseDayOfYear,

-       L: d3_time_parseMilliseconds,

-       m: d3_time_parseMonthNumber,

-       M: d3_time_parseMinutes,

-       p: d3_time_parseAmPm,

-       S: d3_time_parseSeconds,

-       U: d3_time_parseWeekNumberSunday,

-       w: d3_time_parseWeekdayNumber,

-       W: d3_time_parseWeekNumberMonday,

-       x: d3_time_parseLocaleDate,

-       X: d3_time_parseLocaleTime,

-       y: d3_time_parseYear,

-       Y: d3_time_parseFullYear,

-       Z: d3_time_parseZone,

-       "%": d3_time_parseLiteralPercent

-     };

-     function d3_time_parseWeekdayAbbrev(date, string, i) {

-       d3_time_dayAbbrevRe.lastIndex = 0;

-       var n = d3_time_dayAbbrevRe.exec(string.slice(i));

-       return n ? (date.w = d3_time_dayAbbrevLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;

-     }

-     function d3_time_parseWeekday(date, string, i) {

-       d3_time_dayRe.lastIndex = 0;

-       var n = d3_time_dayRe.exec(string.slice(i));

-       return n ? (date.w = d3_time_dayLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;

-     }

-     function d3_time_parseMonthAbbrev(date, string, i) {

-       d3_time_monthAbbrevRe.lastIndex = 0;

-       var n = d3_time_monthAbbrevRe.exec(string.slice(i));

-       return n ? (date.m = d3_time_monthAbbrevLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;

-     }

-     function d3_time_parseMonth(date, string, i) {

-       d3_time_monthRe.lastIndex = 0;

-       var n = d3_time_monthRe.exec(string.slice(i));

-       return n ? (date.m = d3_time_monthLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;

-     }

-     function d3_time_parseLocaleFull(date, string, i) {

-       return d3_time_parse(date, d3_time_formats.c.toString(), string, i);

-     }

-     function d3_time_parseLocaleDate(date, string, i) {

-       return d3_time_parse(date, d3_time_formats.x.toString(), string, i);

-     }

-     function d3_time_parseLocaleTime(date, string, i) {

-       return d3_time_parse(date, d3_time_formats.X.toString(), string, i);

-     }

-     function d3_time_parseAmPm(date, string, i) {

-       var n = d3_time_periodLookup.get(string.slice(i, i += 2).toLowerCase());

-       return n == null ? -1 : (date.p = n, i);

-     }

-     return d3_time_format;

-   }

-   var d3_time_formatPads = {

-     "-": "",

-     _: " ",

-     "0": "0"

-   }, d3_time_numberRe = /^\s*\d+/, d3_time_percentRe = /^%/;

-   function d3_time_formatPad(value, fill, width) {

-     var sign = value < 0 ? "-" : "", string = (sign ? -value : value) + "", length = string.length;

-     return sign + (length < width ? new Array(width - length + 1).join(fill) + string : string);

-   }

-   function d3_time_formatRe(names) {

-     return new RegExp("^(?:" + names.map(d3.requote).join("|") + ")", "i");

-   }

-   function d3_time_formatLookup(names) {

-     var map = new d3_Map(), i = -1, n = names.length;

-     while (++i < n) map.set(names[i].toLowerCase(), i);

-     return map;

-   }

-   function d3_time_parseWeekdayNumber(date, string, i) {

-     d3_time_numberRe.lastIndex = 0;

-     var n = d3_time_numberRe.exec(string.slice(i, i + 1));

-     return n ? (date.w = +n[0], i + n[0].length) : -1;

-   }

-   function d3_time_parseWeekNumberSunday(date, string, i) {

-     d3_time_numberRe.lastIndex = 0;

-     var n = d3_time_numberRe.exec(string.slice(i));

-     return n ? (date.U = +n[0], i + n[0].length) : -1;

-   }

-   function d3_time_parseWeekNumberMonday(date, string, i) {

-     d3_time_numberRe.lastIndex = 0;

-     var n = d3_time_numberRe.exec(string.slice(i));

-     return n ? (date.W = +n[0], i + n[0].length) : -1;

-   }

-   function d3_time_parseFullYear(date, string, i) {

-     d3_time_numberRe.lastIndex = 0;

-     var n = d3_time_numberRe.exec(string.slice(i, i + 4));

-     return n ? (date.y = +n[0], i + n[0].length) : -1;

-   }

-   function d3_time_parseYear(date, string, i) {

-     d3_time_numberRe.lastIndex = 0;

-     var n = d3_time_numberRe.exec(string.slice(i, i + 2));

-     return n ? (date.y = d3_time_expandYear(+n[0]), i + n[0].length) : -1;

-   }

-   function d3_time_parseZone(date, string, i) {

-     return /^[+-]\d{4}$/.test(string = string.slice(i, i + 5)) ? (date.Z = -string,

-     i + 5) : -1;

-   }

-   function d3_time_expandYear(d) {

-     return d + (d > 68 ? 1900 : 2e3);

-   }

-   function d3_time_parseMonthNumber(date, string, i) {

-     d3_time_numberRe.lastIndex = 0;

-     var n = d3_time_numberRe.exec(string.slice(i, i + 2));

-     return n ? (date.m = n[0] - 1, i + n[0].length) : -1;

-   }

-   function d3_time_parseDay(date, string, i) {

-     d3_time_numberRe.lastIndex = 0;

-     var n = d3_time_numberRe.exec(string.slice(i, i + 2));

-     return n ? (date.d = +n[0], i + n[0].length) : -1;

-   }

-   function d3_time_parseDayOfYear(date, string, i) {

-     d3_time_numberRe.lastIndex = 0;

-     var n = d3_time_numberRe.exec(string.slice(i, i + 3));

-     return n ? (date.j = +n[0], i + n[0].length) : -1;

-   }

-   function d3_time_parseHour24(date, string, i) {

-     d3_time_numberRe.lastIndex = 0;

-     var n = d3_time_numberRe.exec(string.slice(i, i + 2));

-     return n ? (date.H = +n[0], i + n[0].length) : -1;

-   }

-   function d3_time_parseMinutes(date, string, i) {

-     d3_time_numberRe.lastIndex = 0;

-     var n = d3_time_numberRe.exec(string.slice(i, i + 2));

-     return n ? (date.M = +n[0], i + n[0].length) : -1;

-   }

-   function d3_time_parseSeconds(date, string, i) {

-     d3_time_numberRe.lastIndex = 0;

-     var n = d3_time_numberRe.exec(string.slice(i, i + 2));

-     return n ? (date.S = +n[0], i + n[0].length) : -1;

-   }

-   function d3_time_parseMilliseconds(date, string, i) {

-     d3_time_numberRe.lastIndex = 0;

-     var n = d3_time_numberRe.exec(string.slice(i, i + 3));

-     return n ? (date.L = +n[0], i + n[0].length) : -1;

-   }

-   function d3_time_zone(d) {

-     var z = d.getTimezoneOffset(), zs = z > 0 ? "-" : "+", zh = abs(z) / 60 | 0, zm = abs(z) % 60;

-     return zs + d3_time_formatPad(zh, "0", 2) + d3_time_formatPad(zm, "0", 2);

-   }

-   function d3_time_parseLiteralPercent(date, string, i) {

-     d3_time_percentRe.lastIndex = 0;

-     var n = d3_time_percentRe.exec(string.slice(i, i + 1));

-     return n ? i + n[0].length : -1;

-   }

-   function d3_time_formatMulti(formats) {

-     var n = formats.length, i = -1;

-     while (++i < n) formats[i][0] = this(formats[i][0]);

-     return function(date) {

-       var i = 0, f = formats[i];

-       while (!f[1](date)) f = formats[++i];

-       return f[0](date);

-     };

-   }

-   d3.locale = function(locale) {

-     return {

-       numberFormat: d3_locale_numberFormat(locale),

-       timeFormat: d3_locale_timeFormat(locale)

-     };

-   };

-   var d3_locale_enUS = d3.locale({

-     decimal: ".",

-     thousands: ",",

-     grouping: [ 3 ],

-     currency: [ "$", "" ],

-     dateTime: "%a %b %e %X %Y",

-     date: "%m/%d/%Y",

-     time: "%H:%M:%S",

-     periods: [ "AM", "PM" ],

-     days: [ "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday" ],

-     shortDays: [ "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" ],

-     months: [ "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December" ],

-     shortMonths: [ "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec" ]

-   });

-   d3.format = d3_locale_enUS.numberFormat;

-   d3.geo = {};

-   function d3_adder() {}

-   d3_adder.prototype = {

-     s: 0,

-     t: 0,

-     add: function(y) {

-       d3_adderSum(y, this.t, d3_adderTemp);

-       d3_adderSum(d3_adderTemp.s, this.s, this);

-       if (this.s) this.t += d3_adderTemp.t; else this.s = d3_adderTemp.t;

-     },

-     reset: function() {

-       this.s = this.t = 0;

-     },

-     valueOf: function() {

-       return this.s;

-     }

-   };

-   var d3_adderTemp = new d3_adder();

-   function d3_adderSum(a, b, o) {

-     var x = o.s = a + b, bv = x - a, av = x - bv;

-     o.t = a - av + (b - bv);

-   }

-   d3.geo.stream = function(object, listener) {

-     if (object && d3_geo_streamObjectType.hasOwnProperty(object.type)) {

-       d3_geo_streamObjectType[object.type](object, listener);

-     } else {

-       d3_geo_streamGeometry(object, listener);

-     }

-   };

-   function d3_geo_streamGeometry(geometry, listener) {

-     if (geometry && d3_geo_streamGeometryType.hasOwnProperty(geometry.type)) {

-       d3_geo_streamGeometryType[geometry.type](geometry, listener);

-     }

-   }

-   var d3_geo_streamObjectType = {

-     Feature: function(feature, listener) {

-       d3_geo_streamGeometry(feature.geometry, listener);

-     },

-     FeatureCollection: function(object, listener) {

-       var features = object.features, i = -1, n = features.length;

-       while (++i < n) d3_geo_streamGeometry(features[i].geometry, listener);

-     }

-   };

-   var d3_geo_streamGeometryType = {

-     Sphere: function(object, listener) {

-       listener.sphere();

-     },

-     Point: function(object, listener) {

-       object = object.coordinates;

-       listener.point(object[0], object[1], object[2]);

-     },

-     MultiPoint: function(object, listener) {

-       var coordinates = object.coordinates, i = -1, n = coordinates.length;

-       while (++i < n) object = coordinates[i], listener.point(object[0], object[1], object[2]);

-     },

-     LineString: function(object, listener) {

-       d3_geo_streamLine(object.coordinates, listener, 0);

-     },

-     MultiLineString: function(object, listener) {

-       var coordinates = object.coordinates, i = -1, n = coordinates.length;

-       while (++i < n) d3_geo_streamLine(coordinates[i], listener, 0);

-     },

-     Polygon: function(object, listener) {

-       d3_geo_streamPolygon(object.coordinates, listener);

-     },

-     MultiPolygon: function(object, listener) {

-       var coordinates = object.coordinates, i = -1, n = coordinates.length;

-       while (++i < n) d3_geo_streamPolygon(coordinates[i], listener);

-     },

-     GeometryCollection: function(object, listener) {

-       var geometries = object.geometries, i = -1, n = geometries.length;

-       while (++i < n) d3_geo_streamGeometry(geometries[i], listener);

-     }

-   };

-   function d3_geo_streamLine(coordinates, listener, closed) {

-     var i = -1, n = coordinates.length - closed, coordinate;

-     listener.lineStart();

-     while (++i < n) coordinate = coordinates[i], listener.point(coordinate[0], coordinate[1], coordinate[2]);

-     listener.lineEnd();

-   }

-   function d3_geo_streamPolygon(coordinates, listener) {

-     var i = -1, n = coordinates.length;

-     listener.polygonStart();

-     while (++i < n) d3_geo_streamLine(coordinates[i], listener, 1);

-     listener.polygonEnd();

-   }

-   d3.geo.area = function(object) {

-     d3_geo_areaSum = 0;

-     d3.geo.stream(object, d3_geo_area);

-     return d3_geo_areaSum;

-   };

-   var d3_geo_areaSum, d3_geo_areaRingSum = new d3_adder();

-   var d3_geo_area = {

-     sphere: function() {

-       d3_geo_areaSum += 4 * π;

-     },

-     point: d3_noop,

-     lineStart: d3_noop,

-     lineEnd: d3_noop,

-     polygonStart: function() {

-       d3_geo_areaRingSum.reset();

-       d3_geo_area.lineStart = d3_geo_areaRingStart;

-     },

-     polygonEnd: function() {

-       var area = 2 * d3_geo_areaRingSum;

-       d3_geo_areaSum += area < 0 ? 4 * π + area : area;

-       d3_geo_area.lineStart = d3_geo_area.lineEnd = d3_geo_area.point = d3_noop;

-     }

-   };

-   function d3_geo_areaRingStart() {

-     var λ00, φ00, λ0, cosφ0, sinφ0;

-     d3_geo_area.point = function(λ, φ) {

-       d3_geo_area.point = nextPoint;

-       λ0 = (λ00 = λ) * d3_radians, cosφ0 = Math.cos(φ = (φ00 = φ) * d3_radians / 2 + π / 4),

-       sinφ0 = Math.sin(φ);

-     };

-     function nextPoint(λ, φ) {

-       λ *= d3_radians;

-       φ = φ * d3_radians / 2 + π / 4;

-       var dλ = λ - λ0, sdλ = dλ >= 0 ? 1 : -1, adλ = sdλ * dλ, cosφ = Math.cos(φ), sinφ = Math.sin(φ), k = sinφ0 * sinφ, u = cosφ0 * cosφ + k * Math.cos(adλ), v = k * sdλ * Math.sin(adλ);

-       d3_geo_areaRingSum.add(Math.atan2(v, u));

-       λ0 = λ, cosφ0 = cosφ, sinφ0 = sinφ;

-     }

-     d3_geo_area.lineEnd = function() {

-       nextPoint(λ00, φ00);

-     };

-   }

-   function d3_geo_cartesian(spherical) {

-     var λ = spherical[0], φ = spherical[1], cosφ = Math.cos(φ);

-     return [ cosφ * Math.cos(λ), cosφ * Math.sin(λ), Math.sin(φ) ];

-   }

-   function d3_geo_cartesianDot(a, b) {

-     return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];

-   }

-   function d3_geo_cartesianCross(a, b) {

-     return [ a[1] * b[2] - a[2] * b[1], a[2] * b[0] - a[0] * b[2], a[0] * b[1] - a[1] * b[0] ];

-   }

-   function d3_geo_cartesianAdd(a, b) {

-     a[0] += b[0];

-     a[1] += b[1];

-     a[2] += b[2];

-   }

-   function d3_geo_cartesianScale(vector, k) {

-     return [ vector[0] * k, vector[1] * k, vector[2] * k ];

-   }

-   function d3_geo_cartesianNormalize(d) {

-     var l = Math.sqrt(d[0] * d[0] + d[1] * d[1] + d[2] * d[2]);

-     d[0] /= l;

-     d[1] /= l;

-     d[2] /= l;

-   }

-   function d3_geo_spherical(cartesian) {

-     return [ Math.atan2(cartesian[1], cartesian[0]), d3_asin(cartesian[2]) ];

-   }

-   function d3_geo_sphericalEqual(a, b) {

-     return abs(a[0] - b[0]) < ε && abs(a[1] - b[1]) < ε;

-   }

-   d3.geo.bounds = function() {

-     var λ0, φ0, λ1, φ1, λ_, λ__, φ__, p0, dλSum, ranges, range;

-     var bound = {

-       point: point,

-       lineStart: lineStart,

-       lineEnd: lineEnd,

-       polygonStart: function() {

-         bound.point = ringPoint;

-         bound.lineStart = ringStart;

-         bound.lineEnd = ringEnd;

-         dλSum = 0;

-         d3_geo_area.polygonStart();

-       },

-       polygonEnd: function() {

-         d3_geo_area.polygonEnd();

-         bound.point = point;

-         bound.lineStart = lineStart;

-         bound.lineEnd = lineEnd;

-         if (d3_geo_areaRingSum < 0) λ0 = -(λ1 = 180), φ0 = -(φ1 = 90); else if (dλSum > ε) φ1 = 90; else if (dλSum < -ε) φ0 = -90;

-         range[0] = λ0, range[1] = λ1;

-       }

-     };

-     function point(λ, φ) {

-       ranges.push(range = [ λ0 = λ, λ1 = λ ]);

-       if (φ < φ0) φ0 = φ;

-       if (φ > φ1) φ1 = φ;

-     }

-     function linePoint(λ, φ) {

-       var p = d3_geo_cartesian([ λ * d3_radians, φ * d3_radians ]);

-       if (p0) {

-         var normal = d3_geo_cartesianCross(p0, p), equatorial = [ normal[1], -normal[0], 0 ], inflection = d3_geo_cartesianCross(equatorial, normal);

-         d3_geo_cartesianNormalize(inflection);

-         inflection = d3_geo_spherical(inflection);

-         var dλ = λ - λ_, s = dλ > 0 ? 1 : -1, λi = inflection[0] * d3_degrees * s, antimeridian = abs(dλ) > 180;

-         if (antimeridian ^ (s * λ_ < λi && λi < s * λ)) {

-           var φi = inflection[1] * d3_degrees;

-           if (φi > φ1) φ1 = φi;

-         } else if (λi = (λi + 360) % 360 - 180, antimeridian ^ (s * λ_ < λi && λi < s * λ)) {

-           var φi = -inflection[1] * d3_degrees;

-           if (φi < φ0) φ0 = φi;

-         } else {

-           if (φ < φ0) φ0 = φ;

-           if (φ > φ1) φ1 = φ;

-         }

-         if (antimeridian) {

-           if (λ < λ_) {

-             if (angle(λ0, λ) > angle(λ0, λ1)) λ1 = λ;

-           } else {

-             if (angle(λ, λ1) > angle(λ0, λ1)) λ0 = λ;

-           }

-         } else {

-           if (λ1 >= λ0) {

-             if (λ < λ0) λ0 = λ;

-             if (λ > λ1) λ1 = λ;

-           } else {

-             if (λ > λ_) {

-               if (angle(λ0, λ) > angle(λ0, λ1)) λ1 = λ;

-             } else {

-               if (angle(λ, λ1) > angle(λ0, λ1)) λ0 = λ;

-             }

-           }

-         }

-       } else {

-         point(λ, φ);

-       }

-       p0 = p, λ_ = λ;

-     }

-     function lineStart() {

-       bound.point = linePoint;

-     }

-     function lineEnd() {

-       range[0] = λ0, range[1] = λ1;

-       bound.point = point;

-       p0 = null;

-     }

-     function ringPoint(λ, φ) {

-       if (p0) {

-         var dλ = λ - λ_;

-         dλSum += abs(dλ) > 180 ? dλ + (dλ > 0 ? 360 : -360) : dλ;

-       } else λ__ = λ, φ__ = φ;

-       d3_geo_area.point(λ, φ);

-       linePoint(λ, φ);

-     }

-     function ringStart() {

-       d3_geo_area.lineStart();

-     }

-     function ringEnd() {

-       ringPoint(λ__, φ__);

-       d3_geo_area.lineEnd();

-       if (abs(dλSum) > ε) λ0 = -(λ1 = 180);

-       range[0] = λ0, range[1] = λ1;

-       p0 = null;

-     }

-     function angle(λ0, λ1) {

-       return (λ1 -= λ0) < 0 ? λ1 + 360 : λ1;

-     }

-     function compareRanges(a, b) {

-       return a[0] - b[0];

-     }

-     function withinRange(x, range) {

-       return range[0] <= range[1] ? range[0] <= x && x <= range[1] : x < range[0] || range[1] < x;

-     }

-     return function(feature) {

-       φ1 = λ1 = -(λ0 = φ0 = Infinity);

-       ranges = [];

-       d3.geo.stream(feature, bound);

-       var n = ranges.length;

-       if (n) {

-         ranges.sort(compareRanges);

-         for (var i = 1, a = ranges[0], b, merged = [ a ]; i < n; ++i) {

-           b = ranges[i];

-           if (withinRange(b[0], a) || withinRange(b[1], a)) {

-             if (angle(a[0], b[1]) > angle(a[0], a[1])) a[1] = b[1];

-             if (angle(b[0], a[1]) > angle(a[0], a[1])) a[0] = b[0];

-           } else {

-             merged.push(a = b);

-           }

-         }

-         var best = -Infinity, dλ;

-         for (var n = merged.length - 1, i = 0, a = merged[n], b; i <= n; a = b, ++i) {

-           b = merged[i];

-           if ((dλ = angle(a[1], b[0])) > best) best = dλ, λ0 = b[0], λ1 = a[1];

-         }

-       }

-       ranges = range = null;

-       return λ0 === Infinity || φ0 === Infinity ? [ [ NaN, NaN ], [ NaN, NaN ] ] : [ [ λ0, φ0 ], [ λ1, φ1 ] ];

-     };

-   }();

-   d3.geo.centroid = function(object) {

-     d3_geo_centroidW0 = d3_geo_centroidW1 = d3_geo_centroidX0 = d3_geo_centroidY0 = d3_geo_centroidZ0 = d3_geo_centroidX1 = d3_geo_centroidY1 = d3_geo_centroidZ1 = d3_geo_centroidX2 = d3_geo_centroidY2 = d3_geo_centroidZ2 = 0;

-     d3.geo.stream(object, d3_geo_centroid);

-     var x = d3_geo_centroidX2, y = d3_geo_centroidY2, z = d3_geo_centroidZ2, m = x * x + y * y + z * z;

-     if (m < ε2) {

-       x = d3_geo_centroidX1, y = d3_geo_centroidY1, z = d3_geo_centroidZ1;

-       if (d3_geo_centroidW1 < ε) x = d3_geo_centroidX0, y = d3_geo_centroidY0, z = d3_geo_centroidZ0;

-       m = x * x + y * y + z * z;

-       if (m < ε2) return [ NaN, NaN ];

-     }

-     return [ Math.atan2(y, x) * d3_degrees, d3_asin(z / Math.sqrt(m)) * d3_degrees ];

-   };

-   var d3_geo_centroidW0, d3_geo_centroidW1, d3_geo_centroidX0, d3_geo_centroidY0, d3_geo_centroidZ0, d3_geo_centroidX1, d3_geo_centroidY1, d3_geo_centroidZ1, d3_geo_centroidX2, d3_geo_centroidY2, d3_geo_centroidZ2;

-   var d3_geo_centroid = {

-     sphere: d3_noop,

-     point: d3_geo_centroidPoint,

-     lineStart: d3_geo_centroidLineStart,

-     lineEnd: d3_geo_centroidLineEnd,

-     polygonStart: function() {

-       d3_geo_centroid.lineStart = d3_geo_centroidRingStart;

-     },

-     polygonEnd: function() {

-       d3_geo_centroid.lineStart = d3_geo_centroidLineStart;

-     }

-   };

-   function d3_geo_centroidPoint(λ, φ) {

-     λ *= d3_radians;

-     var cosφ = Math.cos(φ *= d3_radians);

-     d3_geo_centroidPointXYZ(cosφ * Math.cos(λ), cosφ * Math.sin(λ), Math.sin(φ));

-   }

-   function d3_geo_centroidPointXYZ(x, y, z) {

-     ++d3_geo_centroidW0;

-     d3_geo_centroidX0 += (x - d3_geo_centroidX0) / d3_geo_centroidW0;

-     d3_geo_centroidY0 += (y - d3_geo_centroidY0) / d3_geo_centroidW0;

-     d3_geo_centroidZ0 += (z - d3_geo_centroidZ0) / d3_geo_centroidW0;

-   }

-   function d3_geo_centroidLineStart() {

-     var x0, y0, z0;

-     d3_geo_centroid.point = function(λ, φ) {

-       λ *= d3_radians;

-       var cosφ = Math.cos(φ *= d3_radians);

-       x0 = cosφ * Math.cos(λ);

-       y0 = cosφ * Math.sin(λ);

-       z0 = Math.sin(φ);

-       d3_geo_centroid.point = nextPoint;

-       d3_geo_centroidPointXYZ(x0, y0, z0);

-     };

-     function nextPoint(λ, φ) {

-       λ *= d3_radians;

-       var cosφ = Math.cos(φ *= d3_radians), x = cosφ * Math.cos(λ), y = cosφ * Math.sin(λ), z = Math.sin(φ), w = Math.atan2(Math.sqrt((w = y0 * z - z0 * y) * w + (w = z0 * x - x0 * z) * w + (w = x0 * y - y0 * x) * w), x0 * x + y0 * y + z0 * z);

-       d3_geo_centroidW1 += w;

-       d3_geo_centroidX1 += w * (x0 + (x0 = x));

-       d3_geo_centroidY1 += w * (y0 + (y0 = y));

-       d3_geo_centroidZ1 += w * (z0 + (z0 = z));

-       d3_geo_centroidPointXYZ(x0, y0, z0);

-     }

-   }

-   function d3_geo_centroidLineEnd() {

-     d3_geo_centroid.point = d3_geo_centroidPoint;

-   }

-   function d3_geo_centroidRingStart() {

-     var λ00, φ00, x0, y0, z0;

-     d3_geo_centroid.point = function(λ, φ) {

-       λ00 = λ, φ00 = φ;

-       d3_geo_centroid.point = nextPoint;

-       λ *= d3_radians;

-       var cosφ = Math.cos(φ *= d3_radians);

-       x0 = cosφ * Math.cos(λ);

-       y0 = cosφ * Math.sin(λ);

-       z0 = Math.sin(φ);

-       d3_geo_centroidPointXYZ(x0, y0, z0);

-     };

-     d3_geo_centroid.lineEnd = function() {

-       nextPoint(λ00, φ00);

-       d3_geo_centroid.lineEnd = d3_geo_centroidLineEnd;

-       d3_geo_centroid.point = d3_geo_centroidPoint;

-     };

-     function nextPoint(λ, φ) {

-       λ *= d3_radians;

-       var cosφ = Math.cos(φ *= d3_radians), x = cosφ * Math.cos(λ), y = cosφ * Math.sin(λ), z = Math.sin(φ), cx = y0 * z - z0 * y, cy = z0 * x - x0 * z, cz = x0 * y - y0 * x, m = Math.sqrt(cx * cx + cy * cy + cz * cz), u = x0 * x + y0 * y + z0 * z, v = m && -d3_acos(u) / m, w = Math.atan2(m, u);

-       d3_geo_centroidX2 += v * cx;

-       d3_geo_centroidY2 += v * cy;

-       d3_geo_centroidZ2 += v * cz;

-       d3_geo_centroidW1 += w;

-       d3_geo_centroidX1 += w * (x0 + (x0 = x));

-       d3_geo_centroidY1 += w * (y0 + (y0 = y));

-       d3_geo_centroidZ1 += w * (z0 + (z0 = z));

-       d3_geo_centroidPointXYZ(x0, y0, z0);

-     }

-   }

-   function d3_geo_compose(a, b) {

-     function compose(x, y) {

-       return x = a(x, y), b(x[0], x[1]);

-     }

-     if (a.invert && b.invert) compose.invert = function(x, y) {

-       return x = b.invert(x, y), x && a.invert(x[0], x[1]);

-     };

-     return compose;

-   }

-   function d3_true() {

-     return true;

-   }

-   function d3_geo_clipPolygon(segments, compare, clipStartInside, interpolate, listener) {

-     var subject = [], clip = [];

-     segments.forEach(function(segment) {

-       if ((n = segment.length - 1) <= 0) return;

-       var n, p0 = segment[0], p1 = segment[n];

-       if (d3_geo_sphericalEqual(p0, p1)) {

-         listener.lineStart();

-         for (var i = 0; i < n; ++i) listener.point((p0 = segment[i])[0], p0[1]);

-         listener.lineEnd();

-         return;

-       }

-       var a = new d3_geo_clipPolygonIntersection(p0, segment, null, true), b = new d3_geo_clipPolygonIntersection(p0, null, a, false);

-       a.o = b;

-       subject.push(a);

-       clip.push(b);

-       a = new d3_geo_clipPolygonIntersection(p1, segment, null, false);

-       b = new d3_geo_clipPolygonIntersection(p1, null, a, true);

-       a.o = b;

-       subject.push(a);

-       clip.push(b);

-     });

-     clip.sort(compare);

-     d3_geo_clipPolygonLinkCircular(subject);

-     d3_geo_clipPolygonLinkCircular(clip);

-     if (!subject.length) return;

-     for (var i = 0, entry = clipStartInside, n = clip.length; i < n; ++i) {

-       clip[i].e = entry = !entry;

-     }

-     var start = subject[0], points, point;

-     while (1) {

-       var current = start, isSubject = true;

-       while (current.v) if ((current = current.n) === start) return;

-       points = current.z;

-       listener.lineStart();

-       do {

-         current.v = current.o.v = true;

-         if (current.e) {

-           if (isSubject) {

-             for (var i = 0, n = points.length; i < n; ++i) listener.point((point = points[i])[0], point[1]);

-           } else {

-             interpolate(current.x, current.n.x, 1, listener);

-           }

-           current = current.n;

-         } else {

-           if (isSubject) {

-             points = current.p.z;

-             for (var i = points.length - 1; i >= 0; --i) listener.point((point = points[i])[0], point[1]);

-           } else {

-             interpolate(current.x, current.p.x, -1, listener);

-           }

-           current = current.p;

-         }

-         current = current.o;

-         points = current.z;

-         isSubject = !isSubject;

-       } while (!current.v);

-       listener.lineEnd();

-     }

-   }

-   function d3_geo_clipPolygonLinkCircular(array) {

-     if (!(n = array.length)) return;

-     var n, i = 0, a = array[0], b;

-     while (++i < n) {

-       a.n = b = array[i];

-       b.p = a;

-       a = b;

-     }

-     a.n = b = array[0];

-     b.p = a;

-   }

-   function d3_geo_clipPolygonIntersection(point, points, other, entry) {

-     this.x = point;

-     this.z = points;

-     this.o = other;

-     this.e = entry;

-     this.v = false;

-     this.n = this.p = null;

-   }

-   function d3_geo_clip(pointVisible, clipLine, interpolate, clipStart) {

-     return function(rotate, listener) {

-       var line = clipLine(listener), rotatedClipStart = rotate.invert(clipStart[0], clipStart[1]);

-       var clip = {

-         point: point,

-         lineStart: lineStart,

-         lineEnd: lineEnd,

-         polygonStart: function() {

-           clip.point = pointRing;

-           clip.lineStart = ringStart;

-           clip.lineEnd = ringEnd;

-           segments = [];

-           polygon = [];

-         },

-         polygonEnd: function() {

-           clip.point = point;

-           clip.lineStart = lineStart;

-           clip.lineEnd = lineEnd;

-           segments = d3.merge(segments);

-           var clipStartInside = d3_geo_pointInPolygon(rotatedClipStart, polygon);

-           if (segments.length) {

-             if (!polygonStarted) listener.polygonStart(), polygonStarted = true;

-             d3_geo_clipPolygon(segments, d3_geo_clipSort, clipStartInside, interpolate, listener);

-           } else if (clipStartInside) {

-             if (!polygonStarted) listener.polygonStart(), polygonStarted = true;

-             listener.lineStart();

-             interpolate(null, null, 1, listener);

-             listener.lineEnd();

-           }

-           if (polygonStarted) listener.polygonEnd(), polygonStarted = false;

-           segments = polygon = null;

-         },

-         sphere: function() {

-           listener.polygonStart();

-           listener.lineStart();

-           interpolate(null, null, 1, listener);

-           listener.lineEnd();

-           listener.polygonEnd();

-         }

-       };

-       function point(λ, φ) {

-         var point = rotate(λ, φ);

-         if (pointVisible(λ = point[0], φ = point[1])) listener.point(λ, φ);

-       }

-       function pointLine(λ, φ) {

-         var point = rotate(λ, φ);

-         line.point(point[0], point[1]);

-       }

-       function lineStart() {

-         clip.point = pointLine;

-         line.lineStart();

-       }

-       function lineEnd() {

-         clip.point = point;

-         line.lineEnd();

-       }

-       var segments;

-       var buffer = d3_geo_clipBufferListener(), ringListener = clipLine(buffer), polygonStarted = false, polygon, ring;

-       function pointRing(λ, φ) {

-         ring.push([ λ, φ ]);

-         var point = rotate(λ, φ);

-         ringListener.point(point[0], point[1]);

-       }

-       function ringStart() {

-         ringListener.lineStart();

-         ring = [];

-       }

-       function ringEnd() {

-         pointRing(ring[0][0], ring[0][1]);

-         ringListener.lineEnd();

-         var clean = ringListener.clean(), ringSegments = buffer.buffer(), segment, n = ringSegments.length;

-         ring.pop();

-         polygon.push(ring);

-         ring = null;

-         if (!n) return;

-         if (clean & 1) {

-           segment = ringSegments[0];

-           var n = segment.length - 1, i = -1, point;

-           if (n > 0) {

-             if (!polygonStarted) listener.polygonStart(), polygonStarted = true;

-             listener.lineStart();

-             while (++i < n) listener.point((point = segment[i])[0], point[1]);

-             listener.lineEnd();

-           }

-           return;

-         }

-         if (n > 1 && clean & 2) ringSegments.push(ringSegments.pop().concat(ringSegments.shift()));

-         segments.push(ringSegments.filter(d3_geo_clipSegmentLength1));

-       }

-       return clip;

-     };

-   }

-   function d3_geo_clipSegmentLength1(segment) {

-     return segment.length > 1;

-   }

-   function d3_geo_clipBufferListener() {

-     var lines = [], line;

-     return {

-       lineStart: function() {

-         lines.push(line = []);

-       },

-       point: function(λ, φ) {

-         line.push([ λ, φ ]);

-       },

-       lineEnd: d3_noop,

-       buffer: function() {

-         var buffer = lines;

-         lines = [];

-         line = null;

-         return buffer;

-       },

-       rejoin: function() {

-         if (lines.length > 1) lines.push(lines.pop().concat(lines.shift()));

-       }

-     };

-   }

-   function d3_geo_clipSort(a, b) {

-     return ((a = a.x)[0] < 0 ? a[1] - halfπ - ε : halfπ - a[1]) - ((b = b.x)[0] < 0 ? b[1] - halfπ - ε : halfπ - b[1]);

-   }

-   var d3_geo_clipAntimeridian = d3_geo_clip(d3_true, d3_geo_clipAntimeridianLine, d3_geo_clipAntimeridianInterpolate, [ -π, -π / 2 ]);

-   function d3_geo_clipAntimeridianLine(listener) {

-     var λ0 = NaN, φ0 = NaN, sλ0 = NaN, clean;

-     return {

-       lineStart: function() {

-         listener.lineStart();

-         clean = 1;

-       },

-       point: function(λ1, φ1) {

-         var sλ1 = λ1 > 0 ? π : -π, dλ = abs(λ1 - λ0);

-         if (abs(dλ - π) < ε) {

-           listener.point(λ0, φ0 = (φ0 + φ1) / 2 > 0 ? halfπ : -halfπ);

-           listener.point(sλ0, φ0);

-           listener.lineEnd();

-           listener.lineStart();

-           listener.point(sλ1, φ0);

-           listener.point(λ1, φ0);

-           clean = 0;

-         } else if (sλ0 !== sλ1 && dλ >= π) {

-           if (abs(λ0 - sλ0) < ε) λ0 -= sλ0 * ε;

-           if (abs(λ1 - sλ1) < ε) λ1 -= sλ1 * ε;

-           φ0 = d3_geo_clipAntimeridianIntersect(λ0, φ0, λ1, φ1);

-           listener.point(sλ0, φ0);

-           listener.lineEnd();

-           listener.lineStart();

-           listener.point(sλ1, φ0);

-           clean = 0;

-         }

-         listener.point(λ0 = λ1, φ0 = φ1);

-         sλ0 = sλ1;

-       },

-       lineEnd: function() {

-         listener.lineEnd();

-         λ0 = φ0 = NaN;

-       },

-       clean: function() {

-         return 2 - clean;

-       }

-     };

-   }

-   function d3_geo_clipAntimeridianIntersect(λ0, φ0, λ1, φ1) {

-     var cosφ0, cosφ1, sinλ0_λ1 = Math.sin(λ0 - λ1);

-     return abs(sinλ0_λ1) > ε ? Math.atan((Math.sin(φ0) * (cosφ1 = Math.cos(φ1)) * Math.sin(λ1) - Math.sin(φ1) * (cosφ0 = Math.cos(φ0)) * Math.sin(λ0)) / (cosφ0 * cosφ1 * sinλ0_λ1)) : (φ0 + φ1) / 2;

-   }

-   function d3_geo_clipAntimeridianInterpolate(from, to, direction, listener) {

-     var φ;

-     if (from == null) {

-       φ = direction * halfπ;

-       listener.point(-π, φ);

-       listener.point(0, φ);

-       listener.point(π, φ);

-       listener.point(π, 0);

-       listener.point(π, -φ);

-       listener.point(0, -φ);

-       listener.point(-π, -φ);

-       listener.point(-π, 0);

-       listener.point(-π, φ);

-     } else if (abs(from[0] - to[0]) > ε) {

-       var s = from[0] < to[0] ? π : -π;

-       φ = direction * s / 2;

-       listener.point(-s, φ);

-       listener.point(0, φ);

-       listener.point(s, φ);

-     } else {

-       listener.point(to[0], to[1]);

-     }

-   }

-   function d3_geo_pointInPolygon(point, polygon) {

-     var meridian = point[0], parallel = point[1], meridianNormal = [ Math.sin(meridian), -Math.cos(meridian), 0 ], polarAngle = 0, winding = 0;

-     d3_geo_areaRingSum.reset();

-     for (var i = 0, n = polygon.length; i < n; ++i) {

-       var ring = polygon[i], m = ring.length;

-       if (!m) continue;

-       var point0 = ring[0], λ0 = point0[0], φ0 = point0[1] / 2 + π / 4, sinφ0 = Math.sin(φ0), cosφ0 = Math.cos(φ0), j = 1;

-       while (true) {

-         if (j === m) j = 0;

-         point = ring[j];

-         var λ = point[0], φ = point[1] / 2 + π / 4, sinφ = Math.sin(φ), cosφ = Math.cos(φ), dλ = λ - λ0, sdλ = dλ >= 0 ? 1 : -1, adλ = sdλ * dλ, antimeridian = adλ > π, k = sinφ0 * sinφ;

-         d3_geo_areaRingSum.add(Math.atan2(k * sdλ * Math.sin(adλ), cosφ0 * cosφ + k * Math.cos(adλ)));

-         polarAngle += antimeridian ? dλ + sdλ * τ : dλ;

-         if (antimeridian ^ λ0 >= meridian ^ λ >= meridian) {

-           var arc = d3_geo_cartesianCross(d3_geo_cartesian(point0), d3_geo_cartesian(point));

-           d3_geo_cartesianNormalize(arc);

-           var intersection = d3_geo_cartesianCross(meridianNormal, arc);

-           d3_geo_cartesianNormalize(intersection);

-           var φarc = (antimeridian ^ dλ >= 0 ? -1 : 1) * d3_asin(intersection[2]);

-           if (parallel > φarc || parallel === φarc && (arc[0] || arc[1])) {

-             winding += antimeridian ^ dλ >= 0 ? 1 : -1;

-           }

-         }

-         if (!j++) break;

-         λ0 = λ, sinφ0 = sinφ, cosφ0 = cosφ, point0 = point;

-       }

-     }

-     return (polarAngle < -ε || polarAngle < ε && d3_geo_areaRingSum < -ε) ^ winding & 1;

-   }

-   function d3_geo_clipCircle(radius) {

-     var cr = Math.cos(radius), smallRadius = cr > 0, notHemisphere = abs(cr) > ε, interpolate = d3_geo_circleInterpolate(radius, 6 * d3_radians);

-     return d3_geo_clip(visible, clipLine, interpolate, smallRadius ? [ 0, -radius ] : [ -π, radius - π ]);

-     function visible(λ, φ) {

-       return Math.cos(λ) * Math.cos(φ) > cr;

-     }

-     function clipLine(listener) {

-       var point0, c0, v0, v00, clean;

-       return {

-         lineStart: function() {

-           v00 = v0 = false;

-           clean = 1;

-         },

-         point: function(λ, φ) {

-           var point1 = [ λ, φ ], point2, v = visible(λ, φ), c = smallRadius ? v ? 0 : code(λ, φ) : v ? code(λ + (λ < 0 ? π : -π), φ) : 0;

-           if (!point0 && (v00 = v0 = v)) listener.lineStart();

-           if (v !== v0) {

-             point2 = intersect(point0, point1);

-             if (d3_geo_sphericalEqual(point0, point2) || d3_geo_sphericalEqual(point1, point2)) {

-               point1[0] += ε;

-               point1[1] += ε;

-               v = visible(point1[0], point1[1]);

-             }

-           }

-           if (v !== v0) {

-             clean = 0;

-             if (v) {

-               listener.lineStart();

-               point2 = intersect(point1, point0);

-               listener.point(point2[0], point2[1]);

-             } else {

-               point2 = intersect(point0, point1);

-               listener.point(point2[0], point2[1]);

-               listener.lineEnd();

-             }

-             point0 = point2;

-           } else if (notHemisphere && point0 && smallRadius ^ v) {

-             var t;

-             if (!(c & c0) && (t = intersect(point1, point0, true))) {

-               clean = 0;

-               if (smallRadius) {

-                 listener.lineStart();

-                 listener.point(t[0][0], t[0][1]);

-                 listener.point(t[1][0], t[1][1]);

-                 listener.lineEnd();

-               } else {

-                 listener.point(t[1][0], t[1][1]);

-                 listener.lineEnd();

-                 listener.lineStart();

-                 listener.point(t[0][0], t[0][1]);

-               }

-             }

-           }

-           if (v && (!point0 || !d3_geo_sphericalEqual(point0, point1))) {

-             listener.point(point1[0], point1[1]);

-           }

-           point0 = point1, v0 = v, c0 = c;

-         },

-         lineEnd: function() {

-           if (v0) listener.lineEnd();

-           point0 = null;

-         },

-         clean: function() {

-           return clean | (v00 && v0) << 1;

-         }

-       };

-     }

-     function intersect(a, b, two) {

-       var pa = d3_geo_cartesian(a), pb = d3_geo_cartesian(b);

-       var n1 = [ 1, 0, 0 ], n2 = d3_geo_cartesianCross(pa, pb), n2n2 = d3_geo_cartesianDot(n2, n2), n1n2 = n2[0], determinant = n2n2 - n1n2 * n1n2;

-       if (!determinant) return !two && a;

-       var c1 = cr * n2n2 / determinant, c2 = -cr * n1n2 / determinant, n1xn2 = d3_geo_cartesianCross(n1, n2), A = d3_geo_cartesianScale(n1, c1), B = d3_geo_cartesianScale(n2, c2);

-       d3_geo_cartesianAdd(A, B);

-       var u = n1xn2, w = d3_geo_cartesianDot(A, u), uu = d3_geo_cartesianDot(u, u), t2 = w * w - uu * (d3_geo_cartesianDot(A, A) - 1);

-       if (t2 < 0) return;

-       var t = Math.sqrt(t2), q = d3_geo_cartesianScale(u, (-w - t) / uu);

-       d3_geo_cartesianAdd(q, A);

-       q = d3_geo_spherical(q);

-       if (!two) return q;

-       var λ0 = a[0], λ1 = b[0], φ0 = a[1], φ1 = b[1], z;

-       if (λ1 < λ0) z = λ0, λ0 = λ1, λ1 = z;

-       var δλ = λ1 - λ0, polar = abs(δλ - π) < ε, meridian = polar || δλ < ε;

-       if (!polar && φ1 < φ0) z = φ0, φ0 = φ1, φ1 = z;

-       if (meridian ? polar ? φ0 + φ1 > 0 ^ q[1] < (abs(q[0] - λ0) < ε ? φ0 : φ1) : φ0 <= q[1] && q[1] <= φ1 : δλ > π ^ (λ0 <= q[0] && q[0] <= λ1)) {

-         var q1 = d3_geo_cartesianScale(u, (-w + t) / uu);

-         d3_geo_cartesianAdd(q1, A);

-         return [ q, d3_geo_spherical(q1) ];

-       }

-     }

-     function code(λ, φ) {

-       var r = smallRadius ? radius : π - radius, code = 0;

-       if (λ < -r) code |= 1; else if (λ > r) code |= 2;

-       if (φ < -r) code |= 4; else if (φ > r) code |= 8;

-       return code;

-     }

-   }

-   function d3_geom_clipLine(x0, y0, x1, y1) {

-     return function(line) {

-       var a = line.a, b = line.b, ax = a.x, ay = a.y, bx = b.x, by = b.y, t0 = 0, t1 = 1, dx = bx - ax, dy = by - ay, r;

-       r = x0 - ax;

-       if (!dx && r > 0) return;

-       r /= dx;

-       if (dx < 0) {

-         if (r < t0) return;

-         if (r < t1) t1 = r;

-       } else if (dx > 0) {

-         if (r > t1) return;

-         if (r > t0) t0 = r;

-       }

-       r = x1 - ax;

-       if (!dx && r < 0) return;

-       r /= dx;

-       if (dx < 0) {

-         if (r > t1) return;

-         if (r > t0) t0 = r;

-       } else if (dx > 0) {

-         if (r < t0) return;

-         if (r < t1) t1 = r;

-       }

-       r = y0 - ay;

-       if (!dy && r > 0) return;

-       r /= dy;

-       if (dy < 0) {

-         if (r < t0) return;

-         if (r < t1) t1 = r;

-       } else if (dy > 0) {

-         if (r > t1) return;

-         if (r > t0) t0 = r;

-       }

-       r = y1 - ay;

-       if (!dy && r < 0) return;

-       r /= dy;

-       if (dy < 0) {

-         if (r > t1) return;

-         if (r > t0) t0 = r;

-       } else if (dy > 0) {

-         if (r < t0) return;

-         if (r < t1) t1 = r;

-       }

-       if (t0 > 0) line.a = {

-         x: ax + t0 * dx,

-         y: ay + t0 * dy

-       };

-       if (t1 < 1) line.b = {

-         x: ax + t1 * dx,

-         y: ay + t1 * dy

-       };

-       return line;

-     };

-   }

-   var d3_geo_clipExtentMAX = 1e9;

-   d3.geo.clipExtent = function() {

-     var x0, y0, x1, y1, stream, clip, clipExtent = {

-       stream: function(output) {

-         if (stream) stream.valid = false;

-         stream = clip(output);

-         stream.valid = true;

-         return stream;

-       },

-       extent: function(_) {

-         if (!arguments.length) return [ [ x0, y0 ], [ x1, y1 ] ];

-         clip = d3_geo_clipExtent(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]);

-         if (stream) stream.valid = false, stream = null;

-         return clipExtent;

-       }

-     };

-     return clipExtent.extent([ [ 0, 0 ], [ 960, 500 ] ]);

-   };

-   function d3_geo_clipExtent(x0, y0, x1, y1) {

-     return function(listener) {

-       var listener_ = listener, bufferListener = d3_geo_clipBufferListener(), clipLine = d3_geom_clipLine(x0, y0, x1, y1), segments, polygon, ring;

-       var clip = {

-         point: point,

-         lineStart: lineStart,

-         lineEnd: lineEnd,

-         polygonStart: function() {

-           listener = bufferListener;

-           segments = [];

-           polygon = [];

-           clean = true;

-         },

-         polygonEnd: function() {

-           listener = listener_;

-           segments = d3.merge(segments);

-           var clipStartInside = insidePolygon([ x0, y1 ]), inside = clean && clipStartInside, visible = segments.length;

-           if (inside || visible) {

-             listener.polygonStart();

-             if (inside) {

-               listener.lineStart();

-               interpolate(null, null, 1, listener);

-               listener.lineEnd();

-             }

-             if (visible) {

-               d3_geo_clipPolygon(segments, compare, clipStartInside, interpolate, listener);

-             }

-             listener.polygonEnd();

-           }

-           segments = polygon = ring = null;

-         }

-       };

-       function insidePolygon(p) {

-         var wn = 0, n = polygon.length, y = p[1];

-         for (var i = 0; i < n; ++i) {

-           for (var j = 1, v = polygon[i], m = v.length, a = v[0], b; j < m; ++j) {

-             b = v[j];

-             if (a[1] <= y) {

-               if (b[1] > y && d3_cross2d(a, b, p) > 0) ++wn;

-             } else {

-               if (b[1] <= y && d3_cross2d(a, b, p) < 0) --wn;

-             }

-             a = b;

-           }

-         }

-         return wn !== 0;

-       }

-       function interpolate(from, to, direction, listener) {

-         var a = 0, a1 = 0;

-         if (from == null || (a = corner(from, direction)) !== (a1 = corner(to, direction)) || comparePoints(from, to) < 0 ^ direction > 0) {

-           do {

-             listener.point(a === 0 || a === 3 ? x0 : x1, a > 1 ? y1 : y0);

-           } while ((a = (a + direction + 4) % 4) !== a1);

-         } else {

-           listener.point(to[0], to[1]);

-         }

-       }

-       function pointVisible(x, y) {

-         return x0 <= x && x <= x1 && y0 <= y && y <= y1;

-       }

-       function point(x, y) {

-         if (pointVisible(x, y)) listener.point(x, y);

-       }

-       var x__, y__, v__, x_, y_, v_, first, clean;

-       function lineStart() {

-         clip.point = linePoint;

-         if (polygon) polygon.push(ring = []);

-         first = true;

-         v_ = false;

-         x_ = y_ = NaN;

-       }

-       function lineEnd() {

-         if (segments) {

-           linePoint(x__, y__);

-           if (v__ && v_) bufferListener.rejoin();

-           segments.push(bufferListener.buffer());

-         }

-         clip.point = point;

-         if (v_) listener.lineEnd();

-       }

-       function linePoint(x, y) {

-         x = Math.max(-d3_geo_clipExtentMAX, Math.min(d3_geo_clipExtentMAX, x));

-         y = Math.max(-d3_geo_clipExtentMAX, Math.min(d3_geo_clipExtentMAX, y));

-         var v = pointVisible(x, y);

-         if (polygon) ring.push([ x, y ]);

-         if (first) {

-           x__ = x, y__ = y, v__ = v;

-           first = false;

-           if (v) {

-             listener.lineStart();

-             listener.point(x, y);

-           }

-         } else {

-           if (v && v_) listener.point(x, y); else {

-             var l = {

-               a: {

-                 x: x_,

-                 y: y_

-               },

-               b: {

-                 x: x,

-                 y: y

-               }

-             };

-             if (clipLine(l)) {

-               if (!v_) {

-                 listener.lineStart();

-                 listener.point(l.a.x, l.a.y);

-               }

-               listener.point(l.b.x, l.b.y);

-               if (!v) listener.lineEnd();

-               clean = false;

-             } else if (v) {

-               listener.lineStart();

-               listener.point(x, y);

-               clean = false;

-             }

-           }

-         }

-         x_ = x, y_ = y, v_ = v;

-       }

-       return clip;

-     };

-     function corner(p, direction) {

-       return abs(p[0] - x0) < ε ? direction > 0 ? 0 : 3 : abs(p[0] - x1) < ε ? direction > 0 ? 2 : 1 : abs(p[1] - y0) < ε ? direction > 0 ? 1 : 0 : direction > 0 ? 3 : 2;

-     }

-     function compare(a, b) {

-       return comparePoints(a.x, b.x);

-     }

-     function comparePoints(a, b) {

-       var ca = corner(a, 1), cb = corner(b, 1);

-       return ca !== cb ? ca - cb : ca === 0 ? b[1] - a[1] : ca === 1 ? a[0] - b[0] : ca === 2 ? a[1] - b[1] : b[0] - a[0];

-     }

-   }

-   function d3_geo_conic(projectAt) {

-     var φ0 = 0, φ1 = π / 3, m = d3_geo_projectionMutator(projectAt), p = m(φ0, φ1);

-     p.parallels = function(_) {

-       if (!arguments.length) return [ φ0 / π * 180, φ1 / π * 180 ];

-       return m(φ0 = _[0] * π / 180, φ1 = _[1] * π / 180);

-     };

-     return p;

-   }

-   function d3_geo_conicEqualArea(φ0, φ1) {

-     var sinφ0 = Math.sin(φ0), n = (sinφ0 + Math.sin(φ1)) / 2, C = 1 + sinφ0 * (2 * n - sinφ0), ρ0 = Math.sqrt(C) / n;

-     function forward(λ, φ) {

-       var ρ = Math.sqrt(C - 2 * n * Math.sin(φ)) / n;

-       return [ ρ * Math.sin(λ *= n), ρ0 - ρ * Math.cos(λ) ];

-     }

-     forward.invert = function(x, y) {

-       var ρ0_y = ρ0 - y;

-       return [ Math.atan2(x, ρ0_y) / n, d3_asin((C - (x * x + ρ0_y * ρ0_y) * n * n) / (2 * n)) ];

-     };

-     return forward;

-   }

-   (d3.geo.conicEqualArea = function() {

-     return d3_geo_conic(d3_geo_conicEqualArea);

-   }).raw = d3_geo_conicEqualArea;

-   d3.geo.albers = function() {

-     return d3.geo.conicEqualArea().rotate([ 96, 0 ]).center([ -.6, 38.7 ]).parallels([ 29.5, 45.5 ]).scale(1070);

-   };

-   d3.geo.albersUsa = function() {

-     var lower48 = d3.geo.albers();

-     var alaska = d3.geo.conicEqualArea().rotate([ 154, 0 ]).center([ -2, 58.5 ]).parallels([ 55, 65 ]);

-     var hawaii = d3.geo.conicEqualArea().rotate([ 157, 0 ]).center([ -3, 19.9 ]).parallels([ 8, 18 ]);

-     var point, pointStream = {

-       point: function(x, y) {

-         point = [ x, y ];

-       }

-     }, lower48Point, alaskaPoint, hawaiiPoint;

-     function albersUsa(coordinates) {

-       var x = coordinates[0], y = coordinates[1];

-       point = null;

-       (lower48Point(x, y), point) || (alaskaPoint(x, y), point) || hawaiiPoint(x, y);

-       return point;

-     }

-     albersUsa.invert = function(coordinates) {

-       var k = lower48.scale(), t = lower48.translate(), x = (coordinates[0] - t[0]) / k, y = (coordinates[1] - t[1]) / k;

-       return (y >= .12 && y < .234 && x >= -.425 && x < -.214 ? alaska : y >= .166 && y < .234 && x >= -.214 && x < -.115 ? hawaii : lower48).invert(coordinates);

-     };

-     albersUsa.stream = function(stream) {

-       var lower48Stream = lower48.stream(stream), alaskaStream = alaska.stream(stream), hawaiiStream = hawaii.stream(stream);

-       return {

-         point: function(x, y) {

-           lower48Stream.point(x, y);

-           alaskaStream.point(x, y);

-           hawaiiStream.point(x, y);

-         },

-         sphere: function() {

-           lower48Stream.sphere();

-           alaskaStream.sphere();

-           hawaiiStream.sphere();

-         },

-         lineStart: function() {

-           lower48Stream.lineStart();

-           alaskaStream.lineStart();

-           hawaiiStream.lineStart();

-         },

-         lineEnd: function() {

-           lower48Stream.lineEnd();

-           alaskaStream.lineEnd();

-           hawaiiStream.lineEnd();

-         },

-         polygonStart: function() {

-           lower48Stream.polygonStart();

-           alaskaStream.polygonStart();

-           hawaiiStream.polygonStart();

-         },

-         polygonEnd: function() {

-           lower48Stream.polygonEnd();

-           alaskaStream.polygonEnd();

-           hawaiiStream.polygonEnd();

-         }

-       };

-     };

-     albersUsa.precision = function(_) {

-       if (!arguments.length) return lower48.precision();

-       lower48.precision(_);

-       alaska.precision(_);

-       hawaii.precision(_);

-       return albersUsa;

-     };

-     albersUsa.scale = function(_) {

-       if (!arguments.length) return lower48.scale();

-       lower48.scale(_);

-       alaska.scale(_ * .35);

-       hawaii.scale(_);

-       return albersUsa.translate(lower48.translate());

-     };

-     albersUsa.translate = function(_) {

-       if (!arguments.length) return lower48.translate();

-       var k = lower48.scale(), x = +_[0], y = +_[1];

-       lower48Point = lower48.translate(_).clipExtent([ [ x - .455 * k, y - .238 * k ], [ x + .455 * k, y + .238 * k ] ]).stream(pointStream).point;

-       alaskaPoint = alaska.translate([ x - .307 * k, y + .201 * k ]).clipExtent([ [ x - .425 * k + ε, y + .12 * k + ε ], [ x - .214 * k - ε, y + .234 * k - ε ] ]).stream(pointStream).point;

-       hawaiiPoint = hawaii.translate([ x - .205 * k, y + .212 * k ]).clipExtent([ [ x - .214 * k + ε, y + .166 * k + ε ], [ x - .115 * k - ε, y + .234 * k - ε ] ]).stream(pointStream).point;

-       return albersUsa;

-     };

-     return albersUsa.scale(1070);

-   };

-   var d3_geo_pathAreaSum, d3_geo_pathAreaPolygon, d3_geo_pathArea = {

-     point: d3_noop,

-     lineStart: d3_noop,

-     lineEnd: d3_noop,

-     polygonStart: function() {

-       d3_geo_pathAreaPolygon = 0;

-       d3_geo_pathArea.lineStart = d3_geo_pathAreaRingStart;

-     },

-     polygonEnd: function() {

-       d3_geo_pathArea.lineStart = d3_geo_pathArea.lineEnd = d3_geo_pathArea.point = d3_noop;

-       d3_geo_pathAreaSum += abs(d3_geo_pathAreaPolygon / 2);

-     }

-   };

-   function d3_geo_pathAreaRingStart() {

-     var x00, y00, x0, y0;

-     d3_geo_pathArea.point = function(x, y) {

-       d3_geo_pathArea.point = nextPoint;

-       x00 = x0 = x, y00 = y0 = y;

-     };

-     function nextPoint(x, y) {

-       d3_geo_pathAreaPolygon += y0 * x - x0 * y;

-       x0 = x, y0 = y;

-     }

-     d3_geo_pathArea.lineEnd = function() {

-       nextPoint(x00, y00);

-     };

-   }

-   var d3_geo_pathBoundsX0, d3_geo_pathBoundsY0, d3_geo_pathBoundsX1, d3_geo_pathBoundsY1;

-   var d3_geo_pathBounds = {

-     point: d3_geo_pathBoundsPoint,

-     lineStart: d3_noop,

-     lineEnd: d3_noop,

-     polygonStart: d3_noop,

-     polygonEnd: d3_noop

-   };

-   function d3_geo_pathBoundsPoint(x, y) {

-     if (x < d3_geo_pathBoundsX0) d3_geo_pathBoundsX0 = x;

-     if (x > d3_geo_pathBoundsX1) d3_geo_pathBoundsX1 = x;

-     if (y < d3_geo_pathBoundsY0) d3_geo_pathBoundsY0 = y;

-     if (y > d3_geo_pathBoundsY1) d3_geo_pathBoundsY1 = y;

-   }

-   function d3_geo_pathBuffer() {

-     var pointCircle = d3_geo_pathBufferCircle(4.5), buffer = [];

-     var stream = {

-       point: point,

-       lineStart: function() {

-         stream.point = pointLineStart;

-       },

-       lineEnd: lineEnd,

-       polygonStart: function() {

-         stream.lineEnd = lineEndPolygon;

-       },

-       polygonEnd: function() {

-         stream.lineEnd = lineEnd;

-         stream.point = point;

-       },

-       pointRadius: function(_) {

-         pointCircle = d3_geo_pathBufferCircle(_);

-         return stream;

-       },

-       result: function() {

-         if (buffer.length) {

-           var result = buffer.join("");

-           buffer = [];

-           return result;

-         }

-       }

-     };

-     function point(x, y) {

-       buffer.push("M", x, ",", y, pointCircle);

-     }

-     function pointLineStart(x, y) {

-       buffer.push("M", x, ",", y);

-       stream.point = pointLine;

-     }

-     function pointLine(x, y) {

-       buffer.push("L", x, ",", y);

-     }

-     function lineEnd() {

-       stream.point = point;

-     }

-     function lineEndPolygon() {

-       buffer.push("Z");

-     }

-     return stream;

-   }

-   function d3_geo_pathBufferCircle(radius) {

-     return "m0," + radius + "a" + radius + "," + radius + " 0 1,1 0," + -2 * radius + "a" + radius + "," + radius + " 0 1,1 0," + 2 * radius + "z";

-   }

-   var d3_geo_pathCentroid = {

-     point: d3_geo_pathCentroidPoint,

-     lineStart: d3_geo_pathCentroidLineStart,

-     lineEnd: d3_geo_pathCentroidLineEnd,

-     polygonStart: function() {

-       d3_geo_pathCentroid.lineStart = d3_geo_pathCentroidRingStart;

-     },

-     polygonEnd: function() {

-       d3_geo_pathCentroid.point = d3_geo_pathCentroidPoint;

-       d3_geo_pathCentroid.lineStart = d3_geo_pathCentroidLineStart;

-       d3_geo_pathCentroid.lineEnd = d3_geo_pathCentroidLineEnd;

-     }

-   };

-   function d3_geo_pathCentroidPoint(x, y) {

-     d3_geo_centroidX0 += x;

-     d3_geo_centroidY0 += y;

-     ++d3_geo_centroidZ0;

-   }

-   function d3_geo_pathCentroidLineStart() {

-     var x0, y0;

-     d3_geo_pathCentroid.point = function(x, y) {

-       d3_geo_pathCentroid.point = nextPoint;

-       d3_geo_pathCentroidPoint(x0 = x, y0 = y);

-     };

-     function nextPoint(x, y) {

-       var dx = x - x0, dy = y - y0, z = Math.sqrt(dx * dx + dy * dy);

-       d3_geo_centroidX1 += z * (x0 + x) / 2;

-       d3_geo_centroidY1 += z * (y0 + y) / 2;

-       d3_geo_centroidZ1 += z;

-       d3_geo_pathCentroidPoint(x0 = x, y0 = y);

-     }

-   }

-   function d3_geo_pathCentroidLineEnd() {

-     d3_geo_pathCentroid.point = d3_geo_pathCentroidPoint;

-   }

-   function d3_geo_pathCentroidRingStart() {

-     var x00, y00, x0, y0;

-     d3_geo_pathCentroid.point = function(x, y) {

-       d3_geo_pathCentroid.point = nextPoint;

-       d3_geo_pathCentroidPoint(x00 = x0 = x, y00 = y0 = y);

-     };

-     function nextPoint(x, y) {

-       var dx = x - x0, dy = y - y0, z = Math.sqrt(dx * dx + dy * dy);

-       d3_geo_centroidX1 += z * (x0 + x) / 2;

-       d3_geo_centroidY1 += z * (y0 + y) / 2;

-       d3_geo_centroidZ1 += z;

-       z = y0 * x - x0 * y;

-       d3_geo_centroidX2 += z * (x0 + x);

-       d3_geo_centroidY2 += z * (y0 + y);

-       d3_geo_centroidZ2 += z * 3;

-       d3_geo_pathCentroidPoint(x0 = x, y0 = y);

-     }

-     d3_geo_pathCentroid.lineEnd = function() {

-       nextPoint(x00, y00);

-     };

-   }

-   function d3_geo_pathContext(context) {

-     var pointRadius = 4.5;

-     var stream = {

-       point: point,

-       lineStart: function() {

-         stream.point = pointLineStart;

-       },

-       lineEnd: lineEnd,

-       polygonStart: function() {

-         stream.lineEnd = lineEndPolygon;

-       },

-       polygonEnd: function() {

-         stream.lineEnd = lineEnd;

-         stream.point = point;

-       },

-       pointRadius: function(_) {

-         pointRadius = _;

-         return stream;

-       },

-       result: d3_noop

-     };

-     function point(x, y) {

-       context.moveTo(x + pointRadius, y);

-       context.arc(x, y, pointRadius, 0, τ);

-     }

-     function pointLineStart(x, y) {

-       context.moveTo(x, y);

-       stream.point = pointLine;

-     }

-     function pointLine(x, y) {

-       context.lineTo(x, y);

-     }

-     function lineEnd() {

-       stream.point = point;

-     }

-     function lineEndPolygon() {

-       context.closePath();

-     }

-     return stream;

-   }

-   function d3_geo_resample(project) {

-     var δ2 = .5, cosMinDistance = Math.cos(30 * d3_radians), maxDepth = 16;

-     function resample(stream) {

-       return (maxDepth ? resampleRecursive : resampleNone)(stream);

-     }

-     function resampleNone(stream) {

-       return d3_geo_transformPoint(stream, function(x, y) {

-         x = project(x, y);

-         stream.point(x[0], x[1]);

-       });

-     }

-     function resampleRecursive(stream) {

-       var λ00, φ00, x00, y00, a00, b00, c00, λ0, x0, y0, a0, b0, c0;

-       var resample = {

-         point: point,

-         lineStart: lineStart,

-         lineEnd: lineEnd,

-         polygonStart: function() {

-           stream.polygonStart();

-           resample.lineStart = ringStart;

-         },

-         polygonEnd: function() {

-           stream.polygonEnd();

-           resample.lineStart = lineStart;

-         }

-       };

-       function point(x, y) {

-         x = project(x, y);

-         stream.point(x[0], x[1]);

-       }

-       function lineStart() {

-         x0 = NaN;

-         resample.point = linePoint;

-         stream.lineStart();

-       }

-       function linePoint(λ, φ) {

-         var c = d3_geo_cartesian([ λ, φ ]), p = project(λ, φ);

-         resampleLineTo(x0, y0, λ0, a0, b0, c0, x0 = p[0], y0 = p[1], λ0 = λ, a0 = c[0], b0 = c[1], c0 = c[2], maxDepth, stream);

-         stream.point(x0, y0);

-       }

-       function lineEnd() {

-         resample.point = point;

-         stream.lineEnd();

-       }

-       function ringStart() {

-         lineStart();

-         resample.point = ringPoint;

-         resample.lineEnd = ringEnd;

-       }

-       function ringPoint(λ, φ) {

-         linePoint(λ00 = λ, φ00 = φ), x00 = x0, y00 = y0, a00 = a0, b00 = b0, c00 = c0;

-         resample.point = linePoint;

-       }

-       function ringEnd() {

-         resampleLineTo(x0, y0, λ0, a0, b0, c0, x00, y00, λ00, a00, b00, c00, maxDepth, stream);

-         resample.lineEnd = lineEnd;

-         lineEnd();

-       }

-       return resample;

-     }

-     function resampleLineTo(x0, y0, λ0, a0, b0, c0, x1, y1, λ1, a1, b1, c1, depth, stream) {

-       var dx = x1 - x0, dy = y1 - y0, d2 = dx * dx + dy * dy;

-       if (d2 > 4 * δ2 && depth--) {

-         var a = a0 + a1, b = b0 + b1, c = c0 + c1, m = Math.sqrt(a * a + b * b + c * c), φ2 = Math.asin(c /= m), λ2 = abs(abs(c) - 1) < ε || abs(λ0 - λ1) < ε ? (λ0 + λ1) / 2 : Math.atan2(b, a), p = project(λ2, φ2), x2 = p[0], y2 = p[1], dx2 = x2 - x0, dy2 = y2 - y0, dz = dy * dx2 - dx * dy2;

-         if (dz * dz / d2 > δ2 || abs((dx * dx2 + dy * dy2) / d2 - .5) > .3 || a0 * a1 + b0 * b1 + c0 * c1 < cosMinDistance) {

-           resampleLineTo(x0, y0, λ0, a0, b0, c0, x2, y2, λ2, a /= m, b /= m, c, depth, stream);

-           stream.point(x2, y2);

-           resampleLineTo(x2, y2, λ2, a, b, c, x1, y1, λ1, a1, b1, c1, depth, stream);

-         }

-       }

-     }

-     resample.precision = function(_) {

-       if (!arguments.length) return Math.sqrt(δ2);

-       maxDepth = (δ2 = _ * _) > 0 && 16;

-       return resample;

-     };

-     return resample;

-   }

-   d3.geo.path = function() {

-     var pointRadius = 4.5, projection, context, projectStream, contextStream, cacheStream;

-     function path(object) {

-       if (object) {

-         if (typeof pointRadius === "function") contextStream.pointRadius(+pointRadius.apply(this, arguments));

-         if (!cacheStream || !cacheStream.valid) cacheStream = projectStream(contextStream);

-         d3.geo.stream(object, cacheStream);

-       }

-       return contextStream.result();

-     }

-     path.area = function(object) {

-       d3_geo_pathAreaSum = 0;

-       d3.geo.stream(object, projectStream(d3_geo_pathArea));

-       return d3_geo_pathAreaSum;

-     };

-     path.centroid = function(object) {

-       d3_geo_centroidX0 = d3_geo_centroidY0 = d3_geo_centroidZ0 = d3_geo_centroidX1 = d3_geo_centroidY1 = d3_geo_centroidZ1 = d3_geo_centroidX2 = d3_geo_centroidY2 = d3_geo_centroidZ2 = 0;

-       d3.geo.stream(object, projectStream(d3_geo_pathCentroid));

-       return d3_geo_centroidZ2 ? [ d3_geo_centroidX2 / d3_geo_centroidZ2, d3_geo_centroidY2 / d3_geo_centroidZ2 ] : d3_geo_centroidZ1 ? [ d3_geo_centroidX1 / d3_geo_centroidZ1, d3_geo_centroidY1 / d3_geo_centroidZ1 ] : d3_geo_centroidZ0 ? [ d3_geo_centroidX0 / d3_geo_centroidZ0, d3_geo_centroidY0 / d3_geo_centroidZ0 ] : [ NaN, NaN ];

-     };

-     path.bounds = function(object) {

-       d3_geo_pathBoundsX1 = d3_geo_pathBoundsY1 = -(d3_geo_pathBoundsX0 = d3_geo_pathBoundsY0 = Infinity);

-       d3.geo.stream(object, projectStream(d3_geo_pathBounds));

-       return [ [ d3_geo_pathBoundsX0, d3_geo_pathBoundsY0 ], [ d3_geo_pathBoundsX1, d3_geo_pathBoundsY1 ] ];

-     };

-     path.projection = function(_) {

-       if (!arguments.length) return projection;

-       projectStream = (projection = _) ? _.stream || d3_geo_pathProjectStream(_) : d3_identity;

-       return reset();

-     };

-     path.context = function(_) {

-       if (!arguments.length) return context;

-       contextStream = (context = _) == null ? new d3_geo_pathBuffer() : new d3_geo_pathContext(_);

-       if (typeof pointRadius !== "function") contextStream.pointRadius(pointRadius);

-       return reset();

-     };

-     path.pointRadius = function(_) {

-       if (!arguments.length) return pointRadius;

-       pointRadius = typeof _ === "function" ? _ : (contextStream.pointRadius(+_), +_);

-       return path;

-     };

-     function reset() {

-       cacheStream = null;

-       return path;

-     }

-     return path.projection(d3.geo.albersUsa()).context(null);

-   };

-   function d3_geo_pathProjectStream(project) {

-     var resample = d3_geo_resample(function(x, y) {

-       return project([ x * d3_degrees, y * d3_degrees ]);

-     });

-     return function(stream) {

-       return d3_geo_projectionRadians(resample(stream));

-     };

-   }

-   d3.geo.transform = function(methods) {

-     return {

-       stream: function(stream) {

-         var transform = new d3_geo_transform(stream);

-         for (var k in methods) transform[k] = methods[k];

-         return transform;

-       }

-     };

-   };

-   function d3_geo_transform(stream) {

-     this.stream = stream;

-   }

-   d3_geo_transform.prototype = {

-     point: function(x, y) {

-       this.stream.point(x, y);

-     },

-     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 d3_geo_transformPoint(stream, point) {

-     return {

-       point: point,

-       sphere: function() {

-         stream.sphere();

-       },

-       lineStart: function() {

-         stream.lineStart();

-       },

-       lineEnd: function() {

-         stream.lineEnd();

-       },

-       polygonStart: function() {

-         stream.polygonStart();

-       },

-       polygonEnd: function() {

-         stream.polygonEnd();

-       }

-     };

-   }

-   d3.geo.projection = d3_geo_projection;

-   d3.geo.projectionMutator = d3_geo_projectionMutator;

-   function d3_geo_projection(project) {

-     return d3_geo_projectionMutator(function() {

-       return project;

-     })();

-   }

-   function d3_geo_projectionMutator(projectAt) {

-     var project, rotate, projectRotate, projectResample = d3_geo_resample(function(x, y) {

-       x = project(x, y);

-       return [ x[0] * k + δx, δy - x[1] * k ];

-     }), k = 150, x = 480, y = 250, λ = 0, φ = 0, δλ = 0, δφ = 0, δγ = 0, δx, δy, preclip = d3_geo_clipAntimeridian, postclip = d3_identity, clipAngle = null, clipExtent = null, stream;

-     function projection(point) {

-       point = projectRotate(point[0] * d3_radians, point[1] * d3_radians);

-       return [ point[0] * k + δx, δy - point[1] * k ];

-     }

-     function invert(point) {

-       point = projectRotate.invert((point[0] - δx) / k, (δy - point[1]) / k);

-       return point && [ point[0] * d3_degrees, point[1] * d3_degrees ];

-     }

-     projection.stream = function(output) {

-       if (stream) stream.valid = false;

-       stream = d3_geo_projectionRadians(preclip(rotate, projectResample(postclip(output))));

-       stream.valid = true;

-       return stream;

-     };

-     projection.clipAngle = function(_) {

-       if (!arguments.length) return clipAngle;

-       preclip = _ == null ? (clipAngle = _, d3_geo_clipAntimeridian) : d3_geo_clipCircle((clipAngle = +_) * d3_radians);

-       return invalidate();

-     };

-     projection.clipExtent = function(_) {

-       if (!arguments.length) return clipExtent;

-       clipExtent = _;

-       postclip = _ ? d3_geo_clipExtent(_[0][0], _[0][1], _[1][0], _[1][1]) : d3_identity;

-       return invalidate();

-     };

-     projection.scale = function(_) {

-       if (!arguments.length) return k;

-       k = +_;

-       return reset();

-     };

-     projection.translate = function(_) {

-       if (!arguments.length) return [ x, y ];

-       x = +_[0];

-       y = +_[1];

-       return reset();

-     };

-     projection.center = function(_) {

-       if (!arguments.length) return [ λ * d3_degrees, φ * d3_degrees ];

-       λ = _[0] % 360 * d3_radians;

-       φ = _[1] % 360 * d3_radians;

-       return reset();

-     };

-     projection.rotate = function(_) {

-       if (!arguments.length) return [ δλ * d3_degrees, δφ * d3_degrees, δγ * d3_degrees ];

-       δλ = _[0] % 360 * d3_radians;

-       δφ = _[1] % 360 * d3_radians;

-       δγ = _.length > 2 ? _[2] % 360 * d3_radians : 0;

-       return reset();

-     };

-     d3.rebind(projection, projectResample, "precision");

-     function reset() {

-       projectRotate = d3_geo_compose(rotate = d3_geo_rotation(δλ, δφ, δγ), project);

-       var center = project(λ, φ);

-       δx = x - center[0] * k;

-       δy = y + center[1] * k;

-       return invalidate();

-     }

-     function invalidate() {

-       if (stream) stream.valid = false, stream = null;

-       return projection;

-     }

-     return function() {

-       project = projectAt.apply(this, arguments);

-       projection.invert = project.invert && invert;

-       return reset();

-     };

-   }

-   function d3_geo_projectionRadians(stream) {

-     return d3_geo_transformPoint(stream, function(x, y) {

-       stream.point(x * d3_radians, y * d3_radians);

-     });

-   }

-   function d3_geo_equirectangular(λ, φ) {

-     return [ λ, φ ];

-   }

-   (d3.geo.equirectangular = function() {

-     return d3_geo_projection(d3_geo_equirectangular);

-   }).raw = d3_geo_equirectangular.invert = d3_geo_equirectangular;

-   d3.geo.rotation = function(rotate) {

-     rotate = d3_geo_rotation(rotate[0] % 360 * d3_radians, rotate[1] * d3_radians, rotate.length > 2 ? rotate[2] * d3_radians : 0);

-     function forward(coordinates) {

-       coordinates = rotate(coordinates[0] * d3_radians, coordinates[1] * d3_radians);

-       return coordinates[0] *= d3_degrees, coordinates[1] *= d3_degrees, coordinates;

-     }

-     forward.invert = function(coordinates) {

-       coordinates = rotate.invert(coordinates[0] * d3_radians, coordinates[1] * d3_radians);

-       return coordinates[0] *= d3_degrees, coordinates[1] *= d3_degrees, coordinates;

-     };

-     return forward;

-   };

-   function d3_geo_identityRotation(λ, φ) {

-     return [ λ > π ? λ - τ : λ < -π ? λ + τ : λ, φ ];

-   }

-   d3_geo_identityRotation.invert = d3_geo_equirectangular;

-   function d3_geo_rotation(δλ, δφ, δγ) {

-     return δλ ? δφ || δγ ? d3_geo_compose(d3_geo_rotationλ(δλ), d3_geo_rotationφγ(δφ, δγ)) : d3_geo_rotationλ(δλ) : δφ || δγ ? d3_geo_rotationφγ(δφ, δγ) : d3_geo_identityRotation;

-   }

-   function d3_geo_forwardRotationλ(δλ) {

-     return function(λ, φ) {

-       return λ += δλ, [ λ > π ? λ - τ : λ < -π ? λ + τ : λ, φ ];

-     };

-   }

-   function d3_geo_rotationλ(δλ) {

-     var rotation = d3_geo_forwardRotationλ(δλ);

-     rotation.invert = d3_geo_forwardRotationλ(-δλ);

-     return rotation;

-   }

-   function d3_geo_rotationφγ(δφ, δγ) {

-     var cosδφ = Math.cos(δφ), sinδφ = Math.sin(δφ), cosδγ = Math.cos(δγ), sinδγ = Math.sin(δγ);

-     function rotation(λ, φ) {

-       var cosφ = Math.cos(φ), x = Math.cos(λ) * cosφ, y = Math.sin(λ) * cosφ, z = Math.sin(φ), k = z * cosδφ + x * sinδφ;

-       return [ Math.atan2(y * cosδγ - k * sinδγ, x * cosδφ - z * sinδφ), d3_asin(k * cosδγ + y * sinδγ) ];

-     }

-     rotation.invert = function(λ, φ) {

-       var cosφ = Math.cos(φ), x = Math.cos(λ) * cosφ, y = Math.sin(λ) * cosφ, z = Math.sin(φ), k = z * cosδγ - y * sinδγ;

-       return [ Math.atan2(y * cosδγ + z * sinδγ, x * cosδφ + k * sinδφ), d3_asin(k * cosδφ - x * sinδφ) ];

-     };

-     return rotation;

-   }

-   d3.geo.circle = function() {

-     var origin = [ 0, 0 ], angle, precision = 6, interpolate;

-     function circle() {

-       var center = typeof origin === "function" ? origin.apply(this, arguments) : origin, rotate = d3_geo_rotation(-center[0] * d3_radians, -center[1] * d3_radians, 0).invert, ring = [];

-       interpolate(null, null, 1, {

-         point: function(x, y) {

-           ring.push(x = rotate(x, y));

-           x[0] *= d3_degrees, x[1] *= d3_degrees;

-         }

-       });

-       return {

-         type: "Polygon",

-         coordinates: [ ring ]

-       };

-     }

-     circle.origin = function(x) {

-       if (!arguments.length) return origin;

-       origin = x;

-       return circle;

-     };

-     circle.angle = function(x) {

-       if (!arguments.length) return angle;

-       interpolate = d3_geo_circleInterpolate((angle = +x) * d3_radians, precision * d3_radians);

-       return circle;

-     };

-     circle.precision = function(_) {

-       if (!arguments.length) return precision;

-       interpolate = d3_geo_circleInterpolate(angle * d3_radians, (precision = +_) * d3_radians);

-       return circle;

-     };

-     return circle.angle(90);

-   };

-   function d3_geo_circleInterpolate(radius, precision) {

-     var cr = Math.cos(radius), sr = Math.sin(radius);

-     return function(from, to, direction, listener) {

-       var step = direction * precision;

-       if (from != null) {

-         from = d3_geo_circleAngle(cr, from);

-         to = d3_geo_circleAngle(cr, to);

-         if (direction > 0 ? from < to : from > to) from += direction * τ;

-       } else {

-         from = radius + direction * τ;

-         to = radius - .5 * step;

-       }

-       for (var point, t = from; direction > 0 ? t > to : t < to; t -= step) {

-         listener.point((point = d3_geo_spherical([ cr, -sr * Math.cos(t), -sr * Math.sin(t) ]))[0], point[1]);

-       }

-     };

-   }

-   function d3_geo_circleAngle(cr, point) {

-     var a = d3_geo_cartesian(point);

-     a[0] -= cr;

-     d3_geo_cartesianNormalize(a);

-     var angle = d3_acos(-a[1]);

-     return ((-a[2] < 0 ? -angle : angle) + 2 * Math.PI - ε) % (2 * Math.PI);

-   }

-   d3.geo.distance = function(a, b) {

-     var Δλ = (b[0] - a[0]) * d3_radians, φ0 = a[1] * d3_radians, φ1 = b[1] * d3_radians, sinΔλ = Math.sin(Δλ), cosΔλ = Math.cos(Δλ), sinφ0 = Math.sin(φ0), cosφ0 = Math.cos(φ0), sinφ1 = Math.sin(φ1), cosφ1 = Math.cos(φ1), t;

-     return Math.atan2(Math.sqrt((t = cosφ1 * sinΔλ) * t + (t = cosφ0 * sinφ1 - sinφ0 * cosφ1 * cosΔλ) * t), sinφ0 * sinφ1 + cosφ0 * cosφ1 * cosΔλ);

-   };

-   d3.geo.graticule = function() {

-     var x1, x0, X1, X0, y1, y0, Y1, Y0, dx = 10, dy = dx, DX = 90, DY = 360, x, y, X, Y, precision = 2.5;

-     function graticule() {

-       return {

-         type: "MultiLineString",

-         coordinates: lines()

-       };

-     }

-     function lines() {

-       return d3.range(Math.ceil(X0 / DX) * DX, X1, DX).map(X).concat(d3.range(Math.ceil(Y0 / DY) * DY, Y1, DY).map(Y)).concat(d3.range(Math.ceil(x0 / dx) * dx, x1, dx).filter(function(x) {

-         return abs(x % DX) > ε;

-       }).map(x)).concat(d3.range(Math.ceil(y0 / dy) * dy, y1, dy).filter(function(y) {

-         return abs(y % DY) > ε;

-       }).map(y));

-     }

-     graticule.lines = function() {

-       return lines().map(function(coordinates) {

-         return {

-           type: "LineString",

-           coordinates: coordinates

-         };

-       });

-     };

-     graticule.outline = function() {

-       return {

-         type: "Polygon",

-         coordinates: [ X(X0).concat(Y(Y1).slice(1), X(X1).reverse().slice(1), Y(Y0).reverse().slice(1)) ]

-       };

-     };

-     graticule.extent = function(_) {

-       if (!arguments.length) return graticule.minorExtent();

-       return graticule.majorExtent(_).minorExtent(_);

-     };

-     graticule.majorExtent = function(_) {

-       if (!arguments.length) return [ [ X0, Y0 ], [ X1, Y1 ] ];

-       X0 = +_[0][0], X1 = +_[1][0];

-       Y0 = +_[0][1], Y1 = +_[1][1];

-       if (X0 > X1) _ = X0, X0 = X1, X1 = _;

-       if (Y0 > Y1) _ = Y0, Y0 = Y1, Y1 = _;

-       return graticule.precision(precision);

-     };

-     graticule.minorExtent = function(_) {

-       if (!arguments.length) return [ [ x0, y0 ], [ x1, y1 ] ];

-       x0 = +_[0][0], x1 = +_[1][0];

-       y0 = +_[0][1], y1 = +_[1][1];

-       if (x0 > x1) _ = x0, x0 = x1, x1 = _;

-       if (y0 > y1) _ = y0, y0 = y1, y1 = _;

-       return graticule.precision(precision);

-     };

-     graticule.step = function(_) {

-       if (!arguments.length) return graticule.minorStep();

-       return graticule.majorStep(_).minorStep(_);

-     };

-     graticule.majorStep = function(_) {

-       if (!arguments.length) return [ DX, DY ];

-       DX = +_[0], DY = +_[1];

-       return graticule;

-     };

-     graticule.minorStep = function(_) {

-       if (!arguments.length) return [ dx, dy ];

-       dx = +_[0], dy = +_[1];

-       return graticule;

-     };

-     graticule.precision = function(_) {

-       if (!arguments.length) return precision;

-       precision = +_;

-       x = d3_geo_graticuleX(y0, y1, 90);

-       y = d3_geo_graticuleY(x0, x1, precision);

-       X = d3_geo_graticuleX(Y0, Y1, 90);

-       Y = d3_geo_graticuleY(X0, X1, precision);

-       return graticule;

-     };

-     return graticule.majorExtent([ [ -180, -90 + ε ], [ 180, 90 - ε ] ]).minorExtent([ [ -180, -80 - ε ], [ 180, 80 + ε ] ]);

-   };

-   function d3_geo_graticuleX(y0, y1, dy) {

-     var y = d3.range(y0, y1 - ε, dy).concat(y1);

-     return function(x) {

-       return y.map(function(y) {

-         return [ x, y ];

-       });

-     };

-   }

-   function d3_geo_graticuleY(x0, x1, dx) {

-     var x = d3.range(x0, x1 - ε, dx).concat(x1);

-     return function(y) {

-       return x.map(function(x) {

-         return [ x, y ];

-       });

-     };

-   }

-   function d3_source(d) {

-     return d.source;

-   }

-   function d3_target(d) {

-     return d.target;

-   }

-   d3.geo.greatArc = function() {

-     var source = d3_source, source_, target = d3_target, target_;

-     function greatArc() {

-       return {

-         type: "LineString",

-         coordinates: [ source_ || source.apply(this, arguments), target_ || target.apply(this, arguments) ]

-       };

-     }

-     greatArc.distance = function() {

-       return d3.geo.distance(source_ || source.apply(this, arguments), target_ || target.apply(this, arguments));

-     };

-     greatArc.source = function(_) {

-       if (!arguments.length) return source;

-       source = _, source_ = typeof _ === "function" ? null : _;

-       return greatArc;

-     };

-     greatArc.target = function(_) {

-       if (!arguments.length) return target;

-       target = _, target_ = typeof _ === "function" ? null : _;

-       return greatArc;

-     };

-     greatArc.precision = function() {

-       return arguments.length ? greatArc : 0;

-     };

-     return greatArc;

-   };

-   d3.geo.interpolate = function(source, target) {

-     return d3_geo_interpolate(source[0] * d3_radians, source[1] * d3_radians, target[0] * d3_radians, target[1] * d3_radians);

-   };

-   function d3_geo_interpolate(x0, y0, x1, y1) {

-     var cy0 = Math.cos(y0), sy0 = Math.sin(y0), cy1 = Math.cos(y1), sy1 = Math.sin(y1), kx0 = cy0 * Math.cos(x0), ky0 = cy0 * Math.sin(x0), kx1 = cy1 * Math.cos(x1), ky1 = cy1 * Math.sin(x1), d = 2 * Math.asin(Math.sqrt(d3_haversin(y1 - y0) + cy0 * cy1 * d3_haversin(x1 - x0))), k = 1 / Math.sin(d);

-     var interpolate = d ? function(t) {

-       var B = Math.sin(t *= d) * k, A = Math.sin(d - t) * k, x = A * kx0 + B * kx1, y = A * ky0 + B * ky1, z = A * sy0 + B * sy1;

-       return [ Math.atan2(y, x) * d3_degrees, Math.atan2(z, Math.sqrt(x * x + y * y)) * d3_degrees ];

-     } : function() {

-       return [ x0 * d3_degrees, y0 * d3_degrees ];

-     };

-     interpolate.distance = d;

-     return interpolate;

-   }

-   d3.geo.length = function(object) {

-     d3_geo_lengthSum = 0;

-     d3.geo.stream(object, d3_geo_length);

-     return d3_geo_lengthSum;

-   };

-   var d3_geo_lengthSum;

-   var d3_geo_length = {

-     sphere: d3_noop,

-     point: d3_noop,

-     lineStart: d3_geo_lengthLineStart,

-     lineEnd: d3_noop,

-     polygonStart: d3_noop,

-     polygonEnd: d3_noop

-   };

-   function d3_geo_lengthLineStart() {

-     var λ0, sinφ0, cosφ0;

-     d3_geo_length.point = function(λ, φ) {

-       λ0 = λ * d3_radians, sinφ0 = Math.sin(φ *= d3_radians), cosφ0 = Math.cos(φ);

-       d3_geo_length.point = nextPoint;

-     };

-     d3_geo_length.lineEnd = function() {

-       d3_geo_length.point = d3_geo_length.lineEnd = d3_noop;

-     };

-     function nextPoint(λ, φ) {

-       var sinφ = Math.sin(φ *= d3_radians), cosφ = Math.cos(φ), t = abs((λ *= d3_radians) - λ0), cosΔλ = Math.cos(t);

-       d3_geo_lengthSum += Math.atan2(Math.sqrt((t = cosφ * Math.sin(t)) * t + (t = cosφ0 * sinφ - sinφ0 * cosφ * cosΔλ) * t), sinφ0 * sinφ + cosφ0 * cosφ * cosΔλ);

-       λ0 = λ, sinφ0 = sinφ, cosφ0 = cosφ;

-     }

-   }

-   function d3_geo_azimuthal(scale, angle) {

-     function azimuthal(λ, φ) {

-       var cosλ = Math.cos(λ), cosφ = Math.cos(φ), k = scale(cosλ * cosφ);

-       return [ k * cosφ * Math.sin(λ), k * Math.sin(φ) ];

-     }

-     azimuthal.invert = function(x, y) {

-       var ρ = Math.sqrt(x * x + y * y), c = angle(ρ), sinc = Math.sin(c), cosc = Math.cos(c);

-       return [ Math.atan2(x * sinc, ρ * cosc), Math.asin(ρ && y * sinc / ρ) ];

-     };

-     return azimuthal;

-   }

-   var d3_geo_azimuthalEqualArea = d3_geo_azimuthal(function(cosλcosφ) {

-     return Math.sqrt(2 / (1 + cosλcosφ));

-   }, function(ρ) {

-     return 2 * Math.asin(ρ / 2);

-   });

-   (d3.geo.azimuthalEqualArea = function() {

-     return d3_geo_projection(d3_geo_azimuthalEqualArea);

-   }).raw = d3_geo_azimuthalEqualArea;

-   var d3_geo_azimuthalEquidistant = d3_geo_azimuthal(function(cosλcosφ) {

-     var c = Math.acos(cosλcosφ);

-     return c && c / Math.sin(c);

-   }, d3_identity);

-   (d3.geo.azimuthalEquidistant = function() {

-     return d3_geo_projection(d3_geo_azimuthalEquidistant);

-   }).raw = d3_geo_azimuthalEquidistant;

-   function d3_geo_conicConformal(φ0, φ1) {

-     var cosφ0 = Math.cos(φ0), t = function(φ) {

-       return Math.tan(π / 4 + φ / 2);

-     }, n = φ0 === φ1 ? Math.sin(φ0) : Math.log(cosφ0 / Math.cos(φ1)) / Math.log(t(φ1) / t(φ0)), F = cosφ0 * Math.pow(t(φ0), n) / n;

-     if (!n) return d3_geo_mercator;

-     function forward(λ, φ) {

-       if (F > 0) {

-         if (φ < -halfπ + ε) φ = -halfπ + ε;

-       } else {

-         if (φ > halfπ - ε) φ = halfπ - ε;

-       }

-       var ρ = F / Math.pow(t(φ), n);

-       return [ ρ * Math.sin(n * λ), F - ρ * Math.cos(n * λ) ];

-     }

-     forward.invert = function(x, y) {

-       var ρ0_y = F - y, ρ = d3_sgn(n) * Math.sqrt(x * x + ρ0_y * ρ0_y);

-       return [ Math.atan2(x, ρ0_y) / n, 2 * Math.atan(Math.pow(F / ρ, 1 / n)) - halfπ ];

-     };

-     return forward;

-   }

-   (d3.geo.conicConformal = function() {

-     return d3_geo_conic(d3_geo_conicConformal);

-   }).raw = d3_geo_conicConformal;

-   function d3_geo_conicEquidistant(φ0, φ1) {

-     var cosφ0 = Math.cos(φ0), n = φ0 === φ1 ? Math.sin(φ0) : (cosφ0 - Math.cos(φ1)) / (φ1 - φ0), G = cosφ0 / n + φ0;

-     if (abs(n) < ε) return d3_geo_equirectangular;

-     function forward(λ, φ) {

-       var ρ = G - φ;

-       return [ ρ * Math.sin(n * λ), G - ρ * Math.cos(n * λ) ];

-     }

-     forward.invert = function(x, y) {

-       var ρ0_y = G - y;

-       return [ Math.atan2(x, ρ0_y) / n, G - d3_sgn(n) * Math.sqrt(x * x + ρ0_y * ρ0_y) ];

-     };

-     return forward;

-   }

-   (d3.geo.conicEquidistant = function() {

-     return d3_geo_conic(d3_geo_conicEquidistant);

-   }).raw = d3_geo_conicEquidistant;

-   var d3_geo_gnomonic = d3_geo_azimuthal(function(cosλcosφ) {

-     return 1 / cosλcosφ;

-   }, Math.atan);

-   (d3.geo.gnomonic = function() {

-     return d3_geo_projection(d3_geo_gnomonic);

-   }).raw = d3_geo_gnomonic;

-   function d3_geo_mercator(λ, φ) {

-     return [ λ, Math.log(Math.tan(π / 4 + φ / 2)) ];

-   }

-   d3_geo_mercator.invert = function(x, y) {

-     return [ x, 2 * Math.atan(Math.exp(y)) - halfπ ];

-   };

-   function d3_geo_mercatorProjection(project) {

-     var m = d3_geo_projection(project), scale = m.scale, translate = m.translate, clipExtent = m.clipExtent, clipAuto;

-     m.scale = function() {

-       var v = scale.apply(m, arguments);

-       return v === m ? clipAuto ? m.clipExtent(null) : m : v;

-     };

-     m.translate = function() {

-       var v = translate.apply(m, arguments);

-       return v === m ? clipAuto ? m.clipExtent(null) : m : v;

-     };

-     m.clipExtent = function(_) {

-       var v = clipExtent.apply(m, arguments);

-       if (v === m) {

-         if (clipAuto = _ == null) {

-           var k = π * scale(), t = translate();

-           clipExtent([ [ t[0] - k, t[1] - k ], [ t[0] + k, t[1] + k ] ]);

-         }

-       } else if (clipAuto) {

-         v = null;

-       }

-       return v;

-     };

-     return m.clipExtent(null);

-   }

-   (d3.geo.mercator = function() {

-     return d3_geo_mercatorProjection(d3_geo_mercator);

-   }).raw = d3_geo_mercator;

-   var d3_geo_orthographic = d3_geo_azimuthal(function() {

-     return 1;

-   }, Math.asin);

-   (d3.geo.orthographic = function() {

-     return d3_geo_projection(d3_geo_orthographic);

-   }).raw = d3_geo_orthographic;

-   var d3_geo_stereographic = d3_geo_azimuthal(function(cosλcosφ) {

-     return 1 / (1 + cosλcosφ);

-   }, function(ρ) {

-     return 2 * Math.atan(ρ);

-   });

-   (d3.geo.stereographic = function() {

-     return d3_geo_projection(d3_geo_stereographic);

-   }).raw = d3_geo_stereographic;

-   function d3_geo_transverseMercator(λ, φ) {

-     return [ Math.log(Math.tan(π / 4 + φ / 2)), -λ ];

-   }

-   d3_geo_transverseMercator.invert = function(x, y) {

-     return [ -y, 2 * Math.atan(Math.exp(x)) - halfπ ];

-   };

-   (d3.geo.transverseMercator = function() {

-     var projection = d3_geo_mercatorProjection(d3_geo_transverseMercator), center = projection.center, rotate = projection.rotate;

-     projection.center = function(_) {

-       return _ ? center([ -_[1], _[0] ]) : (_ = center(), [ _[1], -_[0] ]);

-     };

-     projection.rotate = function(_) {

-       return _ ? rotate([ _[0], _[1], _.length > 2 ? _[2] + 90 : 90 ]) : (_ = rotate(),

-       [ _[0], _[1], _[2] - 90 ]);

-     };

-     return rotate([ 0, 0, 90 ]);

-   }).raw = d3_geo_transverseMercator;

-   d3.geom = {};

-   function d3_geom_pointX(d) {

-     return d[0];

-   }

-   function d3_geom_pointY(d) {

-     return d[1];

-   }

-   d3.geom.hull = function(vertices) {

-     var x = d3_geom_pointX, y = d3_geom_pointY;

-     if (arguments.length) return hull(vertices);

-     function hull(data) {

-       if (data.length < 3) return [];

-       var fx = d3_functor(x), fy = d3_functor(y), i, n = data.length, points = [], flippedPoints = [];

-       for (i = 0; i < n; i++) {

-         points.push([ +fx.call(this, data[i], i), +fy.call(this, data[i], i), i ]);

-       }

-       points.sort(d3_geom_hullOrder);

-       for (i = 0; i < n; i++) flippedPoints.push([ points[i][0], -points[i][1] ]);

-       var upper = d3_geom_hullUpper(points), lower = d3_geom_hullUpper(flippedPoints);

-       var skipLeft = lower[0] === upper[0], skipRight = lower[lower.length - 1] === upper[upper.length - 1], polygon = [];

-       for (i = upper.length - 1; i >= 0; --i) polygon.push(data[points[upper[i]][2]]);

-       for (i = +skipLeft; i < lower.length - skipRight; ++i) polygon.push(data[points[lower[i]][2]]);

-       return polygon;

-     }

-     hull.x = function(_) {

-       return arguments.length ? (x = _, hull) : x;

-     };

-     hull.y = function(_) {

-       return arguments.length ? (y = _, hull) : y;

-     };

-     return hull;

-   };

-   function d3_geom_hullUpper(points) {

-     var n = points.length, hull = [ 0, 1 ], hs = 2;

-     for (var i = 2; i < n; i++) {

-       while (hs > 1 && d3_cross2d(points[hull[hs - 2]], points[hull[hs - 1]], points[i]) <= 0) --hs;

-       hull[hs++] = i;

-     }

-     return hull.slice(0, hs);

-   }

-   function d3_geom_hullOrder(a, b) {

-     return a[0] - b[0] || a[1] - b[1];

-   }

-   d3.geom.polygon = function(coordinates) {

-     d3_subclass(coordinates, d3_geom_polygonPrototype);

-     return coordinates;

-   };

-   var d3_geom_polygonPrototype = d3.geom.polygon.prototype = [];

-   d3_geom_polygonPrototype.area = function() {

-     var i = -1, n = this.length, a, b = this[n - 1], area = 0;

-     while (++i < n) {

-       a = b;

-       b = this[i];

-       area += a[1] * b[0] - a[0] * b[1];

-     }

-     return area * .5;

-   };

-   d3_geom_polygonPrototype.centroid = function(k) {

-     var i = -1, n = this.length, x = 0, y = 0, a, b = this[n - 1], c;

-     if (!arguments.length) k = -1 / (6 * this.area());

-     while (++i < n) {

-       a = b;

-       b = this[i];

-       c = a[0] * b[1] - b[0] * a[1];

-       x += (a[0] + b[0]) * c;

-       y += (a[1] + b[1]) * c;

-     }

-     return [ x * k, y * k ];

-   };

-   d3_geom_polygonPrototype.clip = function(subject) {

-     var input, closed = d3_geom_polygonClosed(subject), i = -1, n = this.length - d3_geom_polygonClosed(this), j, m, a = this[n - 1], b, c, d;

-     while (++i < n) {

-       input = subject.slice();

-       subject.length = 0;

-       b = this[i];

-       c = input[(m = input.length - closed) - 1];

-       j = -1;

-       while (++j < m) {

-         d = input[j];

-         if (d3_geom_polygonInside(d, a, b)) {

-           if (!d3_geom_polygonInside(c, a, b)) {

-             subject.push(d3_geom_polygonIntersect(c, d, a, b));

-           }

-           subject.push(d);

-         } else if (d3_geom_polygonInside(c, a, b)) {

-           subject.push(d3_geom_polygonIntersect(c, d, a, b));

-         }

-         c = d;

-       }

-       if (closed) subject.push(subject[0]);

-       a = b;

-     }

-     return subject;

-   };

-   function d3_geom_polygonInside(p, a, b) {

-     return (b[0] - a[0]) * (p[1] - a[1]) < (b[1] - a[1]) * (p[0] - a[0]);

-   }

-   function d3_geom_polygonIntersect(c, d, a, b) {

-     var x1 = c[0], x3 = a[0], x21 = d[0] - x1, x43 = b[0] - x3, y1 = c[1], y3 = a[1], y21 = d[1] - y1, y43 = b[1] - y3, ua = (x43 * (y1 - y3) - y43 * (x1 - x3)) / (y43 * x21 - x43 * y21);

-     return [ x1 + ua * x21, y1 + ua * y21 ];

-   }

-   function d3_geom_polygonClosed(coordinates) {

-     var a = coordinates[0], b = coordinates[coordinates.length - 1];

-     return !(a[0] - b[0] || a[1] - b[1]);

-   }

-   var d3_geom_voronoiEdges, d3_geom_voronoiCells, d3_geom_voronoiBeaches, d3_geom_voronoiBeachPool = [], d3_geom_voronoiFirstCircle, d3_geom_voronoiCircles, d3_geom_voronoiCirclePool = [];

-   function d3_geom_voronoiBeach() {

-     d3_geom_voronoiRedBlackNode(this);

-     this.edge = this.site = this.circle = null;

-   }

-   function d3_geom_voronoiCreateBeach(site) {

-     var beach = d3_geom_voronoiBeachPool.pop() || new d3_geom_voronoiBeach();

-     beach.site = site;

-     return beach;

-   }

-   function d3_geom_voronoiDetachBeach(beach) {

-     d3_geom_voronoiDetachCircle(beach);

-     d3_geom_voronoiBeaches.remove(beach);

-     d3_geom_voronoiBeachPool.push(beach);

-     d3_geom_voronoiRedBlackNode(beach);

-   }

-   function d3_geom_voronoiRemoveBeach(beach) {

-     var circle = beach.circle, x = circle.x, y = circle.cy, vertex = {

-       x: x,

-       y: y

-     }, previous = beach.P, next = beach.N, disappearing = [ beach ];

-     d3_geom_voronoiDetachBeach(beach);

-     var lArc = previous;

-     while (lArc.circle && abs(x - lArc.circle.x) < ε && abs(y - lArc.circle.cy) < ε) {

-       previous = lArc.P;

-       disappearing.unshift(lArc);

-       d3_geom_voronoiDetachBeach(lArc);

-       lArc = previous;

-     }

-     disappearing.unshift(lArc);

-     d3_geom_voronoiDetachCircle(lArc);

-     var rArc = next;

-     while (rArc.circle && abs(x - rArc.circle.x) < ε && abs(y - rArc.circle.cy) < ε) {

-       next = rArc.N;

-       disappearing.push(rArc);

-       d3_geom_voronoiDetachBeach(rArc);

-       rArc = next;

-     }

-     disappearing.push(rArc);

-     d3_geom_voronoiDetachCircle(rArc);

-     var nArcs = disappearing.length, iArc;

-     for (iArc = 1; iArc < nArcs; ++iArc) {

-       rArc = disappearing[iArc];

-       lArc = disappearing[iArc - 1];

-       d3_geom_voronoiSetEdgeEnd(rArc.edge, lArc.site, rArc.site, vertex);

-     }

-     lArc = disappearing[0];

-     rArc = disappearing[nArcs - 1];

-     rArc.edge = d3_geom_voronoiCreateEdge(lArc.site, rArc.site, null, vertex);

-     d3_geom_voronoiAttachCircle(lArc);

-     d3_geom_voronoiAttachCircle(rArc);

-   }

-   function d3_geom_voronoiAddBeach(site) {

-     var x = site.x, directrix = site.y, lArc, rArc, dxl, dxr, node = d3_geom_voronoiBeaches._;

-     while (node) {

-       dxl = d3_geom_voronoiLeftBreakPoint(node, directrix) - x;

-       if (dxl > ε) node = node.L; else {

-         dxr = x - d3_geom_voronoiRightBreakPoint(node, directrix);

-         if (dxr > ε) {

-           if (!node.R) {

-             lArc = node;

-             break;

-           }

-           node = node.R;

-         } else {

-           if (dxl > -ε) {

-             lArc = node.P;

-             rArc = node;

-           } else if (dxr > -ε) {

-             lArc = node;

-             rArc = node.N;

-           } else {

-             lArc = rArc = node;

-           }

-           break;

-         }

-       }

-     }

-     var newArc = d3_geom_voronoiCreateBeach(site);

-     d3_geom_voronoiBeaches.insert(lArc, newArc);

-     if (!lArc && !rArc) return;

-     if (lArc === rArc) {

-       d3_geom_voronoiDetachCircle(lArc);

-       rArc = d3_geom_voronoiCreateBeach(lArc.site);

-       d3_geom_voronoiBeaches.insert(newArc, rArc);

-       newArc.edge = rArc.edge = d3_geom_voronoiCreateEdge(lArc.site, newArc.site);

-       d3_geom_voronoiAttachCircle(lArc);

-       d3_geom_voronoiAttachCircle(rArc);

-       return;

-     }

-     if (!rArc) {

-       newArc.edge = d3_geom_voronoiCreateEdge(lArc.site, newArc.site);

-       return;

-     }

-     d3_geom_voronoiDetachCircle(lArc);

-     d3_geom_voronoiDetachCircle(rArc);

-     var lSite = lArc.site, ax = lSite.x, ay = lSite.y, bx = site.x - ax, by = site.y - ay, rSite = rArc.site, cx = rSite.x - ax, cy = rSite.y - ay, d = 2 * (bx * cy - by * cx), hb = bx * bx + by * by, hc = cx * cx + cy * cy, vertex = {

-       x: (cy * hb - by * hc) / d + ax,

-       y: (bx * hc - cx * hb) / d + ay

-     };

-     d3_geom_voronoiSetEdgeEnd(rArc.edge, lSite, rSite, vertex);

-     newArc.edge = d3_geom_voronoiCreateEdge(lSite, site, null, vertex);

-     rArc.edge = d3_geom_voronoiCreateEdge(site, rSite, null, vertex);

-     d3_geom_voronoiAttachCircle(lArc);

-     d3_geom_voronoiAttachCircle(rArc);

-   }

-   function d3_geom_voronoiLeftBreakPoint(arc, directrix) {

-     var site = arc.site, rfocx = site.x, rfocy = site.y, pby2 = rfocy - directrix;

-     if (!pby2) return rfocx;

-     var lArc = arc.P;

-     if (!lArc) return -Infinity;

-     site = lArc.site;

-     var lfocx = site.x, lfocy = site.y, plby2 = lfocy - directrix;

-     if (!plby2) return lfocx;

-     var hl = lfocx - rfocx, aby2 = 1 / pby2 - 1 / plby2, b = hl / plby2;

-     if (aby2) return (-b + Math.sqrt(b * b - 2 * aby2 * (hl * hl / (-2 * plby2) - lfocy + plby2 / 2 + rfocy - pby2 / 2))) / aby2 + rfocx;

-     return (rfocx + lfocx) / 2;

-   }

-   function d3_geom_voronoiRightBreakPoint(arc, directrix) {

-     var rArc = arc.N;

-     if (rArc) return d3_geom_voronoiLeftBreakPoint(rArc, directrix);

-     var site = arc.site;

-     return site.y === directrix ? site.x : Infinity;

-   }

-   function d3_geom_voronoiCell(site) {

-     this.site = site;

-     this.edges = [];

-   }

-   d3_geom_voronoiCell.prototype.prepare = function() {

-     var halfEdges = this.edges, iHalfEdge = halfEdges.length, edge;

-     while (iHalfEdge--) {

-       edge = halfEdges[iHalfEdge].edge;

-       if (!edge.b || !edge.a) halfEdges.splice(iHalfEdge, 1);

-     }

-     halfEdges.sort(d3_geom_voronoiHalfEdgeOrder);

-     return halfEdges.length;

-   };

-   function d3_geom_voronoiCloseCells(extent) {

-     var x0 = extent[0][0], x1 = extent[1][0], y0 = extent[0][1], y1 = extent[1][1], x2, y2, x3, y3, cells = d3_geom_voronoiCells, iCell = cells.length, cell, iHalfEdge, halfEdges, nHalfEdges, start, end;

-     while (iCell--) {

-       cell = cells[iCell];

-       if (!cell || !cell.prepare()) continue;

-       halfEdges = cell.edges;

-       nHalfEdges = halfEdges.length;

-       iHalfEdge = 0;

-       while (iHalfEdge < nHalfEdges) {

-         end = halfEdges[iHalfEdge].end(), x3 = end.x, y3 = end.y;

-         start = halfEdges[++iHalfEdge % nHalfEdges].start(), x2 = start.x, y2 = start.y;

-         if (abs(x3 - x2) > ε || abs(y3 - y2) > ε) {

-           halfEdges.splice(iHalfEdge, 0, new d3_geom_voronoiHalfEdge(d3_geom_voronoiCreateBorderEdge(cell.site, end, abs(x3 - x0) < ε && y1 - y3 > ε ? {

-             x: x0,

-             y: abs(x2 - x0) < ε ? y2 : y1

-           } : abs(y3 - y1) < ε && x1 - x3 > ε ? {

-             x: abs(y2 - y1) < ε ? x2 : x1,

-             y: y1

-           } : abs(x3 - x1) < ε && y3 - y0 > ε ? {

-             x: x1,

-             y: abs(x2 - x1) < ε ? y2 : y0

-           } : abs(y3 - y0) < ε && x3 - x0 > ε ? {

-             x: abs(y2 - y0) < ε ? x2 : x0,

-             y: y0

-           } : null), cell.site, null));

-           ++nHalfEdges;

-         }

-       }

-     }

-   }

-   function d3_geom_voronoiHalfEdgeOrder(a, b) {

-     return b.angle - a.angle;

-   }

-   function d3_geom_voronoiCircle() {

-     d3_geom_voronoiRedBlackNode(this);

-     this.x = this.y = this.arc = this.site = this.cy = null;

-   }

-   function d3_geom_voronoiAttachCircle(arc) {

-     var lArc = arc.P, rArc = arc.N;

-     if (!lArc || !rArc) return;

-     var lSite = lArc.site, cSite = arc.site, rSite = rArc.site;

-     if (lSite === rSite) return;

-     var bx = cSite.x, by = cSite.y, ax = lSite.x - bx, ay = lSite.y - by, cx = rSite.x - bx, cy = rSite.y - by;

-     var d = 2 * (ax * cy - ay * cx);

-     if (d >= -ε2) return;

-     var ha = ax * ax + ay * ay, hc = cx * cx + cy * cy, x = (cy * ha - ay * hc) / d, y = (ax * hc - cx * ha) / d, cy = y + by;

-     var circle = d3_geom_voronoiCirclePool.pop() || new d3_geom_voronoiCircle();

-     circle.arc = arc;

-     circle.site = cSite;

-     circle.x = x + bx;

-     circle.y = cy + Math.sqrt(x * x + y * y);

-     circle.cy = cy;

-     arc.circle = circle;

-     var before = null, node = d3_geom_voronoiCircles._;

-     while (node) {

-       if (circle.y < node.y || circle.y === node.y && circle.x <= node.x) {

-         if (node.L) node = node.L; else {

-           before = node.P;

-           break;

-         }

-       } else {

-         if (node.R) node = node.R; else {

-           before = node;

-           break;

-         }

-       }

-     }

-     d3_geom_voronoiCircles.insert(before, circle);

-     if (!before) d3_geom_voronoiFirstCircle = circle;

-   }

-   function d3_geom_voronoiDetachCircle(arc) {

-     var circle = arc.circle;

-     if (circle) {

-       if (!circle.P) d3_geom_voronoiFirstCircle = circle.N;

-       d3_geom_voronoiCircles.remove(circle);

-       d3_geom_voronoiCirclePool.push(circle);

-       d3_geom_voronoiRedBlackNode(circle);

-       arc.circle = null;

-     }

-   }

-   function d3_geom_voronoiClipEdges(extent) {

-     var edges = d3_geom_voronoiEdges, clip = d3_geom_clipLine(extent[0][0], extent[0][1], extent[1][0], extent[1][1]), i = edges.length, e;

-     while (i--) {

-       e = edges[i];

-       if (!d3_geom_voronoiConnectEdge(e, extent) || !clip(e) || abs(e.a.x - e.b.x) < ε && abs(e.a.y - e.b.y) < ε) {

-         e.a = e.b = null;

-         edges.splice(i, 1);

-       }

-     }

-   }

-   function d3_geom_voronoiConnectEdge(edge, extent) {

-     var vb = edge.b;

-     if (vb) return true;

-     var va = edge.a, x0 = extent[0][0], x1 = extent[1][0], y0 = extent[0][1], y1 = extent[1][1], lSite = edge.l, rSite = edge.r, lx = lSite.x, ly = lSite.y, rx = rSite.x, ry = rSite.y, fx = (lx + rx) / 2, fy = (ly + ry) / 2, fm, fb;

-     if (ry === ly) {

-       if (fx < x0 || fx >= x1) return;

-       if (lx > rx) {

-         if (!va) va = {

-           x: fx,

-           y: y0

-         }; else if (va.y >= y1) return;

-         vb = {

-           x: fx,

-           y: y1

-         };

-       } else {

-         if (!va) va = {

-           x: fx,

-           y: y1

-         }; else if (va.y < y0) return;

-         vb = {

-           x: fx,

-           y: y0

-         };

-       }

-     } else {

-       fm = (lx - rx) / (ry - ly);

-       fb = fy - fm * fx;

-       if (fm < -1 || fm > 1) {

-         if (lx > rx) {

-           if (!va) va = {

-             x: (y0 - fb) / fm,

-             y: y0

-           }; else if (va.y >= y1) return;

-           vb = {

-             x: (y1 - fb) / fm,

-             y: y1

-           };

-         } else {

-           if (!va) va = {

-             x: (y1 - fb) / fm,

-             y: y1

-           }; else if (va.y < y0) return;

-           vb = {

-             x: (y0 - fb) / fm,

-             y: y0

-           };

-         }

-       } else {

-         if (ly < ry) {

-           if (!va) va = {

-             x: x0,

-             y: fm * x0 + fb

-           }; else if (va.x >= x1) return;

-           vb = {

-             x: x1,

-             y: fm * x1 + fb

-           };

-         } else {

-           if (!va) va = {

-             x: x1,

-             y: fm * x1 + fb

-           }; else if (va.x < x0) return;

-           vb = {

-             x: x0,

-             y: fm * x0 + fb

-           };

-         }

-       }

-     }

-     edge.a = va;

-     edge.b = vb;

-     return true;

-   }

-   function d3_geom_voronoiEdge(lSite, rSite) {

-     this.l = lSite;

-     this.r = rSite;

-     this.a = this.b = null;

-   }

-   function d3_geom_voronoiCreateEdge(lSite, rSite, va, vb) {

-     var edge = new d3_geom_voronoiEdge(lSite, rSite);

-     d3_geom_voronoiEdges.push(edge);

-     if (va) d3_geom_voronoiSetEdgeEnd(edge, lSite, rSite, va);

-     if (vb) d3_geom_voronoiSetEdgeEnd(edge, rSite, lSite, vb);

-     d3_geom_voronoiCells[lSite.i].edges.push(new d3_geom_voronoiHalfEdge(edge, lSite, rSite));

-     d3_geom_voronoiCells[rSite.i].edges.push(new d3_geom_voronoiHalfEdge(edge, rSite, lSite));

-     return edge;

-   }

-   function d3_geom_voronoiCreateBorderEdge(lSite, va, vb) {

-     var edge = new d3_geom_voronoiEdge(lSite, null);

-     edge.a = va;

-     edge.b = vb;

-     d3_geom_voronoiEdges.push(edge);

-     return edge;

-   }

-   function d3_geom_voronoiSetEdgeEnd(edge, lSite, rSite, vertex) {

-     if (!edge.a && !edge.b) {

-       edge.a = vertex;

-       edge.l = lSite;

-       edge.r = rSite;

-     } else if (edge.l === rSite) {

-       edge.b = vertex;

-     } else {

-       edge.a = vertex;

-     }

-   }

-   function d3_geom_voronoiHalfEdge(edge, lSite, rSite) {

-     var va = edge.a, vb = edge.b;

-     this.edge = edge;

-     this.site = lSite;

-     this.angle = rSite ? Math.atan2(rSite.y - lSite.y, rSite.x - lSite.x) : edge.l === lSite ? Math.atan2(vb.x - va.x, va.y - vb.y) : Math.atan2(va.x - vb.x, vb.y - va.y);

-   }

-   d3_geom_voronoiHalfEdge.prototype = {

-     start: function() {

-       return this.edge.l === this.site ? this.edge.a : this.edge.b;

-     },

-     end: function() {

-       return this.edge.l === this.site ? this.edge.b : this.edge.a;

-     }

-   };

-   function d3_geom_voronoiRedBlackTree() {

-     this._ = null;

-   }

-   function d3_geom_voronoiRedBlackNode(node) {

-     node.U = node.C = node.L = node.R = node.P = node.N = null;

-   }

-   d3_geom_voronoiRedBlackTree.prototype = {

-     insert: function(after, node) {

-       var parent, grandpa, uncle;

-       if (after) {

-         node.P = after;

-         node.N = after.N;

-         if (after.N) after.N.P = node;

-         after.N = node;

-         if (after.R) {

-           after = after.R;

-           while (after.L) after = after.L;

-           after.L = node;

-         } else {

-           after.R = node;

-         }

-         parent = after;

-       } else if (this._) {

-         after = d3_geom_voronoiRedBlackFirst(this._);

-         node.P = null;

-         node.N = after;

-         after.P = after.L = node;

-         parent = after;

-       } else {

-         node.P = node.N = null;

-         this._ = node;

-         parent = null;

-       }

-       node.L = node.R = null;

-       node.U = parent;

-       node.C = true;

-       after = node;

-       while (parent && parent.C) {

-         grandpa = parent.U;

-         if (parent === grandpa.L) {

-           uncle = grandpa.R;

-           if (uncle && uncle.C) {

-             parent.C = uncle.C = false;

-             grandpa.C = true;

-             after = grandpa;

-           } else {

-             if (after === parent.R) {

-               d3_geom_voronoiRedBlackRotateLeft(this, parent);

-               after = parent;

-               parent = after.U;

-             }

-             parent.C = false;

-             grandpa.C = true;

-             d3_geom_voronoiRedBlackRotateRight(this, grandpa);

-           }

-         } else {

-           uncle = grandpa.L;

-           if (uncle && uncle.C) {

-             parent.C = uncle.C = false;

-             grandpa.C = true;

-             after = grandpa;

-           } else {

-             if (after === parent.L) {

-               d3_geom_voronoiRedBlackRotateRight(this, parent);

-               after = parent;

-               parent = after.U;

-             }

-             parent.C = false;

-             grandpa.C = true;

-             d3_geom_voronoiRedBlackRotateLeft(this, grandpa);

-           }

-         }

-         parent = after.U;

-       }

-       this._.C = false;

-     },

-     remove: function(node) {

-       if (node.N) node.N.P = node.P;

-       if (node.P) node.P.N = node.N;

-       node.N = node.P = null;

-       var parent = node.U, sibling, left = node.L, right = node.R, next, red;

-       if (!left) next = right; else if (!right) next = left; else next = d3_geom_voronoiRedBlackFirst(right);

-       if (parent) {

-         if (parent.L === node) parent.L = next; else parent.R = next;

-       } else {

-         this._ = next;

-       }

-       if (left && right) {

-         red = next.C;

-         next.C = node.C;

-         next.L = left;

-         left.U = next;

-         if (next !== right) {

-           parent = next.U;

-           next.U = node.U;

-           node = next.R;

-           parent.L = node;

-           next.R = right;

-           right.U = next;

-         } else {

-           next.U = parent;

-           parent = next;

-           node = next.R;

-         }

-       } else {

-         red = node.C;

-         node = next;

-       }

-       if (node) node.U = parent;

-       if (red) return;

-       if (node && node.C) {

-         node.C = false;

-         return;

-       }

-       do {

-         if (node === this._) break;

-         if (node === parent.L) {

-           sibling = parent.R;

-           if (sibling.C) {

-             sibling.C = false;

-             parent.C = true;

-             d3_geom_voronoiRedBlackRotateLeft(this, parent);

-             sibling = parent.R;

-           }

-           if (sibling.L && sibling.L.C || sibling.R && sibling.R.C) {

-             if (!sibling.R || !sibling.R.C) {

-               sibling.L.C = false;

-               sibling.C = true;

-               d3_geom_voronoiRedBlackRotateRight(this, sibling);

-               sibling = parent.R;

-             }

-             sibling.C = parent.C;

-             parent.C = sibling.R.C = false;

-             d3_geom_voronoiRedBlackRotateLeft(this, parent);

-             node = this._;

-             break;

-           }

-         } else {

-           sibling = parent.L;

-           if (sibling.C) {

-             sibling.C = false;

-             parent.C = true;

-             d3_geom_voronoiRedBlackRotateRight(this, parent);

-             sibling = parent.L;

-           }

-           if (sibling.L && sibling.L.C || sibling.R && sibling.R.C) {

-             if (!sibling.L || !sibling.L.C) {

-               sibling.R.C = false;

-               sibling.C = true;

-               d3_geom_voronoiRedBlackRotateLeft(this, sibling);

-               sibling = parent.L;

-             }

-             sibling.C = parent.C;

-             parent.C = sibling.L.C = false;

-             d3_geom_voronoiRedBlackRotateRight(this, parent);

-             node = this._;

-             break;

-           }

-         }

-         sibling.C = true;

-         node = parent;

-         parent = parent.U;

-       } while (!node.C);

-       if (node) node.C = false;

-     }

-   };

-   function d3_geom_voronoiRedBlackRotateLeft(tree, node) {

-     var p = node, q = node.R, parent = p.U;

-     if (parent) {

-       if (parent.L === p) parent.L = q; else parent.R = q;

-     } else {

-       tree._ = q;

-     }

-     q.U = parent;

-     p.U = q;

-     p.R = q.L;

-     if (p.R) p.R.U = p;

-     q.L = p;

-   }

-   function d3_geom_voronoiRedBlackRotateRight(tree, node) {

-     var p = node, q = node.L, parent = p.U;

-     if (parent) {

-       if (parent.L === p) parent.L = q; else parent.R = q;

-     } else {

-       tree._ = q;

-     }

-     q.U = parent;

-     p.U = q;

-     p.L = q.R;

-     if (p.L) p.L.U = p;

-     q.R = p;

-   }

-   function d3_geom_voronoiRedBlackFirst(node) {

-     while (node.L) node = node.L;

-     return node;

-   }

-   function d3_geom_voronoi(sites, bbox) {

-     var site = sites.sort(d3_geom_voronoiVertexOrder).pop(), x0, y0, circle;

-     d3_geom_voronoiEdges = [];

-     d3_geom_voronoiCells = new Array(sites.length);

-     d3_geom_voronoiBeaches = new d3_geom_voronoiRedBlackTree();

-     d3_geom_voronoiCircles = new d3_geom_voronoiRedBlackTree();

-     while (true) {

-       circle = d3_geom_voronoiFirstCircle;

-       if (site && (!circle || site.y < circle.y || site.y === circle.y && site.x < circle.x)) {

-         if (site.x !== x0 || site.y !== y0) {

-           d3_geom_voronoiCells[site.i] = new d3_geom_voronoiCell(site);

-           d3_geom_voronoiAddBeach(site);

-           x0 = site.x, y0 = site.y;

-         }

-         site = sites.pop();

-       } else if (circle) {

-         d3_geom_voronoiRemoveBeach(circle.arc);

-       } else {

-         break;

-       }

-     }

-     if (bbox) d3_geom_voronoiClipEdges(bbox), d3_geom_voronoiCloseCells(bbox);

-     var diagram = {

-       cells: d3_geom_voronoiCells,

-       edges: d3_geom_voronoiEdges

-     };

-     d3_geom_voronoiBeaches = d3_geom_voronoiCircles = d3_geom_voronoiEdges = d3_geom_voronoiCells = null;

-     return diagram;

-   }

-   function d3_geom_voronoiVertexOrder(a, b) {

-     return b.y - a.y || b.x - a.x;

-   }

-   d3.geom.voronoi = function(points) {

-     var x = d3_geom_pointX, y = d3_geom_pointY, fx = x, fy = y, clipExtent = d3_geom_voronoiClipExtent;

-     if (points) return voronoi(points);

-     function voronoi(data) {

-       var polygons = new Array(data.length), x0 = clipExtent[0][0], y0 = clipExtent[0][1], x1 = clipExtent[1][0], y1 = clipExtent[1][1];

-       d3_geom_voronoi(sites(data), clipExtent).cells.forEach(function(cell, i) {

-         var edges = cell.edges, site = cell.site, polygon = polygons[i] = edges.length ? edges.map(function(e) {

-           var s = e.start();

-           return [ s.x, s.y ];

-         }) : site.x >= x0 && site.x <= x1 && site.y >= y0 && site.y <= y1 ? [ [ x0, y1 ], [ x1, y1 ], [ x1, y0 ], [ x0, y0 ] ] : [];

-         polygon.point = data[i];

-       });

-       return polygons;

-     }

-     function sites(data) {

-       return data.map(function(d, i) {

-         return {

-           x: Math.round(fx(d, i) / ε) * ε,

-           y: Math.round(fy(d, i) / ε) * ε,

-           i: i

-         };

-       });

-     }

-     voronoi.links = function(data) {

-       return d3_geom_voronoi(sites(data)).edges.filter(function(edge) {

-         return edge.l && edge.r;

-       }).map(function(edge) {

-         return {

-           source: data[edge.l.i],

-           target: data[edge.r.i]

-         };

-       });

-     };

-     voronoi.triangles = function(data) {

-       var triangles = [];

-       d3_geom_voronoi(sites(data)).cells.forEach(function(cell, i) {

-         var site = cell.site, edges = cell.edges.sort(d3_geom_voronoiHalfEdgeOrder), j = -1, m = edges.length, e0, s0, e1 = edges[m - 1].edge, s1 = e1.l === site ? e1.r : e1.l;

-         while (++j < m) {

-           e0 = e1;

-           s0 = s1;

-           e1 = edges[j].edge;

-           s1 = e1.l === site ? e1.r : e1.l;

-           if (i < s0.i && i < s1.i && d3_geom_voronoiTriangleArea(site, s0, s1) < 0) {

-             triangles.push([ data[i], data[s0.i], data[s1.i] ]);

-           }

-         }

-       });

-       return triangles;

-     };

-     voronoi.x = function(_) {

-       return arguments.length ? (fx = d3_functor(x = _), voronoi) : x;

-     };

-     voronoi.y = function(_) {

-       return arguments.length ? (fy = d3_functor(y = _), voronoi) : y;

-     };

-     voronoi.clipExtent = function(_) {

-       if (!arguments.length) return clipExtent === d3_geom_voronoiClipExtent ? null : clipExtent;

-       clipExtent = _ == null ? d3_geom_voronoiClipExtent : _;

-       return voronoi;

-     };

-     voronoi.size = function(_) {

-       if (!arguments.length) return clipExtent === d3_geom_voronoiClipExtent ? null : clipExtent && clipExtent[1];

-       return voronoi.clipExtent(_ && [ [ 0, 0 ], _ ]);

-     };

-     return voronoi;

-   };

-   var d3_geom_voronoiClipExtent = [ [ -1e6, -1e6 ], [ 1e6, 1e6 ] ];

-   function d3_geom_voronoiTriangleArea(a, b, c) {

-     return (a.x - c.x) * (b.y - a.y) - (a.x - b.x) * (c.y - a.y);

-   }

-   d3.geom.delaunay = function(vertices) {

-     return d3.geom.voronoi().triangles(vertices);

-   };

-   d3.geom.quadtree = function(points, x1, y1, x2, y2) {

-     var x = d3_geom_pointX, y = d3_geom_pointY, compat;

-     if (compat = arguments.length) {

-       x = d3_geom_quadtreeCompatX;

-       y = d3_geom_quadtreeCompatY;

-       if (compat === 3) {

-         y2 = y1;

-         x2 = x1;

-         y1 = x1 = 0;

-       }

-       return quadtree(points);

-     }

-     function quadtree(data) {

-       var d, fx = d3_functor(x), fy = d3_functor(y), xs, ys, i, n, x1_, y1_, x2_, y2_;

-       if (x1 != null) {

-         x1_ = x1, y1_ = y1, x2_ = x2, y2_ = y2;

-       } else {

-         x2_ = y2_ = -(x1_ = y1_ = Infinity);

-         xs = [], ys = [];

-         n = data.length;

-         if (compat) for (i = 0; i < n; ++i) {

-           d = data[i];

-           if (d.x < x1_) x1_ = d.x;

-           if (d.y < y1_) y1_ = d.y;

-           if (d.x > x2_) x2_ = d.x;

-           if (d.y > y2_) y2_ = d.y;

-           xs.push(d.x);

-           ys.push(d.y);

-         } else for (i = 0; i < n; ++i) {

-           var x_ = +fx(d = data[i], i), y_ = +fy(d, i);

-           if (x_ < x1_) x1_ = x_;

-           if (y_ < y1_) y1_ = y_;

-           if (x_ > x2_) x2_ = x_;

-           if (y_ > y2_) y2_ = y_;

-           xs.push(x_);

-           ys.push(y_);

-         }

-       }

-       var dx = x2_ - x1_, dy = y2_ - y1_;

-       if (dx > dy) y2_ = y1_ + dx; else x2_ = x1_ + dy;

-       function insert(n, d, x, y, x1, y1, x2, y2) {

-         if (isNaN(x) || isNaN(y)) return;

-         if (n.leaf) {

-           var nx = n.x, ny = n.y;

-           if (nx != null) {

-             if (abs(nx - x) + abs(ny - y) < .01) {

-               insertChild(n, d, x, y, x1, y1, x2, y2);

-             } else {

-               var nPoint = n.point;

-               n.x = n.y = n.point = null;

-               insertChild(n, nPoint, nx, ny, x1, y1, x2, y2);

-               insertChild(n, d, x, y, x1, y1, x2, y2);

-             }

-           } else {

-             n.x = x, n.y = y, n.point = d;

-           }

-         } else {

-           insertChild(n, d, x, y, x1, y1, x2, y2);

-         }

-       }

-       function insertChild(n, d, x, y, x1, y1, x2, y2) {

-         var xm = (x1 + x2) * .5, ym = (y1 + y2) * .5, right = x >= xm, below = y >= ym, i = below << 1 | right;

-         n.leaf = false;

-         n = n.nodes[i] || (n.nodes[i] = d3_geom_quadtreeNode());

-         if (right) x1 = xm; else x2 = xm;

-         if (below) y1 = ym; else y2 = ym;

-         insert(n, d, x, y, x1, y1, x2, y2);

-       }

-       var root = d3_geom_quadtreeNode();

-       root.add = function(d) {

-         insert(root, d, +fx(d, ++i), +fy(d, i), x1_, y1_, x2_, y2_);

-       };

-       root.visit = function(f) {

-         d3_geom_quadtreeVisit(f, root, x1_, y1_, x2_, y2_);

-       };

-       root.find = function(point) {

-         return d3_geom_quadtreeFind(root, point[0], point[1], x1_, y1_, x2_, y2_);

-       };

-       i = -1;

-       if (x1 == null) {

-         while (++i < n) {

-           insert(root, data[i], xs[i], ys[i], x1_, y1_, x2_, y2_);

-         }

-         --i;

-       } else data.forEach(root.add);

-       xs = ys = data = d = null;

-       return root;

-     }

-     quadtree.x = function(_) {

-       return arguments.length ? (x = _, quadtree) : x;

-     };

-     quadtree.y = function(_) {

-       return arguments.length ? (y = _, quadtree) : y;

-     };

-     quadtree.extent = function(_) {

-       if (!arguments.length) return x1 == null ? null : [ [ x1, y1 ], [ x2, y2 ] ];

-       if (_ == null) x1 = y1 = x2 = y2 = null; else x1 = +_[0][0], y1 = +_[0][1], x2 = +_[1][0],

-       y2 = +_[1][1];

-       return quadtree;

-     };

-     quadtree.size = function(_) {

-       if (!arguments.length) return x1 == null ? null : [ x2 - x1, y2 - y1 ];

-       if (_ == null) x1 = y1 = x2 = y2 = null; else x1 = y1 = 0, x2 = +_[0], y2 = +_[1];

-       return quadtree;

-     };

-     return quadtree;

-   };

-   function d3_geom_quadtreeCompatX(d) {

-     return d.x;

-   }

-   function d3_geom_quadtreeCompatY(d) {

-     return d.y;

-   }

-   function d3_geom_quadtreeNode() {

-     return {

-       leaf: true,

-       nodes: [],

-       point: null,

-       x: null,

-       y: null

-     };

-   }

-   function d3_geom_quadtreeVisit(f, node, x1, y1, x2, y2) {

-     if (!f(node, x1, y1, x2, y2)) {

-       var sx = (x1 + x2) * .5, sy = (y1 + y2) * .5, children = node.nodes;

-       if (children[0]) d3_geom_quadtreeVisit(f, children[0], x1, y1, sx, sy);

-       if (children[1]) d3_geom_quadtreeVisit(f, children[1], sx, y1, x2, sy);

-       if (children[2]) d3_geom_quadtreeVisit(f, children[2], x1, sy, sx, y2);

-       if (children[3]) d3_geom_quadtreeVisit(f, children[3], sx, sy, x2, y2);

-     }

-   }

-   function d3_geom_quadtreeFind(root, x, y, x0, y0, x3, y3) {

-     var minDistance2 = Infinity, closestPoint;

-     (function find(node, x1, y1, x2, y2) {

-       if (x1 > x3 || y1 > y3 || x2 < x0 || y2 < y0) return;

-       if (point = node.point) {

-         var point, dx = x - node.x, dy = y - node.y, distance2 = dx * dx + dy * dy;

-         if (distance2 < minDistance2) {

-           var distance = Math.sqrt(minDistance2 = distance2);

-           x0 = x - distance, y0 = y - distance;

-           x3 = x + distance, y3 = y + distance;

-           closestPoint = point;

-         }

-       }

-       var children = node.nodes, xm = (x1 + x2) * .5, ym = (y1 + y2) * .5, right = x >= xm, below = y >= ym;

-       for (var i = below << 1 | right, j = i + 4; i < j; ++i) {

-         if (node = children[i & 3]) switch (i & 3) {

-          case 0:

-           find(node, x1, y1, xm, ym);

-           break;

- 

-          case 1:

-           find(node, xm, y1, x2, ym);

-           break;

- 

-          case 2:

-           find(node, x1, ym, xm, y2);

-           break;

- 

-          case 3:

-           find(node, xm, ym, x2, y2);

-           break;

-         }

-       }

-     })(root, x0, y0, x3, y3);

-     return closestPoint;

-   }

-   d3.interpolateRgb = d3_interpolateRgb;

-   function d3_interpolateRgb(a, b) {

-     a = d3.rgb(a);

-     b = d3.rgb(b);

-     var ar = a.r, ag = a.g, ab = a.b, br = b.r - ar, bg = b.g - ag, bb = b.b - ab;

-     return function(t) {

-       return "#" + d3_rgb_hex(Math.round(ar + br * t)) + d3_rgb_hex(Math.round(ag + bg * t)) + d3_rgb_hex(Math.round(ab + bb * t));

-     };

-   }

-   d3.interpolateObject = d3_interpolateObject;

-   function d3_interpolateObject(a, b) {

-     var i = {}, c = {}, k;

-     for (k in a) {

-       if (k in b) {

-         i[k] = d3_interpolate(a[k], b[k]);

-       } else {

-         c[k] = a[k];

-       }

-     }

-     for (k in b) {

-       if (!(k in a)) {

-         c[k] = b[k];

-       }

-     }

-     return function(t) {

-       for (k in i) c[k] = i[k](t);

-       return c;

-     };

-   }

-   d3.interpolateNumber = d3_interpolateNumber;

-   function d3_interpolateNumber(a, b) {

-     a = +a, b = +b;

-     return function(t) {

-       return a * (1 - t) + b * t;

-     };

-   }

-   d3.interpolateString = d3_interpolateString;

-   function d3_interpolateString(a, b) {

-     var bi = d3_interpolate_numberA.lastIndex = d3_interpolate_numberB.lastIndex = 0, am, bm, bs, i = -1, s = [], q = [];

-     a = a + "", b = b + "";

-     while ((am = d3_interpolate_numberA.exec(a)) && (bm = d3_interpolate_numberB.exec(b))) {

-       if ((bs = bm.index) > bi) {

-         bs = b.slice(bi, bs);

-         if (s[i]) s[i] += bs; else s[++i] = bs;

-       }

-       if ((am = am[0]) === (bm = bm[0])) {

-         if (s[i]) s[i] += bm; else s[++i] = bm;

-       } else {

-         s[++i] = null;

-         q.push({

-           i: i,

-           x: d3_interpolateNumber(am, bm)

-         });

-       }

-       bi = d3_interpolate_numberB.lastIndex;

-     }

-     if (bi < b.length) {

-       bs = b.slice(bi);

-       if (s[i]) s[i] += bs; else s[++i] = bs;

-     }

-     return s.length < 2 ? q[0] ? (b = q[0].x, function(t) {

-       return b(t) + "";

-     }) : function() {

-       return b;

-     } : (b = q.length, function(t) {

-       for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);

-       return s.join("");

-     });

-   }

-   var d3_interpolate_numberA = /[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g, d3_interpolate_numberB = new RegExp(d3_interpolate_numberA.source, "g");

-   d3.interpolate = d3_interpolate;

-   function d3_interpolate(a, b) {

-     var i = d3.interpolators.length, f;

-     while (--i >= 0 && !(f = d3.interpolators[i](a, b))) ;

-     return f;

-   }

-   d3.interpolators = [ function(a, b) {

-     var t = typeof b;

-     return (t === "string" ? d3_rgb_names.has(b.toLowerCase()) || /^(#|rgb\(|hsl\()/i.test(b) ? d3_interpolateRgb : d3_interpolateString : b instanceof d3_color ? d3_interpolateRgb : Array.isArray(b) ? d3_interpolateArray : t === "object" && isNaN(b) ? d3_interpolateObject : d3_interpolateNumber)(a, b);

-   } ];

-   d3.interpolateArray = d3_interpolateArray;

-   function d3_interpolateArray(a, b) {

-     var x = [], c = [], na = a.length, nb = b.length, n0 = Math.min(a.length, b.length), i;

-     for (i = 0; i < n0; ++i) x.push(d3_interpolate(a[i], b[i]));

-     for (;i < na; ++i) c[i] = a[i];

-     for (;i < nb; ++i) c[i] = b[i];

-     return function(t) {

-       for (i = 0; i < n0; ++i) c[i] = x[i](t);

-       return c;

-     };

-   }

-   var d3_ease_default = function() {

-     return d3_identity;

-   };

-   var d3_ease = d3.map({

-     linear: d3_ease_default,

-     poly: d3_ease_poly,

-     quad: function() {

-       return d3_ease_quad;

-     },

-     cubic: function() {

-       return d3_ease_cubic;

-     },

-     sin: function() {

-       return d3_ease_sin;

-     },

-     exp: function() {

-       return d3_ease_exp;

-     },

-     circle: function() {

-       return d3_ease_circle;

-     },

-     elastic: d3_ease_elastic,

-     back: d3_ease_back,

-     bounce: function() {

-       return d3_ease_bounce;

-     }

-   });

-   var d3_ease_mode = d3.map({

-     "in": d3_identity,

-     out: d3_ease_reverse,

-     "in-out": d3_ease_reflect,

-     "out-in": function(f) {

-       return d3_ease_reflect(d3_ease_reverse(f));

-     }

-   });

-   d3.ease = function(name) {

-     var i = name.indexOf("-"), t = i >= 0 ? name.slice(0, i) : name, m = i >= 0 ? name.slice(i + 1) : "in";

-     t = d3_ease.get(t) || d3_ease_default;

-     m = d3_ease_mode.get(m) || d3_identity;

-     return d3_ease_clamp(m(t.apply(null, d3_arraySlice.call(arguments, 1))));

-   };

-   function d3_ease_clamp(f) {

-     return function(t) {

-       return t <= 0 ? 0 : t >= 1 ? 1 : f(t);

-     };

-   }

-   function d3_ease_reverse(f) {

-     return function(t) {

-       return 1 - f(1 - t);

-     };

-   }

-   function d3_ease_reflect(f) {

-     return function(t) {

-       return .5 * (t < .5 ? f(2 * t) : 2 - f(2 - 2 * t));

-     };

-   }

-   function d3_ease_quad(t) {

-     return t * t;

-   }

-   function d3_ease_cubic(t) {

-     return t * t * t;

-   }

-   function d3_ease_cubicInOut(t) {

-     if (t <= 0) return 0;

-     if (t >= 1) return 1;

-     var t2 = t * t, t3 = t2 * t;

-     return 4 * (t < .5 ? t3 : 3 * (t - t2) + t3 - .75);

-   }

-   function d3_ease_poly(e) {

-     return function(t) {

-       return Math.pow(t, e);

-     };

-   }

-   function d3_ease_sin(t) {

-     return 1 - Math.cos(t * halfπ);

-   }

-   function d3_ease_exp(t) {

-     return Math.pow(2, 10 * (t - 1));

-   }

-   function d3_ease_circle(t) {

-     return 1 - Math.sqrt(1 - t * t);

-   }

-   function d3_ease_elastic(a, p) {

-     var s;

-     if (arguments.length < 2) p = .45;

-     if (arguments.length) s = p / τ * Math.asin(1 / a); else a = 1, s = p / 4;

-     return function(t) {

-       return 1 + a * Math.pow(2, -10 * t) * Math.sin((t - s) * τ / p);

-     };

-   }

-   function d3_ease_back(s) {

-     if (!s) s = 1.70158;

-     return function(t) {

-       return t * t * ((s + 1) * t - s);

-     };

-   }

-   function d3_ease_bounce(t) {

-     return t < 1 / 2.75 ? 7.5625 * t * t : t < 2 / 2.75 ? 7.5625 * (t -= 1.5 / 2.75) * t + .75 : t < 2.5 / 2.75 ? 7.5625 * (t -= 2.25 / 2.75) * t + .9375 : 7.5625 * (t -= 2.625 / 2.75) * t + .984375;

-   }

-   d3.interpolateHcl = d3_interpolateHcl;

-   function d3_interpolateHcl(a, b) {

-     a = d3.hcl(a);

-     b = d3.hcl(b);

-     var ah = a.h, ac = a.c, al = a.l, bh = b.h - ah, bc = b.c - ac, bl = b.l - al;

-     if (isNaN(bc)) bc = 0, ac = isNaN(ac) ? b.c : ac;

-     if (isNaN(bh)) bh = 0, ah = isNaN(ah) ? b.h : ah; else if (bh > 180) bh -= 360; else if (bh < -180) bh += 360;

-     return function(t) {

-       return d3_hcl_lab(ah + bh * t, ac + bc * t, al + bl * t) + "";

-     };

-   }

-   d3.interpolateHsl = d3_interpolateHsl;

-   function d3_interpolateHsl(a, b) {

-     a = d3.hsl(a);

-     b = d3.hsl(b);

-     var ah = a.h, as = a.s, al = a.l, bh = b.h - ah, bs = b.s - as, bl = b.l - al;

-     if (isNaN(bs)) bs = 0, as = isNaN(as) ? b.s : as;

-     if (isNaN(bh)) bh = 0, ah = isNaN(ah) ? b.h : ah; else if (bh > 180) bh -= 360; else if (bh < -180) bh += 360;

-     return function(t) {

-       return d3_hsl_rgb(ah + bh * t, as + bs * t, al + bl * t) + "";

-     };

-   }

-   d3.interpolateLab = d3_interpolateLab;

-   function d3_interpolateLab(a, b) {

-     a = d3.lab(a);

-     b = d3.lab(b);

-     var al = a.l, aa = a.a, ab = a.b, bl = b.l - al, ba = b.a - aa, bb = b.b - ab;

-     return function(t) {

-       return d3_lab_rgb(al + bl * t, aa + ba * t, ab + bb * t) + "";

-     };

-   }

-   d3.interpolateRound = d3_interpolateRound;

-   function d3_interpolateRound(a, b) {

-     b -= a;

-     return function(t) {

-       return Math.round(a + b * t);

-     };

-   }

-   d3.transform = function(string) {

-     var g = d3_document.createElementNS(d3.ns.prefix.svg, "g");

-     return (d3.transform = function(string) {

-       if (string != null) {

-         g.setAttribute("transform", string);

-         var t = g.transform.baseVal.consolidate();

-       }

-       return new d3_transform(t ? t.matrix : d3_transformIdentity);

-     })(string);

-   };

-   function d3_transform(m) {

-     var r0 = [ m.a, m.b ], r1 = [ m.c, m.d ], kx = d3_transformNormalize(r0), kz = d3_transformDot(r0, r1), ky = d3_transformNormalize(d3_transformCombine(r1, r0, -kz)) || 0;

-     if (r0[0] * r1[1] < r1[0] * r0[1]) {

-       r0[0] *= -1;

-       r0[1] *= -1;

-       kx *= -1;

-       kz *= -1;

-     }

-     this.rotate = (kx ? Math.atan2(r0[1], r0[0]) : Math.atan2(-r1[0], r1[1])) * d3_degrees;

-     this.translate = [ m.e, m.f ];

-     this.scale = [ kx, ky ];

-     this.skew = ky ? Math.atan2(kz, ky) * d3_degrees : 0;

-   }

-   d3_transform.prototype.toString = function() {

-     return "translate(" + this.translate + ")rotate(" + this.rotate + ")skewX(" + this.skew + ")scale(" + this.scale + ")";

-   };

-   function d3_transformDot(a, b) {

-     return a[0] * b[0] + a[1] * b[1];

-   }

-   function d3_transformNormalize(a) {

-     var k = Math.sqrt(d3_transformDot(a, a));

-     if (k) {

-       a[0] /= k;

-       a[1] /= k;

-     }

-     return k;

-   }

-   function d3_transformCombine(a, b, k) {

-     a[0] += k * b[0];

-     a[1] += k * b[1];

-     return a;

-   }

-   var d3_transformIdentity = {

-     a: 1,

-     b: 0,

-     c: 0,

-     d: 1,

-     e: 0,

-     f: 0

-   };

-   d3.interpolateTransform = d3_interpolateTransform;

-   function d3_interpolateTransformPop(s) {

-     return s.length ? s.pop() + "," : "";

-   }

-   function d3_interpolateTranslate(ta, tb, s, q) {

-     if (ta[0] !== tb[0] || ta[1] !== tb[1]) {

-       var i = s.push("translate(", null, ",", null, ")");

-       q.push({

-         i: i - 4,

-         x: d3_interpolateNumber(ta[0], tb[0])

-       }, {

-         i: i - 2,

-         x: d3_interpolateNumber(ta[1], tb[1])

-       });

-     } else if (tb[0] || tb[1]) {

-       s.push("translate(" + tb + ")");

-     }

-   }

-   function d3_interpolateRotate(ra, rb, s, q) {

-     if (ra !== rb) {

-       if (ra - rb > 180) rb += 360; else if (rb - ra > 180) ra += 360;

-       q.push({

-         i: s.push(d3_interpolateTransformPop(s) + "rotate(", null, ")") - 2,

-         x: d3_interpolateNumber(ra, rb)

-       });

-     } else if (rb) {

-       s.push(d3_interpolateTransformPop(s) + "rotate(" + rb + ")");

-     }

-   }

-   function d3_interpolateSkew(wa, wb, s, q) {

-     if (wa !== wb) {

-       q.push({

-         i: s.push(d3_interpolateTransformPop(s) + "skewX(", null, ")") - 2,

-         x: d3_interpolateNumber(wa, wb)

-       });

-     } else if (wb) {

-       s.push(d3_interpolateTransformPop(s) + "skewX(" + wb + ")");

-     }

-   }

-   function d3_interpolateScale(ka, kb, s, q) {

-     if (ka[0] !== kb[0] || ka[1] !== kb[1]) {

-       var i = s.push(d3_interpolateTransformPop(s) + "scale(", null, ",", null, ")");

-       q.push({

-         i: i - 4,

-         x: d3_interpolateNumber(ka[0], kb[0])

-       }, {

-         i: i - 2,

-         x: d3_interpolateNumber(ka[1], kb[1])

-       });

-     } else if (kb[0] !== 1 || kb[1] !== 1) {

-       s.push(d3_interpolateTransformPop(s) + "scale(" + kb + ")");

-     }

-   }

-   function d3_interpolateTransform(a, b) {

-     var s = [], q = [];

-     a = d3.transform(a), b = d3.transform(b);

-     d3_interpolateTranslate(a.translate, b.translate, s, q);

-     d3_interpolateRotate(a.rotate, b.rotate, s, q);

-     d3_interpolateSkew(a.skew, b.skew, s, q);

-     d3_interpolateScale(a.scale, b.scale, s, q);

-     a = b = null;

-     return function(t) {

-       var i = -1, n = q.length, o;

-       while (++i < n) s[(o = q[i]).i] = o.x(t);

-       return s.join("");

-     };

-   }

-   function d3_uninterpolateNumber(a, b) {

-     b = (b -= a = +a) || 1 / b;

-     return function(x) {

-       return (x - a) / b;

-     };

-   }

-   function d3_uninterpolateClamp(a, b) {

-     b = (b -= a = +a) || 1 / b;

-     return function(x) {

-       return Math.max(0, Math.min(1, (x - a) / b));

-     };

-   }

-   d3.layout = {};

-   d3.layout.bundle = function() {

-     return function(links) {

-       var paths = [], i = -1, n = links.length;

-       while (++i < n) paths.push(d3_layout_bundlePath(links[i]));

-       return paths;

-     };

-   };

-   function d3_layout_bundlePath(link) {

-     var start = link.source, end = link.target, lca = d3_layout_bundleLeastCommonAncestor(start, end), points = [ start ];

-     while (start !== lca) {

-       start = start.parent;

-       points.push(start);

-     }

-     var k = points.length;

-     while (end !== lca) {

-       points.splice(k, 0, end);

-       end = end.parent;

-     }

-     return points;

-   }

-   function d3_layout_bundleAncestors(node) {

-     var ancestors = [], parent = node.parent;

-     while (parent != null) {

-       ancestors.push(node);

-       node = parent;

-       parent = parent.parent;

-     }

-     ancestors.push(node);

-     return ancestors;

-   }

-   function d3_layout_bundleLeastCommonAncestor(a, b) {

-     if (a === b) return a;

-     var aNodes = d3_layout_bundleAncestors(a), bNodes = d3_layout_bundleAncestors(b), aNode = aNodes.pop(), bNode = bNodes.pop(), sharedNode = null;

-     while (aNode === bNode) {

-       sharedNode = aNode;

-       aNode = aNodes.pop();

-       bNode = bNodes.pop();

-     }

-     return sharedNode;

-   }

-   d3.layout.chord = function() {

-     var chord = {}, chords, groups, matrix, n, padding = 0, sortGroups, sortSubgroups, sortChords;

-     function relayout() {

-       var subgroups = {}, groupSums = [], groupIndex = d3.range(n), subgroupIndex = [], k, x, x0, i, j;

-       chords = [];

-       groups = [];

-       k = 0, i = -1;

-       while (++i < n) {

-         x = 0, j = -1;

-         while (++j < n) {

-           x += matrix[i][j];

-         }

-         groupSums.push(x);

-         subgroupIndex.push(d3.range(n));

-         k += x;

-       }

-       if (sortGroups) {

-         groupIndex.sort(function(a, b) {

-           return sortGroups(groupSums[a], groupSums[b]);

-         });

-       }

-       if (sortSubgroups) {

-         subgroupIndex.forEach(function(d, i) {

-           d.sort(function(a, b) {

-             return sortSubgroups(matrix[i][a], matrix[i][b]);

-           });

-         });

-       }

-       k = (τ - padding * n) / k;

-       x = 0, i = -1;

-       while (++i < n) {

-         x0 = x, j = -1;

-         while (++j < n) {

-           var di = groupIndex[i], dj = subgroupIndex[di][j], v = matrix[di][dj], a0 = x, a1 = x += v * k;

-           subgroups[di + "-" + dj] = {

-             index: di,

-             subindex: dj,

-             startAngle: a0,

-             endAngle: a1,

-             value: v

-           };

-         }

-         groups[di] = {

-           index: di,

-           startAngle: x0,

-           endAngle: x,

-           value: groupSums[di]

-         };

-         x += padding;

-       }

-       i = -1;

-       while (++i < n) {

-         j = i - 1;

-         while (++j < n) {

-           var source = subgroups[i + "-" + j], target = subgroups[j + "-" + i];

-           if (source.value || target.value) {

-             chords.push(source.value < target.value ? {

-               source: target,

-               target: source

-             } : {

-               source: source,

-               target: target

-             });

-           }

-         }

-       }

-       if (sortChords) resort();

-     }

-     function resort() {

-       chords.sort(function(a, b) {

-         return sortChords((a.source.value + a.target.value) / 2, (b.source.value + b.target.value) / 2);

-       });

-     }

-     chord.matrix = function(x) {

-       if (!arguments.length) return matrix;

-       n = (matrix = x) && matrix.length;

-       chords = groups = null;

-       return chord;

-     };

-     chord.padding = function(x) {

-       if (!arguments.length) return padding;

-       padding = x;

-       chords = groups = null;

-       return chord;

-     };

-     chord.sortGroups = function(x) {

-       if (!arguments.length) return sortGroups;

-       sortGroups = x;

-       chords = groups = null;

-       return chord;

-     };

-     chord.sortSubgroups = function(x) {

-       if (!arguments.length) return sortSubgroups;

-       sortSubgroups = x;

-       chords = null;

-       return chord;

-     };

-     chord.sortChords = function(x) {

-       if (!arguments.length) return sortChords;

-       sortChords = x;

-       if (chords) resort();

-       return chord;

-     };

-     chord.chords = function() {

-       if (!chords) relayout();

-       return chords;

-     };

-     chord.groups = function() {

-       if (!groups) relayout();

-       return groups;

-     };

-     return chord;

-   };

-   d3.layout.force = function() {

-     var force = {}, event = d3.dispatch("start", "tick", "end"), timer, size = [ 1, 1 ], drag, alpha, friction = .9, linkDistance = d3_layout_forceLinkDistance, linkStrength = d3_layout_forceLinkStrength, charge = -30, chargeDistance2 = d3_layout_forceChargeDistance2, gravity = .1, theta2 = .64, nodes = [], links = [], distances, strengths, charges;

-     function repulse(node) {

-       return function(quad, x1, _, x2) {

-         if (quad.point !== node) {

-           var dx = quad.cx - node.x, dy = quad.cy - node.y, dw = x2 - x1, dn = dx * dx + dy * dy;

-           if (dw * dw / theta2 < dn) {

-             if (dn < chargeDistance2) {

-               var k = quad.charge / dn;

-               node.px -= dx * k;

-               node.py -= dy * k;

-             }

-             return true;

-           }

-           if (quad.point && dn && dn < chargeDistance2) {

-             var k = quad.pointCharge / dn;

-             node.px -= dx * k;

-             node.py -= dy * k;

-           }

-         }

-         return !quad.charge;

-       };

-     }

-     force.tick = function() {

-       if ((alpha *= .99) < .005) {

-         timer = null;

-         event.end({

-           type: "end",

-           alpha: alpha = 0

-         });

-         return true;

-       }

-       var n = nodes.length, m = links.length, q, i, o, s, t, l, k, x, y;

-       for (i = 0; i < m; ++i) {

-         o = links[i];

-         s = o.source;

-         t = o.target;

-         x = t.x - s.x;

-         y = t.y - s.y;

-         if (l = x * x + y * y) {

-           l = alpha * strengths[i] * ((l = Math.sqrt(l)) - distances[i]) / l;

-           x *= l;

-           y *= l;

-           t.x -= x * (k = s.weight + t.weight ? s.weight / (s.weight + t.weight) : .5);

-           t.y -= y * k;

-           s.x += x * (k = 1 - k);

-           s.y += y * k;

-         }

-       }

-       if (k = alpha * gravity) {

-         x = size[0] / 2;

-         y = size[1] / 2;

-         i = -1;

-         if (k) while (++i < n) {

-           o = nodes[i];

-           o.x += (x - o.x) * k;

-           o.y += (y - o.y) * k;

-         }

-       }

-       if (charge) {

-         d3_layout_forceAccumulate(q = d3.geom.quadtree(nodes), alpha, charges);

-         i = -1;

-         while (++i < n) {

-           if (!(o = nodes[i]).fixed) {

-             q.visit(repulse(o));

-           }

-         }

-       }

-       i = -1;

-       while (++i < n) {

-         o = nodes[i];

-         if (o.fixed) {

-           o.x = o.px;

-           o.y = o.py;

-         } else {

-           o.x -= (o.px - (o.px = o.x)) * friction;

-           o.y -= (o.py - (o.py = o.y)) * friction;

-         }

-       }

-       event.tick({

-         type: "tick",

-         alpha: alpha

-       });

-     };

-     force.nodes = function(x) {

-       if (!arguments.length) return nodes;

-       nodes = x;

-       return force;

-     };

-     force.links = function(x) {

-       if (!arguments.length) return links;

-       links = x;

-       return force;

-     };

-     force.size = function(x) {

-       if (!arguments.length) return size;

-       size = x;

-       return force;

-     };

-     force.linkDistance = function(x) {

-       if (!arguments.length) return linkDistance;

-       linkDistance = typeof x === "function" ? x : +x;

-       return force;

-     };

-     force.distance = force.linkDistance;

-     force.linkStrength = function(x) {

-       if (!arguments.length) return linkStrength;

-       linkStrength = typeof x === "function" ? x : +x;

-       return force;

-     };

-     force.friction = function(x) {

-       if (!arguments.length) return friction;

-       friction = +x;

-       return force;

-     };

-     force.charge = function(x) {

-       if (!arguments.length) return charge;

-       charge = typeof x === "function" ? x : +x;

-       return force;

-     };

-     force.chargeDistance = function(x) {

-       if (!arguments.length) return Math.sqrt(chargeDistance2);

-       chargeDistance2 = x * x;

-       return force;

-     };

-     force.gravity = function(x) {

-       if (!arguments.length) return gravity;

-       gravity = +x;

-       return force;

-     };

-     force.theta = function(x) {

-       if (!arguments.length) return Math.sqrt(theta2);

-       theta2 = x * x;

-       return force;

-     };

-     force.alpha = function(x) {

-       if (!arguments.length) return alpha;

-       x = +x;

-       if (alpha) {

-         if (x > 0) {

-           alpha = x;

-         } else {

-           timer.c = null, timer.t = NaN, timer = null;

-           event.end({

-             type: "end",

-             alpha: alpha = 0

-           });

-         }

-       } else if (x > 0) {

-         event.start({

-           type: "start",

-           alpha: alpha = x

-         });

-         timer = d3_timer(force.tick);

-       }

-       return force;

-     };

-     force.start = function() {

-       var i, n = nodes.length, m = links.length, w = size[0], h = size[1], neighbors, o;

-       for (i = 0; i < n; ++i) {

-         (o = nodes[i]).index = i;

-         o.weight = 0;

-       }

-       for (i = 0; i < m; ++i) {

-         o = links[i];

-         if (typeof o.source == "number") o.source = nodes[o.source];

-         if (typeof o.target == "number") o.target = nodes[o.target];

-         ++o.source.weight;

-         ++o.target.weight;

-       }

-       for (i = 0; i < n; ++i) {

-         o = nodes[i];

-         if (isNaN(o.x)) o.x = position("x", w);

-         if (isNaN(o.y)) o.y = position("y", h);

-         if (isNaN(o.px)) o.px = o.x;

-         if (isNaN(o.py)) o.py = o.y;

-       }

-       distances = [];

-       if (typeof linkDistance === "function") for (i = 0; i < m; ++i) distances[i] = +linkDistance.call(this, links[i], i); else for (i = 0; i < m; ++i) distances[i] = linkDistance;

-       strengths = [];

-       if (typeof linkStrength === "function") for (i = 0; i < m; ++i) strengths[i] = +linkStrength.call(this, links[i], i); else for (i = 0; i < m; ++i) strengths[i] = linkStrength;

-       charges = [];

-       if (typeof charge === "function") for (i = 0; i < n; ++i) charges[i] = +charge.call(this, nodes[i], i); else for (i = 0; i < n; ++i) charges[i] = charge;

-       function position(dimension, size) {

-         if (!neighbors) {

-           neighbors = new Array(n);

-           for (j = 0; j < n; ++j) {

-             neighbors[j] = [];

-           }

-           for (j = 0; j < m; ++j) {

-             var o = links[j];

-             neighbors[o.source.index].push(o.target);

-             neighbors[o.target.index].push(o.source);

-           }

-         }

-         var candidates = neighbors[i], j = -1, l = candidates.length, x;

-         while (++j < l) if (!isNaN(x = candidates[j][dimension])) return x;

-         return Math.random() * size;

-       }

-       return force.resume();

-     };

-     force.resume = function() {

-       return force.alpha(.1);

-     };

-     force.stop = function() {

-       return force.alpha(0);

-     };

-     force.drag = function() {

-       if (!drag) drag = d3.behavior.drag().origin(d3_identity).on("dragstart.force", d3_layout_forceDragstart).on("drag.force", dragmove).on("dragend.force", d3_layout_forceDragend);

-       if (!arguments.length) return drag;

-       this.on("mouseover.force", d3_layout_forceMouseover).on("mouseout.force", d3_layout_forceMouseout).call(drag);

-     };

-     function dragmove(d) {

-       d.px = d3.event.x, d.py = d3.event.y;

-       force.resume();

-     }

-     return d3.rebind(force, event, "on");

-   };

-   function d3_layout_forceDragstart(d) {

-     d.fixed |= 2;

-   }

-   function d3_layout_forceDragend(d) {

-     d.fixed &= ~6;

-   }

-   function d3_layout_forceMouseover(d) {

-     d.fixed |= 4;

-     d.px = d.x, d.py = d.y;

-   }

-   function d3_layout_forceMouseout(d) {

-     d.fixed &= ~4;

-   }

-   function d3_layout_forceAccumulate(quad, alpha, charges) {

-     var cx = 0, cy = 0;

-     quad.charge = 0;

-     if (!quad.leaf) {

-       var nodes = quad.nodes, n = nodes.length, i = -1, c;

-       while (++i < n) {

-         c = nodes[i];

-         if (c == null) continue;

-         d3_layout_forceAccumulate(c, alpha, charges);

-         quad.charge += c.charge;

-         cx += c.charge * c.cx;

-         cy += c.charge * c.cy;

-       }

-     }

-     if (quad.point) {

-       if (!quad.leaf) {

-         quad.point.x += Math.random() - .5;

-         quad.point.y += Math.random() - .5;

-       }

-       var k = alpha * charges[quad.point.index];

-       quad.charge += quad.pointCharge = k;

-       cx += k * quad.point.x;

-       cy += k * quad.point.y;

-     }

-     quad.cx = cx / quad.charge;

-     quad.cy = cy / quad.charge;

-   }

-   var d3_layout_forceLinkDistance = 20, d3_layout_forceLinkStrength = 1, d3_layout_forceChargeDistance2 = Infinity;

-   d3.layout.hierarchy = function() {

-     var sort = d3_layout_hierarchySort, children = d3_layout_hierarchyChildren, value = d3_layout_hierarchyValue;

-     function hierarchy(root) {

-       var stack = [ root ], nodes = [], node;

-       root.depth = 0;

-       while ((node = stack.pop()) != null) {

-         nodes.push(node);

-         if ((childs = children.call(hierarchy, node, node.depth)) && (n = childs.length)) {

-           var n, childs, child;

-           while (--n >= 0) {

-             stack.push(child = childs[n]);

-             child.parent = node;

-             child.depth = node.depth + 1;

-           }

-           if (value) node.value = 0;

-           node.children = childs;

-         } else {

-           if (value) node.value = +value.call(hierarchy, node, node.depth) || 0;

-           delete node.children;

-         }

-       }

-       d3_layout_hierarchyVisitAfter(root, function(node) {

-         var childs, parent;

-         if (sort && (childs = node.children)) childs.sort(sort);

-         if (value && (parent = node.parent)) parent.value += node.value;

-       });

-       return nodes;

-     }

-     hierarchy.sort = function(x) {

-       if (!arguments.length) return sort;

-       sort = x;

-       return hierarchy;

-     };

-     hierarchy.children = function(x) {

-       if (!arguments.length) return children;

-       children = x;

-       return hierarchy;

-     };

-     hierarchy.value = function(x) {

-       if (!arguments.length) return value;

-       value = x;

-       return hierarchy;

-     };

-     hierarchy.revalue = function(root) {

-       if (value) {

-         d3_layout_hierarchyVisitBefore(root, function(node) {

-           if (node.children) node.value = 0;

-         });

-         d3_layout_hierarchyVisitAfter(root, function(node) {

-           var parent;

-           if (!node.children) node.value = +value.call(hierarchy, node, node.depth) || 0;

-           if (parent = node.parent) parent.value += node.value;

-         });

-       }

-       return root;

-     };

-     return hierarchy;

-   };

-   function d3_layout_hierarchyRebind(object, hierarchy) {

-     d3.rebind(object, hierarchy, "sort", "children", "value");

-     object.nodes = object;

-     object.links = d3_layout_hierarchyLinks;

-     return object;

-   }

-   function d3_layout_hierarchyVisitBefore(node, callback) {

-     var nodes = [ node ];

-     while ((node = nodes.pop()) != null) {

-       callback(node);

-       if ((children = node.children) && (n = children.length)) {

-         var n, children;

-         while (--n >= 0) nodes.push(children[n]);

-       }

-     }

-   }

-   function d3_layout_hierarchyVisitAfter(node, callback) {

-     var nodes = [ node ], nodes2 = [];

-     while ((node = nodes.pop()) != null) {

-       nodes2.push(node);

-       if ((children = node.children) && (n = children.length)) {

-         var i = -1, n, children;

-         while (++i < n) nodes.push(children[i]);

-       }

-     }

-     while ((node = nodes2.pop()) != null) {

-       callback(node);

-     }

-   }

-   function d3_layout_hierarchyChildren(d) {

-     return d.children;

-   }

-   function d3_layout_hierarchyValue(d) {

-     return d.value;

-   }

-   function d3_layout_hierarchySort(a, b) {

-     return b.value - a.value;

-   }

-   function d3_layout_hierarchyLinks(nodes) {

-     return d3.merge(nodes.map(function(parent) {

-       return (parent.children || []).map(function(child) {

-         return {

-           source: parent,

-           target: child

-         };

-       });

-     }));

-   }

-   d3.layout.partition = function() {

-     var hierarchy = d3.layout.hierarchy(), size = [ 1, 1 ];

-     function position(node, x, dx, dy) {

-       var children = node.children;

-       node.x = x;

-       node.y = node.depth * dy;

-       node.dx = dx;

-       node.dy = dy;

-       if (children && (n = children.length)) {

-         var i = -1, n, c, d;

-         dx = node.value ? dx / node.value : 0;

-         while (++i < n) {

-           position(c = children[i], x, d = c.value * dx, dy);

-           x += d;

-         }

-       }

-     }

-     function depth(node) {

-       var children = node.children, d = 0;

-       if (children && (n = children.length)) {

-         var i = -1, n;

-         while (++i < n) d = Math.max(d, depth(children[i]));

-       }

-       return 1 + d;

-     }

-     function partition(d, i) {

-       var nodes = hierarchy.call(this, d, i);

-       position(nodes[0], 0, size[0], size[1] / depth(nodes[0]));

-       return nodes;

-     }

-     partition.size = function(x) {

-       if (!arguments.length) return size;

-       size = x;

-       return partition;

-     };

-     return d3_layout_hierarchyRebind(partition, hierarchy);

-   };

-   d3.layout.pie = function() {

-     var value = Number, sort = d3_layout_pieSortByValue, startAngle = 0, endAngle = τ, padAngle = 0;

-     function pie(data) {

-       var n = data.length, values = data.map(function(d, i) {

-         return +value.call(pie, d, i);

-       }), a = +(typeof startAngle === "function" ? startAngle.apply(this, arguments) : startAngle), da = (typeof endAngle === "function" ? endAngle.apply(this, arguments) : endAngle) - a, p = Math.min(Math.abs(da) / n, +(typeof padAngle === "function" ? padAngle.apply(this, arguments) : padAngle)), pa = p * (da < 0 ? -1 : 1), sum = d3.sum(values), k = sum ? (da - n * pa) / sum : 0, index = d3.range(n), arcs = [], v;

-       if (sort != null) index.sort(sort === d3_layout_pieSortByValue ? function(i, j) {

-         return values[j] - values[i];

-       } : function(i, j) {

-         return sort(data[i], data[j]);

-       });

-       index.forEach(function(i) {

-         arcs[i] = {

-           data: data[i],

-           value: v = values[i],

-           startAngle: a,

-           endAngle: a += v * k + pa,

-           padAngle: p

-         };

-       });

-       return arcs;

-     }

-     pie.value = function(_) {

-       if (!arguments.length) return value;

-       value = _;

-       return pie;

-     };

-     pie.sort = function(_) {

-       if (!arguments.length) return sort;

-       sort = _;

-       return pie;

-     };

-     pie.startAngle = function(_) {

-       if (!arguments.length) return startAngle;

-       startAngle = _;

-       return pie;

-     };

-     pie.endAngle = function(_) {

-       if (!arguments.length) return endAngle;

-       endAngle = _;

-       return pie;

-     };

-     pie.padAngle = function(_) {

-       if (!arguments.length) return padAngle;

-       padAngle = _;

-       return pie;

-     };

-     return pie;

-   };

-   var d3_layout_pieSortByValue = {};

-   d3.layout.stack = function() {

-     var values = d3_identity, order = d3_layout_stackOrderDefault, offset = d3_layout_stackOffsetZero, out = d3_layout_stackOut, x = d3_layout_stackX, y = d3_layout_stackY;

-     function stack(data, index) {

-       if (!(n = data.length)) return data;

-       var series = data.map(function(d, i) {

-         return values.call(stack, d, i);

-       });

-       var points = series.map(function(d) {

-         return d.map(function(v, i) {

-           return [ x.call(stack, v, i), y.call(stack, v, i) ];

-         });

-       });

-       var orders = order.call(stack, points, index);

-       series = d3.permute(series, orders);

-       points = d3.permute(points, orders);

-       var offsets = offset.call(stack, points, index);

-       var m = series[0].length, n, i, j, o;

-       for (j = 0; j < m; ++j) {

-         out.call(stack, series[0][j], o = offsets[j], points[0][j][1]);

-         for (i = 1; i < n; ++i) {

-           out.call(stack, series[i][j], o += points[i - 1][j][1], points[i][j][1]);

-         }

-       }

-       return data;

-     }

-     stack.values = function(x) {

-       if (!arguments.length) return values;

-       values = x;

-       return stack;

-     };

-     stack.order = function(x) {

-       if (!arguments.length) return order;

-       order = typeof x === "function" ? x : d3_layout_stackOrders.get(x) || d3_layout_stackOrderDefault;

-       return stack;

-     };

-     stack.offset = function(x) {

-       if (!arguments.length) return offset;

-       offset = typeof x === "function" ? x : d3_layout_stackOffsets.get(x) || d3_layout_stackOffsetZero;

-       return stack;

-     };

-     stack.x = function(z) {

-       if (!arguments.length) return x;

-       x = z;

-       return stack;

-     };

-     stack.y = function(z) {

-       if (!arguments.length) return y;

-       y = z;

-       return stack;

-     };

-     stack.out = function(z) {

-       if (!arguments.length) return out;

-       out = z;

-       return stack;

-     };

-     return stack;

-   };

-   function d3_layout_stackX(d) {

-     return d.x;

-   }

-   function d3_layout_stackY(d) {

-     return d.y;

-   }

-   function d3_layout_stackOut(d, y0, y) {

-     d.y0 = y0;

-     d.y = y;

-   }

-   var d3_layout_stackOrders = d3.map({

-     "inside-out": function(data) {

-       var n = data.length, i, j, max = data.map(d3_layout_stackMaxIndex), sums = data.map(d3_layout_stackReduceSum), index = d3.range(n).sort(function(a, b) {

-         return max[a] - max[b];

-       }), top = 0, bottom = 0, tops = [], bottoms = [];

-       for (i = 0; i < n; ++i) {

-         j = index[i];

-         if (top < bottom) {

-           top += sums[j];

-           tops.push(j);

-         } else {

-           bottom += sums[j];

-           bottoms.push(j);

-         }

-       }

-       return bottoms.reverse().concat(tops);

-     },

-     reverse: function(data) {

-       return d3.range(data.length).reverse();

-     },

-     "default": d3_layout_stackOrderDefault

-   });

-   var d3_layout_stackOffsets = d3.map({

-     silhouette: function(data) {

-       var n = data.length, m = data[0].length, sums = [], max = 0, i, j, o, y0 = [];

-       for (j = 0; j < m; ++j) {

-         for (i = 0, o = 0; i < n; i++) o += data[i][j][1];

-         if (o > max) max = o;

-         sums.push(o);

-       }

-       for (j = 0; j < m; ++j) {

-         y0[j] = (max - sums[j]) / 2;

-       }

-       return y0;

-     },

-     wiggle: function(data) {

-       var n = data.length, x = data[0], m = x.length, i, j, k, s1, s2, s3, dx, o, o0, y0 = [];

-       y0[0] = o = o0 = 0;

-       for (j = 1; j < m; ++j) {

-         for (i = 0, s1 = 0; i < n; ++i) s1 += data[i][j][1];

-         for (i = 0, s2 = 0, dx = x[j][0] - x[j - 1][0]; i < n; ++i) {

-           for (k = 0, s3 = (data[i][j][1] - data[i][j - 1][1]) / (2 * dx); k < i; ++k) {

-             s3 += (data[k][j][1] - data[k][j - 1][1]) / dx;

-           }

-           s2 += s3 * data[i][j][1];

-         }

-         y0[j] = o -= s1 ? s2 / s1 * dx : 0;

-         if (o < o0) o0 = o;

-       }

-       for (j = 0; j < m; ++j) y0[j] -= o0;

-       return y0;

-     },

-     expand: function(data) {

-       var n = data.length, m = data[0].length, k = 1 / n, i, j, o, y0 = [];

-       for (j = 0; j < m; ++j) {

-         for (i = 0, o = 0; i < n; i++) o += data[i][j][1];

-         if (o) for (i = 0; i < n; i++) data[i][j][1] /= o; else for (i = 0; i < n; i++) data[i][j][1] = k;

-       }

-       for (j = 0; j < m; ++j) y0[j] = 0;

-       return y0;

-     },

-     zero: d3_layout_stackOffsetZero

-   });

-   function d3_layout_stackOrderDefault(data) {

-     return d3.range(data.length);

-   }

-   function d3_layout_stackOffsetZero(data) {

-     var j = -1, m = data[0].length, y0 = [];

-     while (++j < m) y0[j] = 0;

-     return y0;

-   }

-   function d3_layout_stackMaxIndex(array) {

-     var i = 1, j = 0, v = array[0][1], k, n = array.length;

-     for (;i < n; ++i) {

-       if ((k = array[i][1]) > v) {

-         j = i;

-         v = k;

-       }

-     }

-     return j;

-   }

-   function d3_layout_stackReduceSum(d) {

-     return d.reduce(d3_layout_stackSum, 0);

-   }

-   function d3_layout_stackSum(p, d) {

-     return p + d[1];

-   }

-   d3.layout.histogram = function() {

-     var frequency = true, valuer = Number, ranger = d3_layout_histogramRange, binner = d3_layout_histogramBinSturges;

-     function histogram(data, i) {

-       var bins = [], values = data.map(valuer, this), range = ranger.call(this, values, i), thresholds = binner.call(this, range, values, i), bin, i = -1, n = values.length, m = thresholds.length - 1, k = frequency ? 1 : 1 / n, x;

-       while (++i < m) {

-         bin = bins[i] = [];

-         bin.dx = thresholds[i + 1] - (bin.x = thresholds[i]);

-         bin.y = 0;

-       }

-       if (m > 0) {

-         i = -1;

-         while (++i < n) {

-           x = values[i];

-           if (x >= range[0] && x <= range[1]) {

-             bin = bins[d3.bisect(thresholds, x, 1, m) - 1];

-             bin.y += k;

-             bin.push(data[i]);

-           }

-         }

-       }

-       return bins;

-     }

-     histogram.value = function(x) {

-       if (!arguments.length) return valuer;

-       valuer = x;

-       return histogram;

-     };

-     histogram.range = function(x) {

-       if (!arguments.length) return ranger;

-       ranger = d3_functor(x);

-       return histogram;

-     };

-     histogram.bins = function(x) {

-       if (!arguments.length) return binner;

-       binner = typeof x === "number" ? function(range) {

-         return d3_layout_histogramBinFixed(range, x);

-       } : d3_functor(x);

-       return histogram;

-     };

-     histogram.frequency = function(x) {

-       if (!arguments.length) return frequency;

-       frequency = !!x;

-       return histogram;

-     };

-     return histogram;

-   };

-   function d3_layout_histogramBinSturges(range, values) {

-     return d3_layout_histogramBinFixed(range, Math.ceil(Math.log(values.length) / Math.LN2 + 1));

-   }

-   function d3_layout_histogramBinFixed(range, n) {

-     var x = -1, b = +range[0], m = (range[1] - b) / n, f = [];

-     while (++x <= n) f[x] = m * x + b;

-     return f;

-   }

-   function d3_layout_histogramRange(values) {

-     return [ d3.min(values), d3.max(values) ];

-   }

-   d3.layout.pack = function() {

-     var hierarchy = d3.layout.hierarchy().sort(d3_layout_packSort), padding = 0, size = [ 1, 1 ], radius;

-     function pack(d, i) {

-       var nodes = hierarchy.call(this, d, i), root = nodes[0], w = size[0], h = size[1], r = radius == null ? Math.sqrt : typeof radius === "function" ? radius : function() {

-         return radius;

-       };

-       root.x = root.y = 0;

-       d3_layout_hierarchyVisitAfter(root, function(d) {

-         d.r = +r(d.value);

-       });

-       d3_layout_hierarchyVisitAfter(root, d3_layout_packSiblings);

-       if (padding) {

-         var dr = padding * (radius ? 1 : Math.max(2 * root.r / w, 2 * root.r / h)) / 2;

-         d3_layout_hierarchyVisitAfter(root, function(d) {

-           d.r += dr;

-         });

-         d3_layout_hierarchyVisitAfter(root, d3_layout_packSiblings);

-         d3_layout_hierarchyVisitAfter(root, function(d) {

-           d.r -= dr;

-         });

-       }

-       d3_layout_packTransform(root, w / 2, h / 2, radius ? 1 : 1 / Math.max(2 * root.r / w, 2 * root.r / h));

-       return nodes;

-     }

-     pack.size = function(_) {

-       if (!arguments.length) return size;

-       size = _;

-       return pack;

-     };

-     pack.radius = function(_) {

-       if (!arguments.length) return radius;

-       radius = _ == null || typeof _ === "function" ? _ : +_;

-       return pack;

-     };

-     pack.padding = function(_) {

-       if (!arguments.length) return padding;

-       padding = +_;

-       return pack;

-     };

-     return d3_layout_hierarchyRebind(pack, hierarchy);

-   };

-   function d3_layout_packSort(a, b) {

-     return a.value - b.value;

-   }

-   function d3_layout_packInsert(a, b) {

-     var c = a._pack_next;

-     a._pack_next = b;

-     b._pack_prev = a;

-     b._pack_next = c;

-     c._pack_prev = b;

-   }

-   function d3_layout_packSplice(a, b) {

-     a._pack_next = b;

-     b._pack_prev = a;

-   }

-   function d3_layout_packIntersects(a, b) {

-     var dx = b.x - a.x, dy = b.y - a.y, dr = a.r + b.r;

-     return .999 * dr * dr > dx * dx + dy * dy;

-   }

-   function d3_layout_packSiblings(node) {

-     if (!(nodes = node.children) || !(n = nodes.length)) return;

-     var nodes, xMin = Infinity, xMax = -Infinity, yMin = Infinity, yMax = -Infinity, a, b, c, i, j, k, n;

-     function bound(node) {

-       xMin = Math.min(node.x - node.r, xMin);

-       xMax = Math.max(node.x + node.r, xMax);

-       yMin = Math.min(node.y - node.r, yMin);

-       yMax = Math.max(node.y + node.r, yMax);

-     }

-     nodes.forEach(d3_layout_packLink);

-     a = nodes[0];

-     a.x = -a.r;

-     a.y = 0;

-     bound(a);

-     if (n > 1) {

-       b = nodes[1];

-       b.x = b.r;

-       b.y = 0;

-       bound(b);

-       if (n > 2) {

-         c = nodes[2];

-         d3_layout_packPlace(a, b, c);

-         bound(c);

-         d3_layout_packInsert(a, c);

-         a._pack_prev = c;

-         d3_layout_packInsert(c, b);

-         b = a._pack_next;

-         for (i = 3; i < n; i++) {

-           d3_layout_packPlace(a, b, c = nodes[i]);

-           var isect = 0, s1 = 1, s2 = 1;

-           for (j = b._pack_next; j !== b; j = j._pack_next, s1++) {

-             if (d3_layout_packIntersects(j, c)) {

-               isect = 1;

-               break;

-             }

-           }

-           if (isect == 1) {

-             for (k = a._pack_prev; k !== j._pack_prev; k = k._pack_prev, s2++) {

-               if (d3_layout_packIntersects(k, c)) {

-                 break;

-               }

-             }

-           }

-           if (isect) {

-             if (s1 < s2 || s1 == s2 && b.r < a.r) d3_layout_packSplice(a, b = j); else d3_layout_packSplice(a = k, b);

-             i--;

-           } else {

-             d3_layout_packInsert(a, c);

-             b = c;

-             bound(c);

-           }

-         }

-       }

-     }

-     var cx = (xMin + xMax) / 2, cy = (yMin + yMax) / 2, cr = 0;

-     for (i = 0; i < n; i++) {

-       c = nodes[i];

-       c.x -= cx;

-       c.y -= cy;

-       cr = Math.max(cr, c.r + Math.sqrt(c.x * c.x + c.y * c.y));

-     }

-     node.r = cr;

-     nodes.forEach(d3_layout_packUnlink);

-   }

-   function d3_layout_packLink(node) {

-     node._pack_next = node._pack_prev = node;

-   }

-   function d3_layout_packUnlink(node) {

-     delete node._pack_next;

-     delete node._pack_prev;

-   }

-   function d3_layout_packTransform(node, x, y, k) {

-     var children = node.children;

-     node.x = x += k * node.x;

-     node.y = y += k * node.y;

-     node.r *= k;

-     if (children) {

-       var i = -1, n = children.length;

-       while (++i < n) d3_layout_packTransform(children[i], x, y, k);

-     }

-   }

-   function d3_layout_packPlace(a, b, c) {

-     var db = a.r + c.r, dx = b.x - a.x, dy = b.y - a.y;

-     if (db && (dx || dy)) {

-       var da = b.r + c.r, dc = dx * dx + dy * dy;

-       da *= da;

-       db *= db;

-       var x = .5 + (db - da) / (2 * dc), y = Math.sqrt(Math.max(0, 2 * da * (db + dc) - (db -= dc) * db - da * da)) / (2 * dc);

-       c.x = a.x + x * dx + y * dy;

-       c.y = a.y + x * dy - y * dx;

-     } else {

-       c.x = a.x + db;

-       c.y = a.y;

-     }

-   }

-   d3.layout.tree = function() {

-     var hierarchy = d3.layout.hierarchy().sort(null).value(null), separation = d3_layout_treeSeparation, size = [ 1, 1 ], nodeSize = null;

-     function tree(d, i) {

-       var nodes = hierarchy.call(this, d, i), root0 = nodes[0], root1 = wrapTree(root0);

-       d3_layout_hierarchyVisitAfter(root1, firstWalk), root1.parent.m = -root1.z;

-       d3_layout_hierarchyVisitBefore(root1, secondWalk);

-       if (nodeSize) d3_layout_hierarchyVisitBefore(root0, sizeNode); else {

-         var left = root0, right = root0, bottom = root0;

-         d3_layout_hierarchyVisitBefore(root0, function(node) {

-           if (node.x < left.x) left = node;

-           if (node.x > right.x) right = node;

-           if (node.depth > bottom.depth) bottom = node;

-         });

-         var tx = separation(left, right) / 2 - left.x, kx = size[0] / (right.x + separation(right, left) / 2 + tx), ky = size[1] / (bottom.depth || 1);

-         d3_layout_hierarchyVisitBefore(root0, function(node) {

-           node.x = (node.x + tx) * kx;

-           node.y = node.depth * ky;

-         });

-       }

-       return nodes;

-     }

-     function wrapTree(root0) {

-       var root1 = {

-         A: null,

-         children: [ root0 ]

-       }, queue = [ root1 ], node1;

-       while ((node1 = queue.pop()) != null) {

-         for (var children = node1.children, child, i = 0, n = children.length; i < n; ++i) {

-           queue.push((children[i] = child = {

-             _: children[i],

-             parent: node1,

-             children: (child = children[i].children) && child.slice() || [],

-             A: null,

-             a: null,

-             z: 0,

-             m: 0,

-             c: 0,

-             s: 0,

-             t: null,

-             i: i

-           }).a = child);

-         }

-       }

-       return root1.children[0];

-     }

-     function firstWalk(v) {

-       var children = v.children, siblings = v.parent.children, w = v.i ? siblings[v.i - 1] : null;

-       if (children.length) {

-         d3_layout_treeShift(v);

-         var midpoint = (children[0].z + children[children.length - 1].z) / 2;

-         if (w) {

-           v.z = w.z + separation(v._, w._);

-           v.m = v.z - midpoint;

-         } else {

-           v.z = midpoint;

-         }

-       } else if (w) {

-         v.z = w.z + separation(v._, w._);

-       }

-       v.parent.A = apportion(v, w, v.parent.A || siblings[0]);

-     }

-     function secondWalk(v) {

-       v._.x = v.z + v.parent.m;

-       v.m += v.parent.m;

-     }

-     function apportion(v, w, ancestor) {

-       if (w) {

-         var vip = v, vop = v, vim = w, vom = vip.parent.children[0], sip = vip.m, sop = vop.m, sim = vim.m, som = vom.m, shift;

-         while (vim = d3_layout_treeRight(vim), vip = d3_layout_treeLeft(vip), vim && vip) {

-           vom = d3_layout_treeLeft(vom);

-           vop = d3_layout_treeRight(vop);

-           vop.a = v;

-           shift = vim.z + sim - vip.z - sip + separation(vim._, vip._);

-           if (shift > 0) {

-             d3_layout_treeMove(d3_layout_treeAncestor(vim, v, ancestor), v, shift);

-             sip += shift;

-             sop += shift;

-           }

-           sim += vim.m;

-           sip += vip.m;

-           som += vom.m;

-           sop += vop.m;

-         }

-         if (vim && !d3_layout_treeRight(vop)) {

-           vop.t = vim;

-           vop.m += sim - sop;

-         }

-         if (vip && !d3_layout_treeLeft(vom)) {

-           vom.t = vip;

-           vom.m += sip - som;

-           ancestor = v;

-         }

-       }

-       return ancestor;

-     }

-     function sizeNode(node) {

-       node.x *= size[0];

-       node.y = node.depth * size[1];

-     }

-     tree.separation = function(x) {

-       if (!arguments.length) return separation;

-       separation = x;

-       return tree;

-     };

-     tree.size = function(x) {

-       if (!arguments.length) return nodeSize ? null : size;

-       nodeSize = (size = x) == null ? sizeNode : null;

-       return tree;

-     };

-     tree.nodeSize = function(x) {

-       if (!arguments.length) return nodeSize ? size : null;

-       nodeSize = (size = x) == null ? null : sizeNode;

-       return tree;

-     };

-     return d3_layout_hierarchyRebind(tree, hierarchy);

-   };

-   function d3_layout_treeSeparation(a, b) {

-     return a.parent == b.parent ? 1 : 2;

-   }

-   function d3_layout_treeLeft(v) {

-     var children = v.children;

-     return children.length ? children[0] : v.t;

-   }

-   function d3_layout_treeRight(v) {

-     var children = v.children, n;

-     return (n = children.length) ? children[n - 1] : v.t;

-   }

-   function d3_layout_treeMove(wm, wp, shift) {

-     var change = shift / (wp.i - wm.i);

-     wp.c -= change;

-     wp.s += shift;

-     wm.c += change;

-     wp.z += shift;

-     wp.m += shift;

-   }

-   function d3_layout_treeShift(v) {

-     var shift = 0, change = 0, children = v.children, i = children.length, w;

-     while (--i >= 0) {

-       w = children[i];

-       w.z += shift;

-       w.m += shift;

-       shift += w.s + (change += w.c);

-     }

-   }

-   function d3_layout_treeAncestor(vim, v, ancestor) {

-     return vim.a.parent === v.parent ? vim.a : ancestor;

-   }

-   d3.layout.cluster = function() {

-     var hierarchy = d3.layout.hierarchy().sort(null).value(null), separation = d3_layout_treeSeparation, size = [ 1, 1 ], nodeSize = false;

-     function cluster(d, i) {

-       var nodes = hierarchy.call(this, d, i), root = nodes[0], previousNode, x = 0;

-       d3_layout_hierarchyVisitAfter(root, function(node) {

-         var children = node.children;

-         if (children && children.length) {

-           node.x = d3_layout_clusterX(children);

-           node.y = d3_layout_clusterY(children);

-         } else {

-           node.x = previousNode ? x += separation(node, previousNode) : 0;

-           node.y = 0;

-           previousNode = node;

-         }

-       });

-       var left = d3_layout_clusterLeft(root), right = d3_layout_clusterRight(root), x0 = left.x - separation(left, right) / 2, x1 = right.x + separation(right, left) / 2;

-       d3_layout_hierarchyVisitAfter(root, nodeSize ? function(node) {

-         node.x = (node.x - root.x) * size[0];

-         node.y = (root.y - node.y) * size[1];

-       } : function(node) {

-         node.x = (node.x - x0) / (x1 - x0) * size[0];

-         node.y = (1 - (root.y ? node.y / root.y : 1)) * size[1];

-       });

-       return nodes;

-     }

-     cluster.separation = function(x) {

-       if (!arguments.length) return separation;

-       separation = x;

-       return cluster;

-     };

-     cluster.size = function(x) {

-       if (!arguments.length) return nodeSize ? null : size;

-       nodeSize = (size = x) == null;

-       return cluster;

-     };

-     cluster.nodeSize = function(x) {

-       if (!arguments.length) return nodeSize ? size : null;

-       nodeSize = (size = x) != null;

-       return cluster;

-     };

-     return d3_layout_hierarchyRebind(cluster, hierarchy);

-   };

-   function d3_layout_clusterY(children) {

-     return 1 + d3.max(children, function(child) {

-       return child.y;

-     });

-   }

-   function d3_layout_clusterX(children) {

-     return children.reduce(function(x, child) {

-       return x + child.x;

-     }, 0) / children.length;

-   }

-   function d3_layout_clusterLeft(node) {

-     var children = node.children;

-     return children && children.length ? d3_layout_clusterLeft(children[0]) : node;

-   }

-   function d3_layout_clusterRight(node) {

-     var children = node.children, n;

-     return children && (n = children.length) ? d3_layout_clusterRight(children[n - 1]) : node;

-   }

-   d3.layout.treemap = function() {

-     var hierarchy = d3.layout.hierarchy(), round = Math.round, size = [ 1, 1 ], padding = null, pad = d3_layout_treemapPadNull, sticky = false, stickies, mode = "squarify", ratio = .5 * (1 + Math.sqrt(5));

-     function scale(children, k) {

-       var i = -1, n = children.length, child, area;

-       while (++i < n) {

-         area = (child = children[i]).value * (k < 0 ? 0 : k);

-         child.area = isNaN(area) || area <= 0 ? 0 : area;

-       }

-     }

-     function squarify(node) {

-       var children = node.children;

-       if (children && children.length) {

-         var rect = pad(node), row = [], remaining = children.slice(), child, best = Infinity, score, u = mode === "slice" ? rect.dx : mode === "dice" ? rect.dy : mode === "slice-dice" ? node.depth & 1 ? rect.dy : rect.dx : Math.min(rect.dx, rect.dy), n;

-         scale(remaining, rect.dx * rect.dy / node.value);

-         row.area = 0;

-         while ((n = remaining.length) > 0) {

-           row.push(child = remaining[n - 1]);

-           row.area += child.area;

-           if (mode !== "squarify" || (score = worst(row, u)) <= best) {

-             remaining.pop();

-             best = score;

-           } else {

-             row.area -= row.pop().area;

-             position(row, u, rect, false);

-             u = Math.min(rect.dx, rect.dy);

-             row.length = row.area = 0;

-             best = Infinity;

-           }

-         }

-         if (row.length) {

-           position(row, u, rect, true);

-           row.length = row.area = 0;

-         }

-         children.forEach(squarify);

-       }

-     }

-     function stickify(node) {

-       var children = node.children;

-       if (children && children.length) {

-         var rect = pad(node), remaining = children.slice(), child, row = [];

-         scale(remaining, rect.dx * rect.dy / node.value);

-         row.area = 0;

-         while (child = remaining.pop()) {

-           row.push(child);

-           row.area += child.area;

-           if (child.z != null) {

-             position(row, child.z ? rect.dx : rect.dy, rect, !remaining.length);

-             row.length = row.area = 0;

-           }

-         }

-         children.forEach(stickify);

-       }

-     }

-     function worst(row, u) {

-       var s = row.area, r, rmax = 0, rmin = Infinity, i = -1, n = row.length;

-       while (++i < n) {

-         if (!(r = row[i].area)) continue;

-         if (r < rmin) rmin = r;

-         if (r > rmax) rmax = r;

-       }

-       s *= s;

-       u *= u;

-       return s ? Math.max(u * rmax * ratio / s, s / (u * rmin * ratio)) : Infinity;

-     }

-     function position(row, u, rect, flush) {

-       var i = -1, n = row.length, x = rect.x, y = rect.y, v = u ? round(row.area / u) : 0, o;

-       if (u == rect.dx) {

-         if (flush || v > rect.dy) v = rect.dy;

-         while (++i < n) {

-           o = row[i];

-           o.x = x;

-           o.y = y;

-           o.dy = v;

-           x += o.dx = Math.min(rect.x + rect.dx - x, v ? round(o.area / v) : 0);

-         }

-         o.z = true;

-         o.dx += rect.x + rect.dx - x;

-         rect.y += v;

-         rect.dy -= v;

-       } else {

-         if (flush || v > rect.dx) v = rect.dx;

-         while (++i < n) {

-           o = row[i];

-           o.x = x;

-           o.y = y;

-           o.dx = v;

-           y += o.dy = Math.min(rect.y + rect.dy - y, v ? round(o.area / v) : 0);

-         }

-         o.z = false;

-         o.dy += rect.y + rect.dy - y;

-         rect.x += v;

-         rect.dx -= v;

-       }

-     }

-     function treemap(d) {

-       var nodes = stickies || hierarchy(d), root = nodes[0];

-       root.x = root.y = 0;

-       if (root.value) root.dx = size[0], root.dy = size[1]; else root.dx = root.dy = 0;

-       if (stickies) hierarchy.revalue(root);

-       scale([ root ], root.dx * root.dy / root.value);

-       (stickies ? stickify : squarify)(root);

-       if (sticky) stickies = nodes;

-       return nodes;

-     }

-     treemap.size = function(x) {

-       if (!arguments.length) return size;

-       size = x;

-       return treemap;

-     };

-     treemap.padding = function(x) {

-       if (!arguments.length) return padding;

-       function padFunction(node) {

-         var p = x.call(treemap, node, node.depth);

-         return p == null ? d3_layout_treemapPadNull(node) : d3_layout_treemapPad(node, typeof p === "number" ? [ p, p, p, p ] : p);

-       }

-       function padConstant(node) {

-         return d3_layout_treemapPad(node, x);

-       }

-       var type;

-       pad = (padding = x) == null ? d3_layout_treemapPadNull : (type = typeof x) === "function" ? padFunction : type === "number" ? (x = [ x, x, x, x ],

-       padConstant) : padConstant;

-       return treemap;

-     };

-     treemap.round = function(x) {

-       if (!arguments.length) return round != Number;

-       round = x ? Math.round : Number;

-       return treemap;

-     };

-     treemap.sticky = function(x) {

-       if (!arguments.length) return sticky;

-       sticky = x;

-       stickies = null;

-       return treemap;

-     };

-     treemap.ratio = function(x) {

-       if (!arguments.length) return ratio;

-       ratio = x;

-       return treemap;

-     };

-     treemap.mode = function(x) {

-       if (!arguments.length) return mode;

-       mode = x + "";

-       return treemap;

-     };

-     return d3_layout_hierarchyRebind(treemap, hierarchy);

-   };

-   function d3_layout_treemapPadNull(node) {

-     return {

-       x: node.x,

-       y: node.y,

-       dx: node.dx,

-       dy: node.dy

-     };

-   }

-   function d3_layout_treemapPad(node, padding) {

-     var x = node.x + padding[3], y = node.y + padding[0], dx = node.dx - padding[1] - padding[3], dy = node.dy - padding[0] - padding[2];

-     if (dx < 0) {

-       x += dx / 2;

-       dx = 0;

-     }

-     if (dy < 0) {

-       y += dy / 2;

-       dy = 0;

-     }

-     return {

-       x: x,

-       y: y,

-       dx: dx,

-       dy: dy

-     };

-   }

-   d3.random = {

-     normal: function(µ, σ) {

-       var n = arguments.length;

-       if (n < 2) σ = 1;

-       if (n < 1) µ = 0;

-       return function() {

-         var x, y, r;

-         do {

-           x = Math.random() * 2 - 1;

-           y = Math.random() * 2 - 1;

-           r = x * x + y * y;

-         } while (!r || r > 1);

-         return µ + σ * x * Math.sqrt(-2 * Math.log(r) / r);

-       };

-     },

-     logNormal: function() {

-       var random = d3.random.normal.apply(d3, arguments);

-       return function() {

-         return Math.exp(random());

-       };

-     },

-     bates: function(m) {

-       var random = d3.random.irwinHall(m);

-       return function() {

-         return random() / m;

-       };

-     },

-     irwinHall: function(m) {

-       return function() {

-         for (var s = 0, j = 0; j < m; j++) s += Math.random();

-         return s;

-       };

-     }

-   };

-   d3.scale = {};

-   function d3_scaleExtent(domain) {

-     var start = domain[0], stop = domain[domain.length - 1];

-     return start < stop ? [ start, stop ] : [ stop, start ];

-   }

-   function d3_scaleRange(scale) {

-     return scale.rangeExtent ? scale.rangeExtent() : d3_scaleExtent(scale.range());

-   }

-   function d3_scale_bilinear(domain, range, uninterpolate, interpolate) {

-     var u = uninterpolate(domain[0], domain[1]), i = interpolate(range[0], range[1]);

-     return function(x) {

-       return i(u(x));

-     };

-   }

-   function d3_scale_nice(domain, nice) {

-     var i0 = 0, i1 = domain.length - 1, x0 = domain[i0], x1 = domain[i1], dx;

-     if (x1 < x0) {

-       dx = i0, i0 = i1, i1 = dx;

-       dx = x0, x0 = x1, x1 = dx;

-     }

-     domain[i0] = nice.floor(x0);

-     domain[i1] = nice.ceil(x1);

-     return domain;

-   }

-   function d3_scale_niceStep(step) {

-     return step ? {

-       floor: function(x) {

-         return Math.floor(x / step) * step;

-       },

-       ceil: function(x) {

-         return Math.ceil(x / step) * step;

-       }

-     } : d3_scale_niceIdentity;

-   }

-   var d3_scale_niceIdentity = {

-     floor: d3_identity,

-     ceil: d3_identity

-   };

-   function d3_scale_polylinear(domain, range, uninterpolate, interpolate) {

-     var u = [], i = [], j = 0, k = Math.min(domain.length, range.length) - 1;

-     if (domain[k] < domain[0]) {

-       domain = domain.slice().reverse();

-       range = range.slice().reverse();

-     }

-     while (++j <= k) {

-       u.push(uninterpolate(domain[j - 1], domain[j]));

-       i.push(interpolate(range[j - 1], range[j]));

-     }

-     return function(x) {

-       var j = d3.bisect(domain, x, 1, k) - 1;

-       return i[j](u[j](x));

-     };

-   }

-   d3.scale.linear = function() {

-     return d3_scale_linear([ 0, 1 ], [ 0, 1 ], d3_interpolate, false);

-   };

-   function d3_scale_linear(domain, range, interpolate, clamp) {

-     var output, input;

-     function rescale() {

-       var linear = Math.min(domain.length, range.length) > 2 ? d3_scale_polylinear : d3_scale_bilinear, uninterpolate = clamp ? d3_uninterpolateClamp : d3_uninterpolateNumber;

-       output = linear(domain, range, uninterpolate, interpolate);

-       input = linear(range, domain, uninterpolate, d3_interpolate);

-       return scale;

-     }

-     function scale(x) {

-       return output(x);

-     }

-     scale.invert = function(y) {

-       return input(y);

-     };

-     scale.domain = function(x) {

-       if (!arguments.length) return domain;

-       domain = x.map(Number);

-       return rescale();

-     };

-     scale.range = function(x) {

-       if (!arguments.length) return range;

-       range = x;

-       return rescale();

-     };

-     scale.rangeRound = function(x) {

-       return scale.range(x).interpolate(d3_interpolateRound);

-     };

-     scale.clamp = function(x) {

-       if (!arguments.length) return clamp;

-       clamp = x;

-       return rescale();

-     };

-     scale.interpolate = function(x) {

-       if (!arguments.length) return interpolate;

-       interpolate = x;

-       return rescale();

-     };

-     scale.ticks = function(m) {

-       return d3_scale_linearTicks(domain, m);

-     };

-     scale.tickFormat = function(m, format) {

-       return d3_scale_linearTickFormat(domain, m, format);

-     };

-     scale.nice = function(m) {

-       d3_scale_linearNice(domain, m);

-       return rescale();

-     };

-     scale.copy = function() {

-       return d3_scale_linear(domain, range, interpolate, clamp);

-     };

-     return rescale();

-   }

-   function d3_scale_linearRebind(scale, linear) {

-     return d3.rebind(scale, linear, "range", "rangeRound", "interpolate", "clamp");

-   }

-   function d3_scale_linearNice(domain, m) {

-     d3_scale_nice(domain, d3_scale_niceStep(d3_scale_linearTickRange(domain, m)[2]));

-     d3_scale_nice(domain, d3_scale_niceStep(d3_scale_linearTickRange(domain, m)[2]));

-     return domain;

-   }

-   function d3_scale_linearTickRange(domain, m) {

-     if (m == null) m = 10;

-     var extent = d3_scaleExtent(domain), span = extent[1] - extent[0], step = Math.pow(10, Math.floor(Math.log(span / m) / Math.LN10)), err = m / span * step;

-     if (err <= .15) step *= 10; else if (err <= .35) step *= 5; else if (err <= .75) step *= 2;

-     extent[0] = Math.ceil(extent[0] / step) * step;

-     extent[1] = Math.floor(extent[1] / step) * step + step * .5;

-     extent[2] = step;

-     return extent;

-   }

-   function d3_scale_linearTicks(domain, m) {

-     return d3.range.apply(d3, d3_scale_linearTickRange(domain, m));

-   }

-   function d3_scale_linearTickFormat(domain, m, format) {

-     var range = d3_scale_linearTickRange(domain, m);

-     if (format) {

-       var match = d3_format_re.exec(format);

-       match.shift();

-       if (match[8] === "s") {

-         var prefix = d3.formatPrefix(Math.max(abs(range[0]), abs(range[1])));

-         if (!match[7]) match[7] = "." + d3_scale_linearPrecision(prefix.scale(range[2]));

-         match[8] = "f";

-         format = d3.format(match.join(""));

-         return function(d) {

-           return format(prefix.scale(d)) + prefix.symbol;

-         };

-       }

-       if (!match[7]) match[7] = "." + d3_scale_linearFormatPrecision(match[8], range);

-       format = match.join("");

-     } else {

-       format = ",." + d3_scale_linearPrecision(range[2]) + "f";

-     }

-     return d3.format(format);

-   }

-   var d3_scale_linearFormatSignificant = {

-     s: 1,

-     g: 1,

-     p: 1,

-     r: 1,

-     e: 1

-   };

-   function d3_scale_linearPrecision(value) {

-     return -Math.floor(Math.log(value) / Math.LN10 + .01);

-   }

-   function d3_scale_linearFormatPrecision(type, range) {

-     var p = d3_scale_linearPrecision(range[2]);

-     return type in d3_scale_linearFormatSignificant ? Math.abs(p - d3_scale_linearPrecision(Math.max(abs(range[0]), abs(range[1])))) + +(type !== "e") : p - (type === "%") * 2;

-   }

-   d3.scale.log = function() {

-     return d3_scale_log(d3.scale.linear().domain([ 0, 1 ]), 10, true, [ 1, 10 ]);

-   };

-   function d3_scale_log(linear, base, positive, domain) {

-     function log(x) {

-       return (positive ? Math.log(x < 0 ? 0 : x) : -Math.log(x > 0 ? 0 : -x)) / Math.log(base);

-     }

-     function pow(x) {

-       return positive ? Math.pow(base, x) : -Math.pow(base, -x);

-     }

-     function scale(x) {

-       return linear(log(x));

-     }

-     scale.invert = function(x) {

-       return pow(linear.invert(x));

-     };

-     scale.domain = function(x) {

-       if (!arguments.length) return domain;

-       positive = x[0] >= 0;

-       linear.domain((domain = x.map(Number)).map(log));

-       return scale;

-     };

-     scale.base = function(_) {

-       if (!arguments.length) return base;

-       base = +_;

-       linear.domain(domain.map(log));

-       return scale;

-     };

-     scale.nice = function() {

-       var niced = d3_scale_nice(domain.map(log), positive ? Math : d3_scale_logNiceNegative);

-       linear.domain(niced);

-       domain = niced.map(pow);

-       return scale;

-     };

-     scale.ticks = function() {

-       var extent = d3_scaleExtent(domain), ticks = [], u = extent[0], v = extent[1], i = Math.floor(log(u)), j = Math.ceil(log(v)), n = base % 1 ? 2 : base;

-       if (isFinite(j - i)) {

-         if (positive) {

-           for (;i < j; i++) for (var k = 1; k < n; k++) ticks.push(pow(i) * k);

-           ticks.push(pow(i));

-         } else {

-           ticks.push(pow(i));

-           for (;i++ < j; ) for (var k = n - 1; k > 0; k--) ticks.push(pow(i) * k);

-         }

-         for (i = 0; ticks[i] < u; i++) {}

-         for (j = ticks.length; ticks[j - 1] > v; j--) {}

-         ticks = ticks.slice(i, j);

-       }

-       return ticks;

-     };

-     scale.tickFormat = function(n, format) {

-       if (!arguments.length) return d3_scale_logFormat;

-       if (arguments.length < 2) format = d3_scale_logFormat; else if (typeof format !== "function") format = d3.format(format);

-       var k = Math.max(1, base * n / scale.ticks().length);

-       return function(d) {

-         var i = d / pow(Math.round(log(d)));

-         if (i * base < base - .5) i *= base;

-         return i <= k ? format(d) : "";

-       };

-     };

-     scale.copy = function() {

-       return d3_scale_log(linear.copy(), base, positive, domain);

-     };

-     return d3_scale_linearRebind(scale, linear);

-   }

-   var d3_scale_logFormat = d3.format(".0e"), d3_scale_logNiceNegative = {

-     floor: function(x) {

-       return -Math.ceil(-x);

-     },

-     ceil: function(x) {

-       return -Math.floor(-x);

-     }

-   };

-   d3.scale.pow = function() {

-     return d3_scale_pow(d3.scale.linear(), 1, [ 0, 1 ]);

-   };

-   function d3_scale_pow(linear, exponent, domain) {

-     var powp = d3_scale_powPow(exponent), powb = d3_scale_powPow(1 / exponent);

-     function scale(x) {

-       return linear(powp(x));

-     }

-     scale.invert = function(x) {

-       return powb(linear.invert(x));

-     };

-     scale.domain = function(x) {

-       if (!arguments.length) return domain;

-       linear.domain((domain = x.map(Number)).map(powp));

-       return scale;

-     };

-     scale.ticks = function(m) {

-       return d3_scale_linearTicks(domain, m);

-     };

-     scale.tickFormat = function(m, format) {

-       return d3_scale_linearTickFormat(domain, m, format);

-     };

-     scale.nice = function(m) {

-       return scale.domain(d3_scale_linearNice(domain, m));

-     };

-     scale.exponent = function(x) {

-       if (!arguments.length) return exponent;

-       powp = d3_scale_powPow(exponent = x);

-       powb = d3_scale_powPow(1 / exponent);

-       linear.domain(domain.map(powp));

-       return scale;

-     };

-     scale.copy = function() {

-       return d3_scale_pow(linear.copy(), exponent, domain);

-     };

-     return d3_scale_linearRebind(scale, linear);

-   }

-   function d3_scale_powPow(e) {

-     return function(x) {

-       return x < 0 ? -Math.pow(-x, e) : Math.pow(x, e);

-     };

-   }

-   d3.scale.sqrt = function() {

-     return d3.scale.pow().exponent(.5);

-   };

-   d3.scale.ordinal = function() {

-     return d3_scale_ordinal([], {

-       t: "range",

-       a: [ [] ]

-     });

-   };

-   function d3_scale_ordinal(domain, ranger) {

-     var index, range, rangeBand;

-     function scale(x) {

-       return range[((index.get(x) || (ranger.t === "range" ? index.set(x, domain.push(x)) : NaN)) - 1) % range.length];

-     }

-     function steps(start, step) {

-       return d3.range(domain.length).map(function(i) {

-         return start + step * i;

-       });

-     }

-     scale.domain = function(x) {

-       if (!arguments.length) return domain;

-       domain = [];

-       index = new d3_Map();

-       var i = -1, n = x.length, xi;

-       while (++i < n) if (!index.has(xi = x[i])) index.set(xi, domain.push(xi));

-       return scale[ranger.t].apply(scale, ranger.a);

-     };

-     scale.range = function(x) {

-       if (!arguments.length) return range;

-       range = x;

-       rangeBand = 0;

-       ranger = {

-         t: "range",

-         a: arguments

-       };

-       return scale;

-     };

-     scale.rangePoints = function(x, padding) {

-       if (arguments.length < 2) padding = 0;

-       var start = x[0], stop = x[1], step = domain.length < 2 ? (start = (start + stop) / 2,

-       0) : (stop - start) / (domain.length - 1 + padding);

-       range = steps(start + step * padding / 2, step);

-       rangeBand = 0;

-       ranger = {

-         t: "rangePoints",

-         a: arguments

-       };

-       return scale;

-     };

-     scale.rangeRoundPoints = function(x, padding) {

-       if (arguments.length < 2) padding = 0;

-       var start = x[0], stop = x[1], step = domain.length < 2 ? (start = stop = Math.round((start + stop) / 2),

-       0) : (stop - start) / (domain.length - 1 + padding) | 0;

-       range = steps(start + Math.round(step * padding / 2 + (stop - start - (domain.length - 1 + padding) * step) / 2), step);

-       rangeBand = 0;

-       ranger = {

-         t: "rangeRoundPoints",

-         a: arguments

-       };

-       return scale;

-     };

-     scale.rangeBands = function(x, padding, outerPadding) {

-       if (arguments.length < 2) padding = 0;

-       if (arguments.length < 3) outerPadding = padding;

-       var reverse = x[1] < x[0], start = x[reverse - 0], stop = x[1 - reverse], step = (stop - start) / (domain.length - padding + 2 * outerPadding);

-       range = steps(start + step * outerPadding, step);

-       if (reverse) range.reverse();

-       rangeBand = step * (1 - padding);

-       ranger = {

-         t: "rangeBands",

-         a: arguments

-       };

-       return scale;

-     };

-     scale.rangeRoundBands = function(x, padding, outerPadding) {

-       if (arguments.length < 2) padding = 0;

-       if (arguments.length < 3) outerPadding = padding;

-       var reverse = x[1] < x[0], start = x[reverse - 0], stop = x[1 - reverse], step = Math.floor((stop - start) / (domain.length - padding + 2 * outerPadding));

-       range = steps(start + Math.round((stop - start - (domain.length - padding) * step) / 2), step);

-       if (reverse) range.reverse();

-       rangeBand = Math.round(step * (1 - padding));

-       ranger = {

-         t: "rangeRoundBands",

-         a: arguments

-       };

-       return scale;

-     };

-     scale.rangeBand = function() {

-       return rangeBand;

-     };

-     scale.rangeExtent = function() {

-       return d3_scaleExtent(ranger.a[0]);

-     };

-     scale.copy = function() {

-       return d3_scale_ordinal(domain, ranger);

-     };

-     return scale.domain(domain);

-   }

-   d3.scale.category10 = function() {

-     return d3.scale.ordinal().range(d3_category10);

-   };

-   d3.scale.category20 = function() {

-     return d3.scale.ordinal().range(d3_category20);

-   };

-   d3.scale.category20b = function() {

-     return d3.scale.ordinal().range(d3_category20b);

-   };

-   d3.scale.category20c = function() {

-     return d3.scale.ordinal().range(d3_category20c);

-   };

-   var d3_category10 = [ 2062260, 16744206, 2924588, 14034728, 9725885, 9197131, 14907330, 8355711, 12369186, 1556175 ].map(d3_rgbString);

-   var d3_category20 = [ 2062260, 11454440, 16744206, 16759672, 2924588, 10018698, 14034728, 16750742, 9725885, 12955861, 9197131, 12885140, 14907330, 16234194, 8355711, 13092807, 12369186, 14408589, 1556175, 10410725 ].map(d3_rgbString);

-   var d3_category20b = [ 3750777, 5395619, 7040719, 10264286, 6519097, 9216594, 11915115, 13556636, 9202993, 12426809, 15186514, 15190932, 8666169, 11356490, 14049643, 15177372, 8077683, 10834324, 13528509, 14589654 ].map(d3_rgbString);

-   var d3_category20c = [ 3244733, 7057110, 10406625, 13032431, 15095053, 16616764, 16625259, 16634018, 3253076, 7652470, 10607003, 13101504, 7695281, 10394312, 12369372, 14342891, 6513507, 9868950, 12434877, 14277081 ].map(d3_rgbString);

-   d3.scale.quantile = function() {

-     return d3_scale_quantile([], []);

-   };

-   function d3_scale_quantile(domain, range) {

-     var thresholds;

-     function rescale() {

-       var k = 0, q = range.length;

-       thresholds = [];

-       while (++k < q) thresholds[k - 1] = d3.quantile(domain, k / q);

-       return scale;

-     }

-     function scale(x) {

-       if (!isNaN(x = +x)) return range[d3.bisect(thresholds, x)];

-     }

-     scale.domain = function(x) {

-       if (!arguments.length) return domain;

-       domain = x.map(d3_number).filter(d3_numeric).sort(d3_ascending);

-       return rescale();

-     };

-     scale.range = function(x) {

-       if (!arguments.length) return range;

-       range = x;

-       return rescale();

-     };

-     scale.quantiles = function() {

-       return thresholds;

-     };

-     scale.invertExtent = function(y) {

-       y = range.indexOf(y);

-       return y < 0 ? [ NaN, NaN ] : [ y > 0 ? thresholds[y - 1] : domain[0], y < thresholds.length ? thresholds[y] : domain[domain.length - 1] ];

-     };

-     scale.copy = function() {

-       return d3_scale_quantile(domain, range);

-     };

-     return rescale();

-   }

-   d3.scale.quantize = function() {

-     return d3_scale_quantize(0, 1, [ 0, 1 ]);

-   };

-   function d3_scale_quantize(x0, x1, range) {

-     var kx, i;

-     function scale(x) {

-       return range[Math.max(0, Math.min(i, Math.floor(kx * (x - x0))))];

-     }

-     function rescale() {

-       kx = range.length / (x1 - x0);

-       i = range.length - 1;

-       return scale;

-     }

-     scale.domain = function(x) {

-       if (!arguments.length) return [ x0, x1 ];

-       x0 = +x[0];

-       x1 = +x[x.length - 1];

-       return rescale();

-     };

-     scale.range = function(x) {

-       if (!arguments.length) return range;

-       range = x;

-       return rescale();

-     };

-     scale.invertExtent = function(y) {

-       y = range.indexOf(y);

-       y = y < 0 ? NaN : y / kx + x0;

-       return [ y, y + 1 / kx ];

-     };

-     scale.copy = function() {

-       return d3_scale_quantize(x0, x1, range);

-     };

-     return rescale();

-   }

-   d3.scale.threshold = function() {

-     return d3_scale_threshold([ .5 ], [ 0, 1 ]);

-   };

-   function d3_scale_threshold(domain, range) {

-     function scale(x) {

-       if (x <= x) return range[d3.bisect(domain, x)];

-     }

-     scale.domain = function(_) {

-       if (!arguments.length) return domain;

-       domain = _;

-       return scale;

-     };

-     scale.range = function(_) {

-       if (!arguments.length) return range;

-       range = _;

-       return scale;

-     };

-     scale.invertExtent = function(y) {

-       y = range.indexOf(y);

-       return [ domain[y - 1], domain[y] ];

-     };

-     scale.copy = function() {

-       return d3_scale_threshold(domain, range);

-     };

-     return scale;

-   }

-   d3.scale.identity = function() {

-     return d3_scale_identity([ 0, 1 ]);

-   };

-   function d3_scale_identity(domain) {

-     function identity(x) {

-       return +x;

-     }

-     identity.invert = identity;

-     identity.domain = identity.range = function(x) {

-       if (!arguments.length) return domain;

-       domain = x.map(identity);

-       return identity;

-     };

-     identity.ticks = function(m) {

-       return d3_scale_linearTicks(domain, m);

-     };

-     identity.tickFormat = function(m, format) {

-       return d3_scale_linearTickFormat(domain, m, format);

-     };

-     identity.copy = function() {

-       return d3_scale_identity(domain);

-     };

-     return identity;

-   }

-   d3.svg = {};

-   function d3_zero() {

-     return 0;

-   }

-   d3.svg.arc = function() {

-     var innerRadius = d3_svg_arcInnerRadius, outerRadius = d3_svg_arcOuterRadius, cornerRadius = d3_zero, padRadius = d3_svg_arcAuto, startAngle = d3_svg_arcStartAngle, endAngle = d3_svg_arcEndAngle, padAngle = d3_svg_arcPadAngle;

-     function arc() {

-       var r0 = Math.max(0, +innerRadius.apply(this, arguments)), r1 = Math.max(0, +outerRadius.apply(this, arguments)), a0 = startAngle.apply(this, arguments) - halfπ, a1 = endAngle.apply(this, arguments) - halfπ, da = Math.abs(a1 - a0), cw = a0 > a1 ? 0 : 1;

-       if (r1 < r0) rc = r1, r1 = r0, r0 = rc;

-       if (da >= τε) return circleSegment(r1, cw) + (r0 ? circleSegment(r0, 1 - cw) : "") + "Z";

-       var rc, cr, rp, ap, p0 = 0, p1 = 0, x0, y0, x1, y1, x2, y2, x3, y3, path = [];

-       if (ap = (+padAngle.apply(this, arguments) || 0) / 2) {

-         rp = padRadius === d3_svg_arcAuto ? Math.sqrt(r0 * r0 + r1 * r1) : +padRadius.apply(this, arguments);

-         if (!cw) p1 *= -1;

-         if (r1) p1 = d3_asin(rp / r1 * Math.sin(ap));

-         if (r0) p0 = d3_asin(rp / r0 * Math.sin(ap));

-       }

-       if (r1) {

-         x0 = r1 * Math.cos(a0 + p1);

-         y0 = r1 * Math.sin(a0 + p1);

-         x1 = r1 * Math.cos(a1 - p1);

-         y1 = r1 * Math.sin(a1 - p1);

-         var l1 = Math.abs(a1 - a0 - 2 * p1) <= π ? 0 : 1;

-         if (p1 && d3_svg_arcSweep(x0, y0, x1, y1) === cw ^ l1) {

-           var h1 = (a0 + a1) / 2;

-           x0 = r1 * Math.cos(h1);

-           y0 = r1 * Math.sin(h1);

-           x1 = y1 = null;

-         }

-       } else {

-         x0 = y0 = 0;

-       }

-       if (r0) {

-         x2 = r0 * Math.cos(a1 - p0);

-         y2 = r0 * Math.sin(a1 - p0);

-         x3 = r0 * Math.cos(a0 + p0);

-         y3 = r0 * Math.sin(a0 + p0);

-         var l0 = Math.abs(a0 - a1 + 2 * p0) <= π ? 0 : 1;

-         if (p0 && d3_svg_arcSweep(x2, y2, x3, y3) === 1 - cw ^ l0) {

-           var h0 = (a0 + a1) / 2;

-           x2 = r0 * Math.cos(h0);

-           y2 = r0 * Math.sin(h0);

-           x3 = y3 = null;

-         }

-       } else {

-         x2 = y2 = 0;

-       }

-       if (da > ε && (rc = Math.min(Math.abs(r1 - r0) / 2, +cornerRadius.apply(this, arguments))) > .001) {

-         cr = r0 < r1 ^ cw ? 0 : 1;

-         var rc1 = rc, rc0 = rc;

-         if (da < π) {

-           var oc = x3 == null ? [ x2, y2 ] : x1 == null ? [ x0, y0 ] : d3_geom_polygonIntersect([ x0, y0 ], [ x3, y3 ], [ x1, y1 ], [ x2, y2 ]), ax = x0 - oc[0], ay = y0 - oc[1], bx = x1 - oc[0], by = y1 - oc[1], kc = 1 / Math.sin(Math.acos((ax * bx + ay * by) / (Math.sqrt(ax * ax + ay * ay) * Math.sqrt(bx * bx + by * by))) / 2), lc = Math.sqrt(oc[0] * oc[0] + oc[1] * oc[1]);

-           rc0 = Math.min(rc, (r0 - lc) / (kc - 1));

-           rc1 = Math.min(rc, (r1 - lc) / (kc + 1));

-         }

-         if (x1 != null) {

-           var t30 = d3_svg_arcCornerTangents(x3 == null ? [ x2, y2 ] : [ x3, y3 ], [ x0, y0 ], r1, rc1, cw), t12 = d3_svg_arcCornerTangents([ x1, y1 ], [ x2, y2 ], r1, rc1, cw);

-           if (rc === rc1) {

-             path.push("M", t30[0], "A", rc1, ",", rc1, " 0 0,", cr, " ", t30[1], "A", r1, ",", r1, " 0 ", 1 - cw ^ d3_svg_arcSweep(t30[1][0], t30[1][1], t12[1][0], t12[1][1]), ",", cw, " ", t12[1], "A", rc1, ",", rc1, " 0 0,", cr, " ", t12[0]);

-           } else {

-             path.push("M", t30[0], "A", rc1, ",", rc1, " 0 1,", cr, " ", t12[0]);

-           }

-         } else {

-           path.push("M", x0, ",", y0);

-         }

-         if (x3 != null) {

-           var t03 = d3_svg_arcCornerTangents([ x0, y0 ], [ x3, y3 ], r0, -rc0, cw), t21 = d3_svg_arcCornerTangents([ x2, y2 ], x1 == null ? [ x0, y0 ] : [ x1, y1 ], r0, -rc0, cw);

-           if (rc === rc0) {

-             path.push("L", t21[0], "A", rc0, ",", rc0, " 0 0,", cr, " ", t21[1], "A", r0, ",", r0, " 0 ", cw ^ d3_svg_arcSweep(t21[1][0], t21[1][1], t03[1][0], t03[1][1]), ",", 1 - cw, " ", t03[1], "A", rc0, ",", rc0, " 0 0,", cr, " ", t03[0]);

-           } else {

-             path.push("L", t21[0], "A", rc0, ",", rc0, " 0 0,", cr, " ", t03[0]);

-           }

-         } else {

-           path.push("L", x2, ",", y2);

-         }

-       } else {

-         path.push("M", x0, ",", y0);

-         if (x1 != null) path.push("A", r1, ",", r1, " 0 ", l1, ",", cw, " ", x1, ",", y1);

-         path.push("L", x2, ",", y2);

-         if (x3 != null) path.push("A", r0, ",", r0, " 0 ", l0, ",", 1 - cw, " ", x3, ",", y3);

-       }

-       path.push("Z");

-       return path.join("");

-     }

-     function circleSegment(r1, cw) {

-       return "M0," + r1 + "A" + r1 + "," + r1 + " 0 1," + cw + " 0," + -r1 + "A" + r1 + "," + r1 + " 0 1," + cw + " 0," + r1;

-     }

-     arc.innerRadius = function(v) {

-       if (!arguments.length) return innerRadius;

-       innerRadius = d3_functor(v);

-       return arc;

-     };

-     arc.outerRadius = function(v) {

-       if (!arguments.length) return outerRadius;

-       outerRadius = d3_functor(v);

-       return arc;

-     };

-     arc.cornerRadius = function(v) {

-       if (!arguments.length) return cornerRadius;

-       cornerRadius = d3_functor(v);

-       return arc;

-     };

-     arc.padRadius = function(v) {

-       if (!arguments.length) return padRadius;

-       padRadius = v == d3_svg_arcAuto ? d3_svg_arcAuto : d3_functor(v);

-       return arc;

-     };

-     arc.startAngle = function(v) {

-       if (!arguments.length) return startAngle;

-       startAngle = d3_functor(v);

-       return arc;

-     };

-     arc.endAngle = function(v) {

-       if (!arguments.length) return endAngle;

-       endAngle = d3_functor(v);

-       return arc;

-     };

-     arc.padAngle = function(v) {

-       if (!arguments.length) return padAngle;

-       padAngle = d3_functor(v);

-       return arc;

-     };

-     arc.centroid = function() {

-       var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2, a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - halfπ;

-       return [ Math.cos(a) * r, Math.sin(a) * r ];

-     };

-     return arc;

-   };

-   var d3_svg_arcAuto = "auto";

-   function d3_svg_arcInnerRadius(d) {

-     return d.innerRadius;

-   }

-   function d3_svg_arcOuterRadius(d) {

-     return d.outerRadius;

-   }

-   function d3_svg_arcStartAngle(d) {

-     return d.startAngle;

-   }

-   function d3_svg_arcEndAngle(d) {

-     return d.endAngle;

-   }

-   function d3_svg_arcPadAngle(d) {

-     return d && d.padAngle;

-   }

-   function d3_svg_arcSweep(x0, y0, x1, y1) {

-     return (x0 - x1) * y0 - (y0 - y1) * x0 > 0 ? 0 : 1;

-   }

-   function d3_svg_arcCornerTangents(p0, p1, r1, rc, cw) {

-     var x01 = p0[0] - p1[0], y01 = p0[1] - p1[1], lo = (cw ? rc : -rc) / Math.sqrt(x01 * x01 + y01 * y01), ox = lo * y01, oy = -lo * x01, x1 = p0[0] + ox, y1 = p0[1] + oy, x2 = p1[0] + ox, y2 = p1[1] + oy, x3 = (x1 + x2) / 2, y3 = (y1 + y2) / 2, dx = x2 - x1, dy = y2 - y1, d2 = dx * dx + dy * dy, r = r1 - rc, D = x1 * y2 - x2 * y1, d = (dy < 0 ? -1 : 1) * Math.sqrt(Math.max(0, r * r * d2 - D * D)), cx0 = (D * dy - dx * d) / d2, cy0 = (-D * dx - dy * d) / d2, cx1 = (D * dy + dx * d) / d2, cy1 = (-D * dx + dy * d) / d2, dx0 = cx0 - x3, dy0 = cy0 - y3, dx1 = cx1 - x3, dy1 = cy1 - y3;

-     if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1) cx0 = cx1, cy0 = cy1;

-     return [ [ cx0 - ox, cy0 - oy ], [ cx0 * r1 / r, cy0 * r1 / r ] ];

-   }

-   function d3_svg_line(projection) {

-     var x = d3_geom_pointX, y = d3_geom_pointY, defined = d3_true, interpolate = d3_svg_lineLinear, interpolateKey = interpolate.key, tension = .7;

-     function line(data) {

-       var segments = [], points = [], i = -1, n = data.length, d, fx = d3_functor(x), fy = d3_functor(y);

-       function segment() {

-         segments.push("M", interpolate(projection(points), tension));

-       }

-       while (++i < n) {

-         if (defined.call(this, d = data[i], i)) {

-           points.push([ +fx.call(this, d, i), +fy.call(this, d, i) ]);

-         } else if (points.length) {

-           segment();

-           points = [];

-         }

-       }

-       if (points.length) segment();

-       return segments.length ? segments.join("") : null;

-     }

-     line.x = function(_) {

-       if (!arguments.length) return x;

-       x = _;

-       return line;

-     };

-     line.y = function(_) {

-       if (!arguments.length) return y;

-       y = _;

-       return line;

-     };

-     line.defined = function(_) {

-       if (!arguments.length) return defined;

-       defined = _;

-       return line;

-     };

-     line.interpolate = function(_) {

-       if (!arguments.length) return interpolateKey;

-       if (typeof _ === "function") interpolateKey = interpolate = _; else interpolateKey = (interpolate = d3_svg_lineInterpolators.get(_) || d3_svg_lineLinear).key;

-       return line;

-     };

-     line.tension = function(_) {

-       if (!arguments.length) return tension;

-       tension = _;

-       return line;

-     };

-     return line;

-   }

-   d3.svg.line = function() {

-     return d3_svg_line(d3_identity);

-   };

-   var d3_svg_lineInterpolators = d3.map({

-     linear: d3_svg_lineLinear,

-     "linear-closed": d3_svg_lineLinearClosed,

-     step: d3_svg_lineStep,

-     "step-before": d3_svg_lineStepBefore,

-     "step-after": d3_svg_lineStepAfter,

-     basis: d3_svg_lineBasis,

-     "basis-open": d3_svg_lineBasisOpen,

-     "basis-closed": d3_svg_lineBasisClosed,

-     bundle: d3_svg_lineBundle,

-     cardinal: d3_svg_lineCardinal,

-     "cardinal-open": d3_svg_lineCardinalOpen,

-     "cardinal-closed": d3_svg_lineCardinalClosed,

-     monotone: d3_svg_lineMonotone

-   });

-   d3_svg_lineInterpolators.forEach(function(key, value) {

-     value.key = key;

-     value.closed = /-closed$/.test(key);

-   });

-   function d3_svg_lineLinear(points) {

-     return points.length > 1 ? points.join("L") : points + "Z";

-   }

-   function d3_svg_lineLinearClosed(points) {

-     return points.join("L") + "Z";

-   }

-   function d3_svg_lineStep(points) {

-     var i = 0, n = points.length, p = points[0], path = [ p[0], ",", p[1] ];

-     while (++i < n) path.push("H", (p[0] + (p = points[i])[0]) / 2, "V", p[1]);

-     if (n > 1) path.push("H", p[0]);

-     return path.join("");

-   }

-   function d3_svg_lineStepBefore(points) {

-     var i = 0, n = points.length, p = points[0], path = [ p[0], ",", p[1] ];

-     while (++i < n) path.push("V", (p = points[i])[1], "H", p[0]);

-     return path.join("");

-   }

-   function d3_svg_lineStepAfter(points) {

-     var i = 0, n = points.length, p = points[0], path = [ p[0], ",", p[1] ];

-     while (++i < n) path.push("H", (p = points[i])[0], "V", p[1]);

-     return path.join("");

-   }

-   function d3_svg_lineCardinalOpen(points, tension) {

-     return points.length < 4 ? d3_svg_lineLinear(points) : points[1] + d3_svg_lineHermite(points.slice(1, -1), d3_svg_lineCardinalTangents(points, tension));

-   }

-   function d3_svg_lineCardinalClosed(points, tension) {

-     return points.length < 3 ? d3_svg_lineLinearClosed(points) : points[0] + d3_svg_lineHermite((points.push(points[0]),

-     points), d3_svg_lineCardinalTangents([ points[points.length - 2] ].concat(points, [ points[1] ]), tension));

-   }

-   function d3_svg_lineCardinal(points, tension) {

-     return points.length < 3 ? d3_svg_lineLinear(points) : points[0] + d3_svg_lineHermite(points, d3_svg_lineCardinalTangents(points, tension));

-   }

-   function d3_svg_lineHermite(points, tangents) {

-     if (tangents.length < 1 || points.length != tangents.length && points.length != tangents.length + 2) {

-       return d3_svg_lineLinear(points);

-     }

-     var quad = points.length != tangents.length, path = "", p0 = points[0], p = points[1], t0 = tangents[0], t = t0, pi = 1;

-     if (quad) {

-       path += "Q" + (p[0] - t0[0] * 2 / 3) + "," + (p[1] - t0[1] * 2 / 3) + "," + p[0] + "," + p[1];

-       p0 = points[1];

-       pi = 2;

-     }

-     if (tangents.length > 1) {

-       t = tangents[1];

-       p = points[pi];

-       pi++;

-       path += "C" + (p0[0] + t0[0]) + "," + (p0[1] + t0[1]) + "," + (p[0] - t[0]) + "," + (p[1] - t[1]) + "," + p[0] + "," + p[1];

-       for (var i = 2; i < tangents.length; i++, pi++) {

-         p = points[pi];

-         t = tangents[i];

-         path += "S" + (p[0] - t[0]) + "," + (p[1] - t[1]) + "," + p[0] + "," + p[1];

-       }

-     }

-     if (quad) {

-       var lp = points[pi];

-       path += "Q" + (p[0] + t[0] * 2 / 3) + "," + (p[1] + t[1] * 2 / 3) + "," + lp[0] + "," + lp[1];

-     }

-     return path;

-   }

-   function d3_svg_lineCardinalTangents(points, tension) {

-     var tangents = [], a = (1 - tension) / 2, p0, p1 = points[0], p2 = points[1], i = 1, n = points.length;

-     while (++i < n) {

-       p0 = p1;

-       p1 = p2;

-       p2 = points[i];

-       tangents.push([ a * (p2[0] - p0[0]), a * (p2[1] - p0[1]) ]);

-     }

-     return tangents;

-   }

-   function d3_svg_lineBasis(points) {

-     if (points.length < 3) return d3_svg_lineLinear(points);

-     var i = 1, n = points.length, pi = points[0], x0 = pi[0], y0 = pi[1], px = [ x0, x0, x0, (pi = points[1])[0] ], py = [ y0, y0, y0, pi[1] ], path = [ x0, ",", y0, "L", d3_svg_lineDot4(d3_svg_lineBasisBezier3, px), ",", d3_svg_lineDot4(d3_svg_lineBasisBezier3, py) ];

-     points.push(points[n - 1]);

-     while (++i <= n) {

-       pi = points[i];

-       px.shift();

-       px.push(pi[0]);

-       py.shift();

-       py.push(pi[1]);

-       d3_svg_lineBasisBezier(path, px, py);

-     }

-     points.pop();

-     path.push("L", pi);

-     return path.join("");

-   }

-   function d3_svg_lineBasisOpen(points) {

-     if (points.length < 4) return d3_svg_lineLinear(points);

-     var path = [], i = -1, n = points.length, pi, px = [ 0 ], py = [ 0 ];

-     while (++i < 3) {

-       pi = points[i];

-       px.push(pi[0]);

-       py.push(pi[1]);

-     }

-     path.push(d3_svg_lineDot4(d3_svg_lineBasisBezier3, px) + "," + d3_svg_lineDot4(d3_svg_lineBasisBezier3, py));

-     --i;

-     while (++i < n) {

-       pi = points[i];

-       px.shift();

-       px.push(pi[0]);

-       py.shift();

-       py.push(pi[1]);

-       d3_svg_lineBasisBezier(path, px, py);

-     }

-     return path.join("");

-   }

-   function d3_svg_lineBasisClosed(points) {

-     var path, i = -1, n = points.length, m = n + 4, pi, px = [], py = [];

-     while (++i < 4) {

-       pi = points[i % n];

-       px.push(pi[0]);

-       py.push(pi[1]);

-     }

-     path = [ d3_svg_lineDot4(d3_svg_lineBasisBezier3, px), ",", d3_svg_lineDot4(d3_svg_lineBasisBezier3, py) ];

-     --i;

-     while (++i < m) {

-       pi = points[i % n];

-       px.shift();

-       px.push(pi[0]);

-       py.shift();

-       py.push(pi[1]);

-       d3_svg_lineBasisBezier(path, px, py);

-     }

-     return path.join("");

-   }

-   function d3_svg_lineBundle(points, tension) {

-     var n = points.length - 1;

-     if (n) {

-       var x0 = points[0][0], y0 = points[0][1], dx = points[n][0] - x0, dy = points[n][1] - y0, i = -1, p, t;

-       while (++i <= n) {

-         p = points[i];

-         t = i / n;

-         p[0] = tension * p[0] + (1 - tension) * (x0 + t * dx);

-         p[1] = tension * p[1] + (1 - tension) * (y0 + t * dy);

-       }

-     }

-     return d3_svg_lineBasis(points);

-   }

-   function d3_svg_lineDot4(a, b) {

-     return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];

-   }

-   var d3_svg_lineBasisBezier1 = [ 0, 2 / 3, 1 / 3, 0 ], d3_svg_lineBasisBezier2 = [ 0, 1 / 3, 2 / 3, 0 ], d3_svg_lineBasisBezier3 = [ 0, 1 / 6, 2 / 3, 1 / 6 ];

-   function d3_svg_lineBasisBezier(path, x, y) {

-     path.push("C", d3_svg_lineDot4(d3_svg_lineBasisBezier1, x), ",", d3_svg_lineDot4(d3_svg_lineBasisBezier1, y), ",", d3_svg_lineDot4(d3_svg_lineBasisBezier2, x), ",", d3_svg_lineDot4(d3_svg_lineBasisBezier2, y), ",", d3_svg_lineDot4(d3_svg_lineBasisBezier3, x), ",", d3_svg_lineDot4(d3_svg_lineBasisBezier3, y));

-   }

-   function d3_svg_lineSlope(p0, p1) {

-     return (p1[1] - p0[1]) / (p1[0] - p0[0]);

-   }

-   function d3_svg_lineFiniteDifferences(points) {

-     var i = 0, j = points.length - 1, m = [], p0 = points[0], p1 = points[1], d = m[0] = d3_svg_lineSlope(p0, p1);

-     while (++i < j) {

-       m[i] = (d + (d = d3_svg_lineSlope(p0 = p1, p1 = points[i + 1]))) / 2;

-     }

-     m[i] = d;

-     return m;

-   }

-   function d3_svg_lineMonotoneTangents(points) {

-     var tangents = [], d, a, b, s, m = d3_svg_lineFiniteDifferences(points), i = -1, j = points.length - 1;

-     while (++i < j) {

-       d = d3_svg_lineSlope(points[i], points[i + 1]);

-       if (abs(d) < ε) {

-         m[i] = m[i + 1] = 0;

-       } else {

-         a = m[i] / d;

-         b = m[i + 1] / d;

-         s = a * a + b * b;

-         if (s > 9) {

-           s = d * 3 / Math.sqrt(s);

-           m[i] = s * a;

-           m[i + 1] = s * b;

-         }

-       }

-     }

-     i = -1;

-     while (++i <= j) {

-       s = (points[Math.min(j, i + 1)][0] - points[Math.max(0, i - 1)][0]) / (6 * (1 + m[i] * m[i]));

-       tangents.push([ s || 0, m[i] * s || 0 ]);

-     }

-     return tangents;

-   }

-   function d3_svg_lineMonotone(points) {

-     return points.length < 3 ? d3_svg_lineLinear(points) : points[0] + d3_svg_lineHermite(points, d3_svg_lineMonotoneTangents(points));

-   }

-   d3.svg.line.radial = function() {

-     var line = d3_svg_line(d3_svg_lineRadial);

-     line.radius = line.x, delete line.x;

-     line.angle = line.y, delete line.y;

-     return line;

-   };

-   function d3_svg_lineRadial(points) {

-     var point, i = -1, n = points.length, r, a;

-     while (++i < n) {

-       point = points[i];

-       r = point[0];

-       a = point[1] - halfπ;

-       point[0] = r * Math.cos(a);

-       point[1] = r * Math.sin(a);

-     }

-     return points;

-   }

-   function d3_svg_area(projection) {

-     var x0 = d3_geom_pointX, x1 = d3_geom_pointX, y0 = 0, y1 = d3_geom_pointY, defined = d3_true, interpolate = d3_svg_lineLinear, interpolateKey = interpolate.key, interpolateReverse = interpolate, L = "L", tension = .7;

-     function area(data) {

-       var segments = [], points0 = [], points1 = [], i = -1, n = data.length, d, fx0 = d3_functor(x0), fy0 = d3_functor(y0), fx1 = x0 === x1 ? function() {

-         return x;

-       } : d3_functor(x1), fy1 = y0 === y1 ? function() {

-         return y;

-       } : d3_functor(y1), x, y;

-       function segment() {

-         segments.push("M", interpolate(projection(points1), tension), L, interpolateReverse(projection(points0.reverse()), tension), "Z");

-       }

-       while (++i < n) {

-         if (defined.call(this, d = data[i], i)) {

-           points0.push([ x = +fx0.call(this, d, i), y = +fy0.call(this, d, i) ]);

-           points1.push([ +fx1.call(this, d, i), +fy1.call(this, d, i) ]);

-         } else if (points0.length) {

-           segment();

-           points0 = [];

-           points1 = [];

-         }

-       }

-       if (points0.length) segment();

-       return segments.length ? segments.join("") : null;

-     }

-     area.x = function(_) {

-       if (!arguments.length) return x1;

-       x0 = x1 = _;

-       return area;

-     };

-     area.x0 = function(_) {

-       if (!arguments.length) return x0;

-       x0 = _;

-       return area;

-     };

-     area.x1 = function(_) {

-       if (!arguments.length) return x1;

-       x1 = _;

-       return area;

-     };

-     area.y = function(_) {

-       if (!arguments.length) return y1;

-       y0 = y1 = _;

-       return area;

-     };

-     area.y0 = function(_) {

-       if (!arguments.length) return y0;

-       y0 = _;

-       return area;

-     };

-     area.y1 = function(_) {

-       if (!arguments.length) return y1;

-       y1 = _;

-       return area;

-     };

-     area.defined = function(_) {

-       if (!arguments.length) return defined;

-       defined = _;

-       return area;

-     };

-     area.interpolate = function(_) {

-       if (!arguments.length) return interpolateKey;

-       if (typeof _ === "function") interpolateKey = interpolate = _; else interpolateKey = (interpolate = d3_svg_lineInterpolators.get(_) || d3_svg_lineLinear).key;

-       interpolateReverse = interpolate.reverse || interpolate;

-       L = interpolate.closed ? "M" : "L";

-       return area;

-     };

-     area.tension = function(_) {

-       if (!arguments.length) return tension;

-       tension = _;

-       return area;

-     };

-     return area;

-   }

-   d3_svg_lineStepBefore.reverse = d3_svg_lineStepAfter;

-   d3_svg_lineStepAfter.reverse = d3_svg_lineStepBefore;

-   d3.svg.area = function() {

-     return d3_svg_area(d3_identity);

-   };

-   d3.svg.area.radial = function() {

-     var area = d3_svg_area(d3_svg_lineRadial);

-     area.radius = area.x, delete area.x;

-     area.innerRadius = area.x0, delete area.x0;

-     area.outerRadius = area.x1, delete area.x1;

-     area.angle = area.y, delete area.y;

-     area.startAngle = area.y0, delete area.y0;

-     area.endAngle = area.y1, delete area.y1;

-     return area;

-   };

-   d3.svg.chord = function() {

-     var source = d3_source, target = d3_target, radius = d3_svg_chordRadius, startAngle = d3_svg_arcStartAngle, endAngle = d3_svg_arcEndAngle;

-     function chord(d, i) {

-       var s = subgroup(this, source, d, i), t = subgroup(this, target, d, i);

-       return "M" + s.p0 + arc(s.r, s.p1, s.a1 - s.a0) + (equals(s, t) ? curve(s.r, s.p1, s.r, s.p0) : curve(s.r, s.p1, t.r, t.p0) + arc(t.r, t.p1, t.a1 - t.a0) + curve(t.r, t.p1, s.r, s.p0)) + "Z";

-     }

-     function subgroup(self, f, d, i) {

-       var subgroup = f.call(self, d, i), r = radius.call(self, subgroup, i), a0 = startAngle.call(self, subgroup, i) - halfπ, a1 = endAngle.call(self, subgroup, i) - halfπ;

-       return {

-         r: r,

-         a0: a0,

-         a1: a1,

-         p0: [ r * Math.cos(a0), r * Math.sin(a0) ],

-         p1: [ r * Math.cos(a1), r * Math.sin(a1) ]

-       };

-     }

-     function equals(a, b) {

-       return a.a0 == b.a0 && a.a1 == b.a1;

-     }

-     function arc(r, p, a) {

-       return "A" + r + "," + r + " 0 " + +(a > π) + ",1 " + p;

-     }

-     function curve(r0, p0, r1, p1) {

-       return "Q 0,0 " + p1;

-     }

-     chord.radius = function(v) {

-       if (!arguments.length) return radius;

-       radius = d3_functor(v);

-       return chord;

-     };

-     chord.source = function(v) {

-       if (!arguments.length) return source;

-       source = d3_functor(v);

-       return chord;

-     };

-     chord.target = function(v) {

-       if (!arguments.length) return target;

-       target = d3_functor(v);

-       return chord;

-     };

-     chord.startAngle = function(v) {

-       if (!arguments.length) return startAngle;

-       startAngle = d3_functor(v);

-       return chord;

-     };

-     chord.endAngle = function(v) {

-       if (!arguments.length) return endAngle;

-       endAngle = d3_functor(v);

-       return chord;

-     };

-     return chord;

-   };

-   function d3_svg_chordRadius(d) {

-     return d.radius;

-   }

-   d3.svg.diagonal = function() {

-     var source = d3_source, target = d3_target, projection = d3_svg_diagonalProjection;

-     function diagonal(d, i) {

-       var p0 = source.call(this, d, i), p3 = target.call(this, d, i), m = (p0.y + p3.y) / 2, p = [ p0, {

-         x: p0.x,

-         y: m

-       }, {

-         x: p3.x,

-         y: m

-       }, p3 ];

-       p = p.map(projection);

-       return "M" + p[0] + "C" + p[1] + " " + p[2] + " " + p[3];

-     }

-     diagonal.source = function(x) {

-       if (!arguments.length) return source;

-       source = d3_functor(x);

-       return diagonal;

-     };

-     diagonal.target = function(x) {

-       if (!arguments.length) return target;

-       target = d3_functor(x);

-       return diagonal;

-     };

-     diagonal.projection = function(x) {

-       if (!arguments.length) return projection;

-       projection = x;

-       return diagonal;

-     };

-     return diagonal;

-   };

-   function d3_svg_diagonalProjection(d) {

-     return [ d.x, d.y ];

-   }

-   d3.svg.diagonal.radial = function() {

-     var diagonal = d3.svg.diagonal(), projection = d3_svg_diagonalProjection, projection_ = diagonal.projection;

-     diagonal.projection = function(x) {

-       return arguments.length ? projection_(d3_svg_diagonalRadialProjection(projection = x)) : projection;

-     };

-     return diagonal;

-   };

-   function d3_svg_diagonalRadialProjection(projection) {

-     return function() {

-       var d = projection.apply(this, arguments), r = d[0], a = d[1] - halfπ;

-       return [ r * Math.cos(a), r * Math.sin(a) ];

-     };

-   }

-   d3.svg.symbol = function() {

-     var type = d3_svg_symbolType, size = d3_svg_symbolSize;

-     function symbol(d, i) {

-       return (d3_svg_symbols.get(type.call(this, d, i)) || d3_svg_symbolCircle)(size.call(this, d, i));

-     }

-     symbol.type = function(x) {

-       if (!arguments.length) return type;

-       type = d3_functor(x);

-       return symbol;

-     };

-     symbol.size = function(x) {

-       if (!arguments.length) return size;

-       size = d3_functor(x);

-       return symbol;

-     };

-     return symbol;

-   };

-   function d3_svg_symbolSize() {

-     return 64;

-   }

-   function d3_svg_symbolType() {

-     return "circle";

-   }

-   function d3_svg_symbolCircle(size) {

-     var r = Math.sqrt(size / π);

-     return "M0," + r + "A" + r + "," + r + " 0 1,1 0," + -r + "A" + r + "," + r + " 0 1,1 0," + r + "Z";

-   }

-   var d3_svg_symbols = d3.map({

-     circle: d3_svg_symbolCircle,

-     cross: function(size) {

-       var r = Math.sqrt(size / 5) / 2;

-       return "M" + -3 * r + "," + -r + "H" + -r + "V" + -3 * r + "H" + r + "V" + -r + "H" + 3 * r + "V" + r + "H" + r + "V" + 3 * r + "H" + -r + "V" + r + "H" + -3 * r + "Z";

-     },

-     diamond: function(size) {

-       var ry = Math.sqrt(size / (2 * d3_svg_symbolTan30)), rx = ry * d3_svg_symbolTan30;

-       return "M0," + -ry + "L" + rx + ",0" + " 0," + ry + " " + -rx + ",0" + "Z";

-     },

-     square: function(size) {

-       var r = Math.sqrt(size) / 2;

-       return "M" + -r + "," + -r + "L" + r + "," + -r + " " + r + "," + r + " " + -r + "," + r + "Z";

-     },

-     "triangle-down": function(size) {

-       var rx = Math.sqrt(size / d3_svg_symbolSqrt3), ry = rx * d3_svg_symbolSqrt3 / 2;

-       return "M0," + ry + "L" + rx + "," + -ry + " " + -rx + "," + -ry + "Z";

-     },

-     "triangle-up": function(size) {

-       var rx = Math.sqrt(size / d3_svg_symbolSqrt3), ry = rx * d3_svg_symbolSqrt3 / 2;

-       return "M0," + -ry + "L" + rx + "," + ry + " " + -rx + "," + ry + "Z";

-     }

-   });

-   d3.svg.symbolTypes = d3_svg_symbols.keys();

-   var d3_svg_symbolSqrt3 = Math.sqrt(3), d3_svg_symbolTan30 = Math.tan(30 * d3_radians);

-   d3_selectionPrototype.transition = function(name) {

-     var id = d3_transitionInheritId || ++d3_transitionId, ns = d3_transitionNamespace(name), subgroups = [], subgroup, node, transition = d3_transitionInherit || {

-       time: Date.now(),

-       ease: d3_ease_cubicInOut,

-       delay: 0,

-       duration: 250

-     };

-     for (var j = -1, m = this.length; ++j < m; ) {

-       subgroups.push(subgroup = []);

-       for (var group = this[j], i = -1, n = group.length; ++i < n; ) {

-         if (node = group[i]) d3_transitionNode(node, i, ns, id, transition);

-         subgroup.push(node);

-       }

-     }

-     return d3_transition(subgroups, ns, id);

-   };

-   d3_selectionPrototype.interrupt = function(name) {

-     return this.each(name == null ? d3_selection_interrupt : d3_selection_interruptNS(d3_transitionNamespace(name)));

-   };

-   var d3_selection_interrupt = d3_selection_interruptNS(d3_transitionNamespace());

-   function d3_selection_interruptNS(ns) {

-     return function() {

-       var lock, activeId, active;

-       if ((lock = this[ns]) && (active = lock[activeId = lock.active])) {

-         active.timer.c = null;

-         active.timer.t = NaN;

-         if (--lock.count) delete lock[activeId]; else delete this[ns];

-         lock.active += .5;

-         active.event && active.event.interrupt.call(this, this.__data__, active.index);

-       }

-     };

-   }

-   function d3_transition(groups, ns, id) {

-     d3_subclass(groups, d3_transitionPrototype);

-     groups.namespace = ns;

-     groups.id = id;

-     return groups;

-   }

-   var d3_transitionPrototype = [], d3_transitionId = 0, d3_transitionInheritId, d3_transitionInherit;

-   d3_transitionPrototype.call = d3_selectionPrototype.call;

-   d3_transitionPrototype.empty = d3_selectionPrototype.empty;

-   d3_transitionPrototype.node = d3_selectionPrototype.node;

-   d3_transitionPrototype.size = d3_selectionPrototype.size;

-   d3.transition = function(selection, name) {

-     return selection && selection.transition ? d3_transitionInheritId ? selection.transition(name) : selection : d3.selection().transition(selection);

-   };

-   d3.transition.prototype = d3_transitionPrototype;

-   d3_transitionPrototype.select = function(selector) {

-     var id = this.id, ns = this.namespace, subgroups = [], subgroup, subnode, node;

-     selector = d3_selection_selector(selector);

-     for (var j = -1, m = this.length; ++j < m; ) {

-       subgroups.push(subgroup = []);

-       for (var group = this[j], i = -1, n = group.length; ++i < n; ) {

-         if ((node = group[i]) && (subnode = selector.call(node, node.__data__, i, j))) {

-           if ("__data__" in node) subnode.__data__ = node.__data__;

-           d3_transitionNode(subnode, i, ns, id, node[ns][id]);

-           subgroup.push(subnode);

-         } else {

-           subgroup.push(null);

-         }

-       }

-     }

-     return d3_transition(subgroups, ns, id);

-   };

-   d3_transitionPrototype.selectAll = function(selector) {

-     var id = this.id, ns = this.namespace, subgroups = [], subgroup, subnodes, node, subnode, transition;

-     selector = d3_selection_selectorAll(selector);

-     for (var j = -1, m = this.length; ++j < m; ) {

-       for (var group = this[j], i = -1, n = group.length; ++i < n; ) {

-         if (node = group[i]) {

-           transition = node[ns][id];

-           subnodes = selector.call(node, node.__data__, i, j);

-           subgroups.push(subgroup = []);

-           for (var k = -1, o = subnodes.length; ++k < o; ) {

-             if (subnode = subnodes[k]) d3_transitionNode(subnode, k, ns, id, transition);

-             subgroup.push(subnode);

-           }

-         }

-       }

-     }

-     return d3_transition(subgroups, ns, id);

-   };

-   d3_transitionPrototype.filter = function(filter) {

-     var subgroups = [], subgroup, group, node;

-     if (typeof filter !== "function") filter = d3_selection_filter(filter);

-     for (var j = 0, m = this.length; j < m; j++) {

-       subgroups.push(subgroup = []);

-       for (var group = this[j], i = 0, n = group.length; i < n; i++) {

-         if ((node = group[i]) && filter.call(node, node.__data__, i, j)) {

-           subgroup.push(node);

-         }

-       }

-     }

-     return d3_transition(subgroups, this.namespace, this.id);

-   };

-   d3_transitionPrototype.tween = function(name, tween) {

-     var id = this.id, ns = this.namespace;

-     if (arguments.length < 2) return this.node()[ns][id].tween.get(name);

-     return d3_selection_each(this, tween == null ? function(node) {

-       node[ns][id].tween.remove(name);

-     } : function(node) {

-       node[ns][id].tween.set(name, tween);

-     });

-   };

-   function d3_transition_tween(groups, name, value, tween) {

-     var id = groups.id, ns = groups.namespace;

-     return d3_selection_each(groups, typeof value === "function" ? function(node, i, j) {

-       node[ns][id].tween.set(name, tween(value.call(node, node.__data__, i, j)));

-     } : (value = tween(value), function(node) {

-       node[ns][id].tween.set(name, value);

-     }));

-   }

-   d3_transitionPrototype.attr = function(nameNS, value) {

-     if (arguments.length < 2) {

-       for (value in nameNS) this.attr(value, nameNS[value]);

-       return this;

-     }

-     var interpolate = nameNS == "transform" ? d3_interpolateTransform : d3_interpolate, name = d3.ns.qualify(nameNS);

-     function attrNull() {

-       this.removeAttribute(name);

-     }

-     function attrNullNS() {

-       this.removeAttributeNS(name.space, name.local);

-     }

-     function attrTween(b) {

-       return b == null ? attrNull : (b += "", function() {

-         var a = this.getAttribute(name), i;

-         return a !== b && (i = interpolate(a, b), function(t) {

-           this.setAttribute(name, i(t));

-         });

-       });

-     }

-     function attrTweenNS(b) {

-       return b == null ? attrNullNS : (b += "", function() {

-         var a = this.getAttributeNS(name.space, name.local), i;

-         return a !== b && (i = interpolate(a, b), function(t) {

-           this.setAttributeNS(name.space, name.local, i(t));

-         });

-       });

-     }

-     return d3_transition_tween(this, "attr." + nameNS, value, name.local ? attrTweenNS : attrTween);

-   };

-   d3_transitionPrototype.attrTween = function(nameNS, tween) {

-     var name = d3.ns.qualify(nameNS);

-     function attrTween(d, i) {

-       var f = tween.call(this, d, i, this.getAttribute(name));

-       return f && function(t) {

-         this.setAttribute(name, f(t));

-       };

-     }

-     function attrTweenNS(d, i) {

-       var f = tween.call(this, d, i, this.getAttributeNS(name.space, name.local));

-       return f && function(t) {

-         this.setAttributeNS(name.space, name.local, f(t));

-       };

-     }

-     return this.tween("attr." + nameNS, name.local ? attrTweenNS : attrTween);

-   };

-   d3_transitionPrototype.style = function(name, value, priority) {

-     var n = arguments.length;

-     if (n < 3) {

-       if (typeof name !== "string") {

-         if (n < 2) value = "";

-         for (priority in name) this.style(priority, name[priority], value);

-         return this;

-       }

-       priority = "";

-     }

-     function styleNull() {

-       this.style.removeProperty(name);

-     }

-     function styleString(b) {

-       return b == null ? styleNull : (b += "", function() {

-         var a = d3_window(this).getComputedStyle(this, null).getPropertyValue(name), i;

-         return a !== b && (i = d3_interpolate(a, b), function(t) {

-           this.style.setProperty(name, i(t), priority);

-         });

-       });

-     }

-     return d3_transition_tween(this, "style." + name, value, styleString);

-   };

-   d3_transitionPrototype.styleTween = function(name, tween, priority) {

-     if (arguments.length < 3) priority = "";

-     function styleTween(d, i) {

-       var f = tween.call(this, d, i, d3_window(this).getComputedStyle(this, null).getPropertyValue(name));

-       return f && function(t) {

-         this.style.setProperty(name, f(t), priority);

-       };

-     }

-     return this.tween("style." + name, styleTween);

-   };

-   d3_transitionPrototype.text = function(value) {

-     return d3_transition_tween(this, "text", value, d3_transition_text);

-   };

-   function d3_transition_text(b) {

-     if (b == null) b = "";

-     return function() {

-       this.textContent = b;

-     };

-   }

-   d3_transitionPrototype.remove = function() {

-     var ns = this.namespace;

-     return this.each("end.transition", function() {

-       var p;

-       if (this[ns].count < 2 && (p = this.parentNode)) p.removeChild(this);

-     });

-   };

-   d3_transitionPrototype.ease = function(value) {

-     var id = this.id, ns = this.namespace;

-     if (arguments.length < 1) return this.node()[ns][id].ease;

-     if (typeof value !== "function") value = d3.ease.apply(d3, arguments);

-     return d3_selection_each(this, function(node) {

-       node[ns][id].ease = value;

-     });

-   };

-   d3_transitionPrototype.delay = function(value) {

-     var id = this.id, ns = this.namespace;

-     if (arguments.length < 1) return this.node()[ns][id].delay;

-     return d3_selection_each(this, typeof value === "function" ? function(node, i, j) {

-       node[ns][id].delay = +value.call(node, node.__data__, i, j);

-     } : (value = +value, function(node) {

-       node[ns][id].delay = value;

-     }));

-   };

-   d3_transitionPrototype.duration = function(value) {

-     var id = this.id, ns = this.namespace;

-     if (arguments.length < 1) return this.node()[ns][id].duration;

-     return d3_selection_each(this, typeof value === "function" ? function(node, i, j) {

-       node[ns][id].duration = Math.max(1, value.call(node, node.__data__, i, j));

-     } : (value = Math.max(1, value), function(node) {

-       node[ns][id].duration = value;

-     }));

-   };

-   d3_transitionPrototype.each = function(type, listener) {

-     var id = this.id, ns = this.namespace;

-     if (arguments.length < 2) {

-       var inherit = d3_transitionInherit, inheritId = d3_transitionInheritId;

-       try {

-         d3_transitionInheritId = id;

-         d3_selection_each(this, function(node, i, j) {

-           d3_transitionInherit = node[ns][id];

-           type.call(node, node.__data__, i, j);

-         });

-       } finally {

-         d3_transitionInherit = inherit;

-         d3_transitionInheritId = inheritId;

-       }

-     } else {

-       d3_selection_each(this, function(node) {

-         var transition = node[ns][id];

-         (transition.event || (transition.event = d3.dispatch("start", "end", "interrupt"))).on(type, listener);

-       });

-     }

-     return this;

-   };

-   d3_transitionPrototype.transition = function() {

-     var id0 = this.id, id1 = ++d3_transitionId, ns = this.namespace, subgroups = [], subgroup, group, node, transition;

-     for (var j = 0, m = this.length; j < m; j++) {

-       subgroups.push(subgroup = []);

-       for (var group = this[j], i = 0, n = group.length; i < n; i++) {

-         if (node = group[i]) {

-           transition = node[ns][id0];

-           d3_transitionNode(node, i, ns, id1, {

-             time: transition.time,

-             ease: transition.ease,

-             delay: transition.delay + transition.duration,

-             duration: transition.duration

-           });

-         }

-         subgroup.push(node);

-       }

-     }

-     return d3_transition(subgroups, ns, id1);

-   };

-   function d3_transitionNamespace(name) {

-     return name == null ? "__transition__" : "__transition_" + name + "__";

-   }

-   function d3_transitionNode(node, i, ns, id, inherit) {

-     var lock = node[ns] || (node[ns] = {

-       active: 0,

-       count: 0

-     }), transition = lock[id], time, timer, duration, ease, tweens;

-     function schedule(elapsed) {

-       var delay = transition.delay;

-       timer.t = delay + time;

-       if (delay <= elapsed) return start(elapsed - delay);

-       timer.c = start;

-     }

-     function start(elapsed) {

-       var activeId = lock.active, active = lock[activeId];

-       if (active) {

-         active.timer.c = null;

-         active.timer.t = NaN;

-         --lock.count;

-         delete lock[activeId];

-         active.event && active.event.interrupt.call(node, node.__data__, active.index);

-       }

-       for (var cancelId in lock) {

-         if (+cancelId < id) {

-           var cancel = lock[cancelId];

-           cancel.timer.c = null;

-           cancel.timer.t = NaN;

-           --lock.count;

-           delete lock[cancelId];

-         }

-       }

-       timer.c = tick;

-       d3_timer(function() {

-         if (timer.c && tick(elapsed || 1)) {

-           timer.c = null;

-           timer.t = NaN;

-         }

-         return 1;

-       }, 0, time);

-       lock.active = id;

-       transition.event && transition.event.start.call(node, node.__data__, i);

-       tweens = [];

-       transition.tween.forEach(function(key, value) {

-         if (value = value.call(node, node.__data__, i)) {

-           tweens.push(value);

-         }

-       });

-       ease = transition.ease;

-       duration = transition.duration;

-     }

-     function tick(elapsed) {

-       var t = elapsed / duration, e = ease(t), n = tweens.length;

-       while (n > 0) {

-         tweens[--n].call(node, e);

-       }

-       if (t >= 1) {

-         transition.event && transition.event.end.call(node, node.__data__, i);

-         if (--lock.count) delete lock[id]; else delete node[ns];

-         return 1;

-       }

-     }

-     if (!transition) {

-       time = inherit.time;

-       timer = d3_timer(schedule, 0, time);

-       transition = lock[id] = {

-         tween: new d3_Map(),

-         time: time,

-         timer: timer,

-         delay: inherit.delay,

-         duration: inherit.duration,

-         ease: inherit.ease,

-         index: i

-       };

-       inherit = null;

-       ++lock.count;

-     }

-   }

-   d3.svg.axis = function() {

-     var scale = d3.scale.linear(), orient = d3_svg_axisDefaultOrient, innerTickSize = 6, outerTickSize = 6, tickPadding = 3, tickArguments_ = [ 10 ], tickValues = null, tickFormat_;

-     function axis(g) {

-       g.each(function() {

-         var g = d3.select(this);

-         var scale0 = this.__chart__ || scale, scale1 = this.__chart__ = scale.copy();

-         var ticks = tickValues == null ? scale1.ticks ? scale1.ticks.apply(scale1, tickArguments_) : scale1.domain() : tickValues, tickFormat = tickFormat_ == null ? scale1.tickFormat ? scale1.tickFormat.apply(scale1, tickArguments_) : d3_identity : tickFormat_, tick = g.selectAll(".tick").data(ticks, scale1), tickEnter = tick.enter().insert("g", ".domain").attr("class", "tick").style("opacity", ε), tickExit = d3.transition(tick.exit()).style("opacity", ε).remove(), tickUpdate = d3.transition(tick.order()).style("opacity", 1), tickSpacing = Math.max(innerTickSize, 0) + tickPadding, tickTransform;

-         var range = d3_scaleRange(scale1), path = g.selectAll(".domain").data([ 0 ]), pathUpdate = (path.enter().append("path").attr("class", "domain"),

-         d3.transition(path));

-         tickEnter.append("line");

-         tickEnter.append("text");

-         var lineEnter = tickEnter.select("line"), lineUpdate = tickUpdate.select("line"), text = tick.select("text").text(tickFormat), textEnter = tickEnter.select("text"), textUpdate = tickUpdate.select("text"), sign = orient === "top" || orient === "left" ? -1 : 1, x1, x2, y1, y2;

-         if (orient === "bottom" || orient === "top") {

-           tickTransform = d3_svg_axisX, x1 = "x", y1 = "y", x2 = "x2", y2 = "y2";

-           text.attr("dy", sign < 0 ? "0em" : ".71em").style("text-anchor", "middle");

-           pathUpdate.attr("d", "M" + range[0] + "," + sign * outerTickSize + "V0H" + range[1] + "V" + sign * outerTickSize);

-         } else {

-           tickTransform = d3_svg_axisY, x1 = "y", y1 = "x", x2 = "y2", y2 = "x2";

-           text.attr("dy", ".32em").style("text-anchor", sign < 0 ? "end" : "start");

-           pathUpdate.attr("d", "M" + sign * outerTickSize + "," + range[0] + "H0V" + range[1] + "H" + sign * outerTickSize);

-         }

-         lineEnter.attr(y2, sign * innerTickSize);

-         textEnter.attr(y1, sign * tickSpacing);

-         lineUpdate.attr(x2, 0).attr(y2, sign * innerTickSize);

-         textUpdate.attr(x1, 0).attr(y1, sign * tickSpacing);

-         if (scale1.rangeBand) {

-           var x = scale1, dx = x.rangeBand() / 2;

-           scale0 = scale1 = function(d) {

-             return x(d) + dx;

-           };

-         } else if (scale0.rangeBand) {

-           scale0 = scale1;

-         } else {

-           tickExit.call(tickTransform, scale1, scale0);

-         }

-         tickEnter.call(tickTransform, scale0, scale1);

-         tickUpdate.call(tickTransform, scale1, scale1);

-       });

-     }

-     axis.scale = function(x) {

-       if (!arguments.length) return scale;

-       scale = x;

-       return axis;

-     };

-     axis.orient = function(x) {

-       if (!arguments.length) return orient;

-       orient = x in d3_svg_axisOrients ? x + "" : d3_svg_axisDefaultOrient;

-       return axis;

-     };

-     axis.ticks = function() {

-       if (!arguments.length) return tickArguments_;

-       tickArguments_ = d3_array(arguments);

-       return axis;

-     };

-     axis.tickValues = function(x) {

-       if (!arguments.length) return tickValues;

-       tickValues = x;

-       return axis;

-     };

-     axis.tickFormat = function(x) {

-       if (!arguments.length) return tickFormat_;

-       tickFormat_ = x;

-       return axis;

-     };

-     axis.tickSize = function(x) {

-       var n = arguments.length;

-       if (!n) return innerTickSize;

-       innerTickSize = +x;

-       outerTickSize = +arguments[n - 1];

-       return axis;

-     };

-     axis.innerTickSize = function(x) {

-       if (!arguments.length) return innerTickSize;

-       innerTickSize = +x;

-       return axis;

-     };

-     axis.outerTickSize = function(x) {

-       if (!arguments.length) return outerTickSize;

-       outerTickSize = +x;

-       return axis;

-     };

-     axis.tickPadding = function(x) {

-       if (!arguments.length) return tickPadding;

-       tickPadding = +x;

-       return axis;

-     };

-     axis.tickSubdivide = function() {

-       return arguments.length && axis;

-     };

-     return axis;

-   };

-   var d3_svg_axisDefaultOrient = "bottom", d3_svg_axisOrients = {

-     top: 1,

-     right: 1,

-     bottom: 1,

-     left: 1

-   };

-   function d3_svg_axisX(selection, x0, x1) {

-     selection.attr("transform", function(d) {

-       var v0 = x0(d);

-       return "translate(" + (isFinite(v0) ? v0 : x1(d)) + ",0)";

-     });

-   }

-   function d3_svg_axisY(selection, y0, y1) {

-     selection.attr("transform", function(d) {

-       var v0 = y0(d);

-       return "translate(0," + (isFinite(v0) ? v0 : y1(d)) + ")";

-     });

-   }

-   d3.svg.brush = function() {

-     var event = d3_eventDispatch(brush, "brushstart", "brush", "brushend"), x = null, y = null, xExtent = [ 0, 0 ], yExtent = [ 0, 0 ], xExtentDomain, yExtentDomain, xClamp = true, yClamp = true, resizes = d3_svg_brushResizes[0];

-     function brush(g) {

-       g.each(function() {

-         var g = d3.select(this).style("pointer-events", "all").style("-webkit-tap-highlight-color", "rgba(0,0,0,0)").on("mousedown.brush", brushstart).on("touchstart.brush", brushstart);

-         var background = g.selectAll(".background").data([ 0 ]);

-         background.enter().append("rect").attr("class", "background").style("visibility", "hidden").style("cursor", "crosshair");

-         g.selectAll(".extent").data([ 0 ]).enter().append("rect").attr("class", "extent").style("cursor", "move");

-         var resize = g.selectAll(".resize").data(resizes, d3_identity);

-         resize.exit().remove();

-         resize.enter().append("g").attr("class", function(d) {

-           return "resize " + d;

-         }).style("cursor", function(d) {

-           return d3_svg_brushCursor[d];

-         }).append("rect").attr("x", function(d) {

-           return /[ew]$/.test(d) ? -3 : null;

-         }).attr("y", function(d) {

-           return /^[ns]/.test(d) ? -3 : null;

-         }).attr("width", 6).attr("height", 6).style("visibility", "hidden");

-         resize.style("display", brush.empty() ? "none" : null);

-         var gUpdate = d3.transition(g), backgroundUpdate = d3.transition(background), range;

-         if (x) {

-           range = d3_scaleRange(x);

-           backgroundUpdate.attr("x", range[0]).attr("width", range[1] - range[0]);

-           redrawX(gUpdate);

-         }

-         if (y) {

-           range = d3_scaleRange(y);

-           backgroundUpdate.attr("y", range[0]).attr("height", range[1] - range[0]);

-           redrawY(gUpdate);

-         }

-         redraw(gUpdate);

-       });

-     }

-     brush.event = function(g) {

-       g.each(function() {

-         var event_ = event.of(this, arguments), extent1 = {

-           x: xExtent,

-           y: yExtent,

-           i: xExtentDomain,

-           j: yExtentDomain

-         }, extent0 = this.__chart__ || extent1;

-         this.__chart__ = extent1;

-         if (d3_transitionInheritId) {

-           d3.select(this).transition().each("start.brush", function() {

-             xExtentDomain = extent0.i;

-             yExtentDomain = extent0.j;

-             xExtent = extent0.x;

-             yExtent = extent0.y;

-             event_({

-               type: "brushstart"

-             });

-           }).tween("brush:brush", function() {

-             var xi = d3_interpolateArray(xExtent, extent1.x), yi = d3_interpolateArray(yExtent, extent1.y);

-             xExtentDomain = yExtentDomain = null;

-             return function(t) {

-               xExtent = extent1.x = xi(t);

-               yExtent = extent1.y = yi(t);

-               event_({

-                 type: "brush",

-                 mode: "resize"

-               });

-             };

-           }).each("end.brush", function() {

-             xExtentDomain = extent1.i;

-             yExtentDomain = extent1.j;

-             event_({

-               type: "brush",

-               mode: "resize"

-             });

-             event_({

-               type: "brushend"

-             });

-           });

-         } else {

-           event_({

-             type: "brushstart"

-           });

-           event_({

-             type: "brush",

-             mode: "resize"

-           });

-           event_({

-             type: "brushend"

-           });

-         }

-       });

-     };

-     function redraw(g) {

-       g.selectAll(".resize").attr("transform", function(d) {

-         return "translate(" + xExtent[+/e$/.test(d)] + "," + yExtent[+/^s/.test(d)] + ")";

-       });

-     }

-     function redrawX(g) {

-       g.select(".extent").attr("x", xExtent[0]);

-       g.selectAll(".extent,.n>rect,.s>rect").attr("width", xExtent[1] - xExtent[0]);

-     }

-     function redrawY(g) {

-       g.select(".extent").attr("y", yExtent[0]);

-       g.selectAll(".extent,.e>rect,.w>rect").attr("height", yExtent[1] - yExtent[0]);

-     }

-     function brushstart() {

-       var target = this, eventTarget = d3.select(d3.event.target), event_ = event.of(target, arguments), g = d3.select(target), resizing = eventTarget.datum(), resizingX = !/^(n|s)$/.test(resizing) && x, resizingY = !/^(e|w)$/.test(resizing) && y, dragging = eventTarget.classed("extent"), dragRestore = d3_event_dragSuppress(target), center, origin = d3.mouse(target), offset;

-       var w = d3.select(d3_window(target)).on("keydown.brush", keydown).on("keyup.brush", keyup);

-       if (d3.event.changedTouches) {

-         w.on("touchmove.brush", brushmove).on("touchend.brush", brushend);

-       } else {

-         w.on("mousemove.brush", brushmove).on("mouseup.brush", brushend);

-       }

-       g.interrupt().selectAll("*").interrupt();

-       if (dragging) {

-         origin[0] = xExtent[0] - origin[0];

-         origin[1] = yExtent[0] - origin[1];

-       } else if (resizing) {

-         var ex = +/w$/.test(resizing), ey = +/^n/.test(resizing);

-         offset = [ xExtent[1 - ex] - origin[0], yExtent[1 - ey] - origin[1] ];

-         origin[0] = xExtent[ex];

-         origin[1] = yExtent[ey];

-       } else if (d3.event.altKey) center = origin.slice();

-       g.style("pointer-events", "none").selectAll(".resize").style("display", null);

-       d3.select("body").style("cursor", eventTarget.style("cursor"));

-       event_({

-         type: "brushstart"

-       });

-       brushmove();

-       function keydown() {

-         if (d3.event.keyCode == 32) {

-           if (!dragging) {

-             center = null;

-             origin[0] -= xExtent[1];

-             origin[1] -= yExtent[1];

-             dragging = 2;

-           }

-           d3_eventPreventDefault();

-         }

-       }

-       function keyup() {

-         if (d3.event.keyCode == 32 && dragging == 2) {

-           origin[0] += xExtent[1];

-           origin[1] += yExtent[1];

-           dragging = 0;

-           d3_eventPreventDefault();

-         }

-       }

-       function brushmove() {

-         var point = d3.mouse(target), moved = false;

-         if (offset) {

-           point[0] += offset[0];

-           point[1] += offset[1];

-         }

-         if (!dragging) {

-           if (d3.event.altKey) {

-             if (!center) center = [ (xExtent[0] + xExtent[1]) / 2, (yExtent[0] + yExtent[1]) / 2 ];

-             origin[0] = xExtent[+(point[0] < center[0])];

-             origin[1] = yExtent[+(point[1] < center[1])];

-           } else center = null;

-         }

-         if (resizingX && move1(point, x, 0)) {

-           redrawX(g);

-           moved = true;

-         }

-         if (resizingY && move1(point, y, 1)) {

-           redrawY(g);

-           moved = true;

-         }

-         if (moved) {

-           redraw(g);

-           event_({

-             type: "brush",

-             mode: dragging ? "move" : "resize"

-           });

-         }

-       }

-       function move1(point, scale, i) {

-         var range = d3_scaleRange(scale), r0 = range[0], r1 = range[1], position = origin[i], extent = i ? yExtent : xExtent, size = extent[1] - extent[0], min, max;

-         if (dragging) {

-           r0 -= position;

-           r1 -= size + position;

-         }

-         min = (i ? yClamp : xClamp) ? Math.max(r0, Math.min(r1, point[i])) : point[i];

-         if (dragging) {

-           max = (min += position) + size;

-         } else {

-           if (center) position = Math.max(r0, Math.min(r1, 2 * center[i] - min));

-           if (position < min) {

-             max = min;

-             min = position;

-           } else {

-             max = position;

-           }

-         }

-         if (extent[0] != min || extent[1] != max) {

-           if (i) yExtentDomain = null; else xExtentDomain = null;

-           extent[0] = min;

-           extent[1] = max;

-           return true;

-         }

-       }

-       function brushend() {

-         brushmove();

-         g.style("pointer-events", "all").selectAll(".resize").style("display", brush.empty() ? "none" : null);

-         d3.select("body").style("cursor", null);

-         w.on("mousemove.brush", null).on("mouseup.brush", null).on("touchmove.brush", null).on("touchend.brush", null).on("keydown.brush", null).on("keyup.brush", null);

-         dragRestore();

-         event_({

-           type: "brushend"

-         });

-       }

-     }

-     brush.x = function(z) {

-       if (!arguments.length) return x;

-       x = z;

-       resizes = d3_svg_brushResizes[!x << 1 | !y];

-       return brush;

-     };

-     brush.y = function(z) {

-       if (!arguments.length) return y;

-       y = z;

-       resizes = d3_svg_brushResizes[!x << 1 | !y];

-       return brush;

-     };

-     brush.clamp = function(z) {

-       if (!arguments.length) return x && y ? [ xClamp, yClamp ] : x ? xClamp : y ? yClamp : null;

-       if (x && y) xClamp = !!z[0], yClamp = !!z[1]; else if (x) xClamp = !!z; else if (y) yClamp = !!z;

-       return brush;

-     };

-     brush.extent = function(z) {

-       var x0, x1, y0, y1, t;

-       if (!arguments.length) {

-         if (x) {

-           if (xExtentDomain) {

-             x0 = xExtentDomain[0], x1 = xExtentDomain[1];

-           } else {

-             x0 = xExtent[0], x1 = xExtent[1];

-             if (x.invert) x0 = x.invert(x0), x1 = x.invert(x1);

-             if (x1 < x0) t = x0, x0 = x1, x1 = t;

-           }

-         }

-         if (y) {

-           if (yExtentDomain) {

-             y0 = yExtentDomain[0], y1 = yExtentDomain[1];

-           } else {

-             y0 = yExtent[0], y1 = yExtent[1];

-             if (y.invert) y0 = y.invert(y0), y1 = y.invert(y1);

-             if (y1 < y0) t = y0, y0 = y1, y1 = t;

-           }

-         }

-         return x && y ? [ [ x0, y0 ], [ x1, y1 ] ] : x ? [ x0, x1 ] : y && [ y0, y1 ];

-       }

-       if (x) {

-         x0 = z[0], x1 = z[1];

-         if (y) x0 = x0[0], x1 = x1[0];

-         xExtentDomain = [ x0, x1 ];

-         if (x.invert) x0 = x(x0), x1 = x(x1);

-         if (x1 < x0) t = x0, x0 = x1, x1 = t;

-         if (x0 != xExtent[0] || x1 != xExtent[1]) xExtent = [ x0, x1 ];

-       }

-       if (y) {

-         y0 = z[0], y1 = z[1];

-         if (x) y0 = y0[1], y1 = y1[1];

-         yExtentDomain = [ y0, y1 ];

-         if (y.invert) y0 = y(y0), y1 = y(y1);

-         if (y1 < y0) t = y0, y0 = y1, y1 = t;

-         if (y0 != yExtent[0] || y1 != yExtent[1]) yExtent = [ y0, y1 ];

-       }

-       return brush;

-     };

-     brush.clear = function() {

-       if (!brush.empty()) {

-         xExtent = [ 0, 0 ], yExtent = [ 0, 0 ];

-         xExtentDomain = yExtentDomain = null;

-       }

-       return brush;

-     };

-     brush.empty = function() {

-       return !!x && xExtent[0] == xExtent[1] || !!y && yExtent[0] == yExtent[1];

-     };

-     return d3.rebind(brush, event, "on");

-   };

-   var d3_svg_brushCursor = {

-     n: "ns-resize",

-     e: "ew-resize",

-     s: "ns-resize",

-     w: "ew-resize",

-     nw: "nwse-resize",

-     ne: "nesw-resize",

-     se: "nwse-resize",

-     sw: "nesw-resize"

-   };

-   var d3_svg_brushResizes = [ [ "n", "e", "s", "w", "nw", "ne", "se", "sw" ], [ "e", "w" ], [ "n", "s" ], [] ];

-   var d3_time_format = d3_time.format = d3_locale_enUS.timeFormat;

-   var d3_time_formatUtc = d3_time_format.utc;

-   var d3_time_formatIso = d3_time_formatUtc("%Y-%m-%dT%H:%M:%S.%LZ");

-   d3_time_format.iso = Date.prototype.toISOString && +new Date("2000-01-01T00:00:00.000Z") ? d3_time_formatIsoNative : d3_time_formatIso;

-   function d3_time_formatIsoNative(date) {

-     return date.toISOString();

-   }

-   d3_time_formatIsoNative.parse = function(string) {

-     var date = new Date(string);

-     return isNaN(date) ? null : date;

-   };

-   d3_time_formatIsoNative.toString = d3_time_formatIso.toString;

-   d3_time.second = d3_time_interval(function(date) {

-     return new d3_date(Math.floor(date / 1e3) * 1e3);

-   }, function(date, offset) {

-     date.setTime(date.getTime() + Math.floor(offset) * 1e3);

-   }, function(date) {

-     return date.getSeconds();

-   });

-   d3_time.seconds = d3_time.second.range;

-   d3_time.seconds.utc = d3_time.second.utc.range;

-   d3_time.minute = d3_time_interval(function(date) {

-     return new d3_date(Math.floor(date / 6e4) * 6e4);

-   }, function(date, offset) {

-     date.setTime(date.getTime() + Math.floor(offset) * 6e4);

-   }, function(date) {

-     return date.getMinutes();

-   });

-   d3_time.minutes = d3_time.minute.range;

-   d3_time.minutes.utc = d3_time.minute.utc.range;

-   d3_time.hour = d3_time_interval(function(date) {

-     var timezone = date.getTimezoneOffset() / 60;

-     return new d3_date((Math.floor(date / 36e5 - timezone) + timezone) * 36e5);

-   }, function(date, offset) {

-     date.setTime(date.getTime() + Math.floor(offset) * 36e5);

-   }, function(date) {

-     return date.getHours();

-   });

-   d3_time.hours = d3_time.hour.range;

-   d3_time.hours.utc = d3_time.hour.utc.range;

-   d3_time.month = d3_time_interval(function(date) {

-     date = d3_time.day(date);

-     date.setDate(1);

-     return date;

-   }, function(date, offset) {

-     date.setMonth(date.getMonth() + offset);

-   }, function(date) {

-     return date.getMonth();

-   });

-   d3_time.months = d3_time.month.range;

-   d3_time.months.utc = d3_time.month.utc.range;

-   function d3_time_scale(linear, methods, format) {

-     function scale(x) {

-       return linear(x);

-     }

-     scale.invert = function(x) {

-       return d3_time_scaleDate(linear.invert(x));

-     };

-     scale.domain = function(x) {

-       if (!arguments.length) return linear.domain().map(d3_time_scaleDate);

-       linear.domain(x);

-       return scale;

-     };

-     function tickMethod(extent, count) {

-       var span = extent[1] - extent[0], target = span / count, i = d3.bisect(d3_time_scaleSteps, target);

-       return i == d3_time_scaleSteps.length ? [ methods.year, d3_scale_linearTickRange(extent.map(function(d) {

-         return d / 31536e6;

-       }), count)[2] ] : !i ? [ d3_time_scaleMilliseconds, d3_scale_linearTickRange(extent, count)[2] ] : methods[target / d3_time_scaleSteps[i - 1] < d3_time_scaleSteps[i] / target ? i - 1 : i];

-     }

-     scale.nice = function(interval, skip) {

-       var domain = scale.domain(), extent = d3_scaleExtent(domain), method = interval == null ? tickMethod(extent, 10) : typeof interval === "number" && tickMethod(extent, interval);

-       if (method) interval = method[0], skip = method[1];

-       function skipped(date) {

-         return !isNaN(date) && !interval.range(date, d3_time_scaleDate(+date + 1), skip).length;

-       }

-       return scale.domain(d3_scale_nice(domain, skip > 1 ? {

-         floor: function(date) {

-           while (skipped(date = interval.floor(date))) date = d3_time_scaleDate(date - 1);

-           return date;

-         },

-         ceil: function(date) {

-           while (skipped(date = interval.ceil(date))) date = d3_time_scaleDate(+date + 1);

-           return date;

-         }

-       } : interval));

-     };

-     scale.ticks = function(interval, skip) {

-       var extent = d3_scaleExtent(scale.domain()), method = interval == null ? tickMethod(extent, 10) : typeof interval === "number" ? tickMethod(extent, interval) : !interval.range && [ {

-         range: interval

-       }, skip ];

-       if (method) interval = method[0], skip = method[1];

-       return interval.range(extent[0], d3_time_scaleDate(+extent[1] + 1), skip < 1 ? 1 : skip);

-     };

-     scale.tickFormat = function() {

-       return format;

-     };

-     scale.copy = function() {

-       return d3_time_scale(linear.copy(), methods, format);

-     };

-     return d3_scale_linearRebind(scale, linear);

-   }

-   function d3_time_scaleDate(t) {

-     return new Date(t);

-   }

-   var d3_time_scaleSteps = [ 1e3, 5e3, 15e3, 3e4, 6e4, 3e5, 9e5, 18e5, 36e5, 108e5, 216e5, 432e5, 864e5, 1728e5, 6048e5, 2592e6, 7776e6, 31536e6 ];

-   var d3_time_scaleLocalMethods = [ [ d3_time.second, 1 ], [ d3_time.second, 5 ], [ d3_time.second, 15 ], [ d3_time.second, 30 ], [ d3_time.minute, 1 ], [ d3_time.minute, 5 ], [ d3_time.minute, 15 ], [ d3_time.minute, 30 ], [ d3_time.hour, 1 ], [ d3_time.hour, 3 ], [ d3_time.hour, 6 ], [ d3_time.hour, 12 ], [ d3_time.day, 1 ], [ d3_time.day, 2 ], [ d3_time.week, 1 ], [ d3_time.month, 1 ], [ d3_time.month, 3 ], [ d3_time.year, 1 ] ];

-   var d3_time_scaleLocalFormat = d3_time_format.multi([ [ ".%L", function(d) {

-     return d.getMilliseconds();

-   } ], [ ":%S", function(d) {

-     return d.getSeconds();

-   } ], [ "%I:%M", function(d) {

-     return d.getMinutes();

-   } ], [ "%I %p", function(d) {

-     return d.getHours();

-   } ], [ "%a %d", function(d) {

-     return d.getDay() && d.getDate() != 1;

-   } ], [ "%b %d", function(d) {

-     return d.getDate() != 1;

-   } ], [ "%B", function(d) {

-     return d.getMonth();

-   } ], [ "%Y", d3_true ] ]);

-   var d3_time_scaleMilliseconds = {

-     range: function(start, stop, step) {

-       return d3.range(Math.ceil(start / step) * step, +stop, step).map(d3_time_scaleDate);

-     },

-     floor: d3_identity,

-     ceil: d3_identity

-   };

-   d3_time_scaleLocalMethods.year = d3_time.year;

-   d3_time.scale = function() {

-     return d3_time_scale(d3.scale.linear(), d3_time_scaleLocalMethods, d3_time_scaleLocalFormat);

-   };

-   var d3_time_scaleUtcMethods = d3_time_scaleLocalMethods.map(function(m) {

-     return [ m[0].utc, m[1] ];

-   });

-   var d3_time_scaleUtcFormat = d3_time_formatUtc.multi([ [ ".%L", function(d) {

-     return d.getUTCMilliseconds();

-   } ], [ ":%S", function(d) {

-     return d.getUTCSeconds();

-   } ], [ "%I:%M", function(d) {

-     return d.getUTCMinutes();

-   } ], [ "%I %p", function(d) {

-     return d.getUTCHours();

-   } ], [ "%a %d", function(d) {

-     return d.getUTCDay() && d.getUTCDate() != 1;

-   } ], [ "%b %d", function(d) {

-     return d.getUTCDate() != 1;

-   } ], [ "%B", function(d) {

-     return d.getUTCMonth();

-   } ], [ "%Y", d3_true ] ]);

-   d3_time_scaleUtcMethods.year = d3_time.year.utc;

-   d3_time.scale.utc = function() {

-     return d3_time_scale(d3.scale.linear(), d3_time_scaleUtcMethods, d3_time_scaleUtcFormat);

-   };

-   d3.text = d3_xhrType(function(request) {

-     return request.responseText;

-   });

-   d3.json = function(url, callback) {

-     return d3_xhr(url, "application/json", d3_json, callback);

-   };

-   function d3_json(request) {

-     return JSON.parse(request.responseText);

-   }

-   d3.html = function(url, callback) {

-     return d3_xhr(url, "text/html", d3_html, callback);

-   };

-   function d3_html(request) {

-     var range = d3_document.createRange();

-     range.selectNode(d3_document.body);

-     return range.createContextualFragment(request.responseText);

-   }

-   d3.xml = d3_xhrType(function(request) {

-     return request.responseXML;

-   });

-   if (typeof define === "function" && define.amd) this.d3 = d3, define(d3); else if (typeof module === "object" && module.exports) module.exports = d3; else this.d3 = d3;

- }(); 

\ No newline at end of file

@@ -1,5 +0,0 @@ 

- !function(){function n(n){return n&&(n.ownerDocument||n.document||n).documentElement}function t(n){return n&&(n.ownerDocument&&n.ownerDocument.defaultView||n.document&&n||n.defaultView)}function e(n,t){return t>n?-1:n>t?1:n>=t?0:NaN}function r(n){return null===n?NaN:+n}function i(n){return!isNaN(n)}function u(n){return{left:function(t,e,r,i){for(arguments.length<3&&(r=0),arguments.length<4&&(i=t.length);i>r;){var u=r+i>>>1;n(t[u],e)<0?r=u+1:i=u}return r},right:function(t,e,r,i){for(arguments.length<3&&(r=0),arguments.length<4&&(i=t.length);i>r;){var u=r+i>>>1;n(t[u],e)>0?i=u:r=u+1}return r}}}function o(n){return n.length}function a(n){for(var t=1;n*t%1;)t*=10;return t}function l(n,t){for(var e in t)Object.defineProperty(n.prototype,e,{value:t[e],enumerable:!1})}function c(){this._=Object.create(null)}function f(n){return(n+="")===bo||n[0]===_o?_o+n:n}function s(n){return(n+="")[0]===_o?n.slice(1):n}function h(n){return f(n)in this._}function p(n){return(n=f(n))in this._&&delete this._[n]}function g(){var n=[];for(var t in this._)n.push(s(t));return n}function v(){var n=0;for(var t in this._)++n;return n}function d(){for(var n in this._)return!1;return!0}function y(){this._=Object.create(null)}function m(n){return n}function M(n,t,e){return function(){var r=e.apply(t,arguments);return r===t?n:r}}function x(n,t){if(t in n)return t;t=t.charAt(0).toUpperCase()+t.slice(1);for(var e=0,r=wo.length;r>e;++e){var i=wo[e]+t;if(i in n)return i}}function b(){}function _(){}function w(n){function t(){for(var t,r=e,i=-1,u=r.length;++i<u;)(t=r[i].on)&&t.apply(this,arguments);return n}var e=[],r=new c;return t.on=function(t,i){var u,o=r.get(t);return arguments.length<2?o&&o.on:(o&&(o.on=null,e=e.slice(0,u=e.indexOf(o)).concat(e.slice(u+1)),r.remove(t)),i&&e.push(r.set(t,{on:i})),n)},t}function S(){ao.event.preventDefault()}function k(){for(var n,t=ao.event;n=t.sourceEvent;)t=n;return t}function N(n){for(var t=new _,e=0,r=arguments.length;++e<r;)t[arguments[e]]=w(t);return t.of=function(e,r){return function(i){try{var u=i.sourceEvent=ao.event;i.target=n,ao.event=i,t[i.type].apply(e,r)}finally{ao.event=u}}},t}function E(n){return ko(n,Co),n}function A(n){return"function"==typeof n?n:function(){return No(n,this)}}function C(n){return"function"==typeof n?n:function(){return Eo(n,this)}}function z(n,t){function e(){this.removeAttribute(n)}function r(){this.removeAttributeNS(n.space,n.local)}function i(){this.setAttribute(n,t)}function u(){this.setAttributeNS(n.space,n.local,t)}function o(){var e=t.apply(this,arguments);null==e?this.removeAttribute(n):this.setAttribute(n,e)}function a(){var e=t.apply(this,arguments);null==e?this.removeAttributeNS(n.space,n.local):this.setAttributeNS(n.space,n.local,e)}return n=ao.ns.qualify(n),null==t?n.local?r:e:"function"==typeof t?n.local?a:o:n.local?u:i}function L(n){return n.trim().replace(/\s+/g," ")}function q(n){return new RegExp("(?:^|\\s+)"+ao.requote(n)+"(?:\\s+|$)","g")}function T(n){return(n+"").trim().split(/^|\s+/)}function R(n,t){function e(){for(var e=-1;++e<i;)n[e](this,t)}function r(){for(var e=-1,r=t.apply(this,arguments);++e<i;)n[e](this,r)}n=T(n).map(D);var i=n.length;return"function"==typeof t?r:e}function D(n){var t=q(n);return function(e,r){if(i=e.classList)return r?i.add(n):i.remove(n);var i=e.getAttribute("class")||"";r?(t.lastIndex=0,t.test(i)||e.setAttribute("class",L(i+" "+n))):e.setAttribute("class",L(i.replace(t," ")))}}function P(n,t,e){function r(){this.style.removeProperty(n)}function i(){this.style.setProperty(n,t,e)}function u(){var r=t.apply(this,arguments);null==r?this.style.removeProperty(n):this.style.setProperty(n,r,e)}return null==t?r:"function"==typeof t?u:i}function U(n,t){function e(){delete this[n]}function r(){this[n]=t}function i(){var e=t.apply(this,arguments);null==e?delete this[n]:this[n]=e}return null==t?e:"function"==typeof t?i:r}function j(n){function t(){var t=this.ownerDocument,e=this.namespaceURI;return e===zo&&t.documentElement.namespaceURI===zo?t.createElement(n):t.createElementNS(e,n)}function e(){return this.ownerDocument.createElementNS(n.space,n.local)}return"function"==typeof n?n:(n=ao.ns.qualify(n)).local?e:t}function F(){var n=this.parentNode;n&&n.removeChild(this)}function H(n){return{__data__:n}}function O(n){return function(){return Ao(this,n)}}function I(n){return arguments.length||(n=e),function(t,e){return t&&e?n(t.__data__,e.__data__):!t-!e}}function Y(n,t){for(var e=0,r=n.length;r>e;e++)for(var i,u=n[e],o=0,a=u.length;a>o;o++)(i=u[o])&&t(i,o,e);return n}function Z(n){return ko(n,qo),n}function V(n){var t,e;return function(r,i,u){var o,a=n[u].update,l=a.length;for(u!=e&&(e=u,t=0),i>=t&&(t=i+1);!(o=a[t])&&++t<l;);return o}}function X(n,t,e){function r(){var t=this[o];t&&(this.removeEventListener(n,t,t.$),delete this[o])}function i(){var i=l(t,co(arguments));r.call(this),this.addEventListener(n,this[o]=i,i.$=e),i._=t}function u(){var t,e=new RegExp("^__on([^.]+)"+ao.requote(n)+"$");for(var r in this)if(t=r.match(e)){var i=this[r];this.removeEventListener(t[1],i,i.$),delete this[r]}}var o="__on"+n,a=n.indexOf("."),l=$;a>0&&(n=n.slice(0,a));var c=To.get(n);return c&&(n=c,l=B),a?t?i:r:t?b:u}function $(n,t){return function(e){var r=ao.event;ao.event=e,t[0]=this.__data__;try{n.apply(this,t)}finally{ao.event=r}}}function B(n,t){var e=$(n,t);return function(n){var t=this,r=n.relatedTarget;r&&(r===t||8&r.compareDocumentPosition(t))||e.call(t,n)}}function W(e){var r=".dragsuppress-"+ ++Do,i="click"+r,u=ao.select(t(e)).on("touchmove"+r,S).on("dragstart"+r,S).on("selectstart"+r,S);if(null==Ro&&(Ro="onselectstart"in e?!1:x(e.style,"userSelect")),Ro){var o=n(e).style,a=o[Ro];o[Ro]="none"}return function(n){if(u.on(r,null),Ro&&(o[Ro]=a),n){var t=function(){u.on(i,null)};u.on(i,function(){S(),t()},!0),setTimeout(t,0)}}}function J(n,e){e.changedTouches&&(e=e.changedTouches[0]);var r=n.ownerSVGElement||n;if(r.createSVGPoint){var i=r.createSVGPoint();if(0>Po){var u=t(n);if(u.scrollX||u.scrollY){r=ao.select("body").append("svg").style({position:"absolute",top:0,left:0,margin:0,padding:0,border:"none"},"important");var o=r[0][0].getScreenCTM();Po=!(o.f||o.e),r.remove()}}return Po?(i.x=e.pageX,i.y=e.pageY):(i.x=e.clientX,i.y=e.clientY),i=i.matrixTransform(n.getScreenCTM().inverse()),[i.x,i.y]}var a=n.getBoundingClientRect();return[e.clientX-a.left-n.clientLeft,e.clientY-a.top-n.clientTop]}function G(){return ao.event.changedTouches[0].identifier}function K(n){return n>0?1:0>n?-1:0}function Q(n,t,e){return(t[0]-n[0])*(e[1]-n[1])-(t[1]-n[1])*(e[0]-n[0])}function nn(n){return n>1?0:-1>n?Fo:Math.acos(n)}function tn(n){return n>1?Io:-1>n?-Io:Math.asin(n)}function en(n){return((n=Math.exp(n))-1/n)/2}function rn(n){return((n=Math.exp(n))+1/n)/2}function un(n){return((n=Math.exp(2*n))-1)/(n+1)}function on(n){return(n=Math.sin(n/2))*n}function an(){}function ln(n,t,e){return this instanceof ln?(this.h=+n,this.s=+t,void(this.l=+e)):arguments.length<2?n instanceof ln?new ln(n.h,n.s,n.l):_n(""+n,wn,ln):new ln(n,t,e)}function cn(n,t,e){function r(n){return n>360?n-=360:0>n&&(n+=360),60>n?u+(o-u)*n/60:180>n?o:240>n?u+(o-u)*(240-n)/60:u}function i(n){return Math.round(255*r(n))}var u,o;return n=isNaN(n)?0:(n%=360)<0?n+360:n,t=isNaN(t)?0:0>t?0:t>1?1:t,e=0>e?0:e>1?1:e,o=.5>=e?e*(1+t):e+t-e*t,u=2*e-o,new mn(i(n+120),i(n),i(n-120))}function fn(n,t,e){return this instanceof fn?(this.h=+n,this.c=+t,void(this.l=+e)):arguments.length<2?n instanceof fn?new fn(n.h,n.c,n.l):n instanceof hn?gn(n.l,n.a,n.b):gn((n=Sn((n=ao.rgb(n)).r,n.g,n.b)).l,n.a,n.b):new fn(n,t,e)}function sn(n,t,e){return isNaN(n)&&(n=0),isNaN(t)&&(t=0),new hn(e,Math.cos(n*=Yo)*t,Math.sin(n)*t)}function hn(n,t,e){return this instanceof hn?(this.l=+n,this.a=+t,void(this.b=+e)):arguments.length<2?n instanceof hn?new hn(n.l,n.a,n.b):n instanceof fn?sn(n.h,n.c,n.l):Sn((n=mn(n)).r,n.g,n.b):new hn(n,t,e)}function pn(n,t,e){var r=(n+16)/116,i=r+t/500,u=r-e/200;return i=vn(i)*na,r=vn(r)*ta,u=vn(u)*ea,new mn(yn(3.2404542*i-1.5371385*r-.4985314*u),yn(-.969266*i+1.8760108*r+.041556*u),yn(.0556434*i-.2040259*r+1.0572252*u))}function gn(n,t,e){return n>0?new fn(Math.atan2(e,t)*Zo,Math.sqrt(t*t+e*e),n):new fn(NaN,NaN,n)}function vn(n){return n>.206893034?n*n*n:(n-4/29)/7.787037}function dn(n){return n>.008856?Math.pow(n,1/3):7.787037*n+4/29}function yn(n){return Math.round(255*(.00304>=n?12.92*n:1.055*Math.pow(n,1/2.4)-.055))}function mn(n,t,e){return this instanceof mn?(this.r=~~n,this.g=~~t,void(this.b=~~e)):arguments.length<2?n instanceof mn?new mn(n.r,n.g,n.b):_n(""+n,mn,cn):new mn(n,t,e)}function Mn(n){return new mn(n>>16,n>>8&255,255&n)}function xn(n){return Mn(n)+""}function bn(n){return 16>n?"0"+Math.max(0,n).toString(16):Math.min(255,n).toString(16)}function _n(n,t,e){var r,i,u,o=0,a=0,l=0;if(r=/([a-z]+)\((.*)\)/.exec(n=n.toLowerCase()))switch(i=r[2].split(","),r[1]){case"hsl":return e(parseFloat(i[0]),parseFloat(i[1])/100,parseFloat(i[2])/100);case"rgb":return t(Nn(i[0]),Nn(i[1]),Nn(i[2]))}return(u=ua.get(n))?t(u.r,u.g,u.b):(null==n||"#"!==n.charAt(0)||isNaN(u=parseInt(n.slice(1),16))||(4===n.length?(o=(3840&u)>>4,o=o>>4|o,a=240&u,a=a>>4|a,l=15&u,l=l<<4|l):7===n.length&&(o=(16711680&u)>>16,a=(65280&u)>>8,l=255&u)),t(o,a,l))}function wn(n,t,e){var r,i,u=Math.min(n/=255,t/=255,e/=255),o=Math.max(n,t,e),a=o-u,l=(o+u)/2;return a?(i=.5>l?a/(o+u):a/(2-o-u),r=n==o?(t-e)/a+(e>t?6:0):t==o?(e-n)/a+2:(n-t)/a+4,r*=60):(r=NaN,i=l>0&&1>l?0:r),new ln(r,i,l)}function Sn(n,t,e){n=kn(n),t=kn(t),e=kn(e);var r=dn((.4124564*n+.3575761*t+.1804375*e)/na),i=dn((.2126729*n+.7151522*t+.072175*e)/ta),u=dn((.0193339*n+.119192*t+.9503041*e)/ea);return hn(116*i-16,500*(r-i),200*(i-u))}function kn(n){return(n/=255)<=.04045?n/12.92:Math.pow((n+.055)/1.055,2.4)}function Nn(n){var t=parseFloat(n);return"%"===n.charAt(n.length-1)?Math.round(2.55*t):t}function En(n){return"function"==typeof n?n:function(){return n}}function An(n){return function(t,e,r){return 2===arguments.length&&"function"==typeof e&&(r=e,e=null),Cn(t,e,n,r)}}function Cn(n,t,e,r){function i(){var n,t=l.status;if(!t&&Ln(l)||t>=200&&300>t||304===t){try{n=e.call(u,l)}catch(r){return void o.error.call(u,r)}o.load.call(u,n)}else o.error.call(u,l)}var u={},o=ao.dispatch("beforesend","progress","load","error"),a={},l=new XMLHttpRequest,c=null;return!this.XDomainRequest||"withCredentials"in l||!/^(http(s)?:)?\/\//.test(n)||(l=new XDomainRequest),"onload"in l?l.onload=l.onerror=i:l.onreadystatechange=function(){l.readyState>3&&i()},l.onprogress=function(n){var t=ao.event;ao.event=n;try{o.progress.call(u,l)}finally{ao.event=t}},u.header=function(n,t){return n=(n+"").toLowerCase(),arguments.length<2?a[n]:(null==t?delete a[n]:a[n]=t+"",u)},u.mimeType=function(n){return arguments.length?(t=null==n?null:n+"",u):t},u.responseType=function(n){return arguments.length?(c=n,u):c},u.response=function(n){return e=n,u},["get","post"].forEach(function(n){u[n]=function(){return u.send.apply(u,[n].concat(co(arguments)))}}),u.send=function(e,r,i){if(2===arguments.length&&"function"==typeof r&&(i=r,r=null),l.open(e,n,!0),null==t||"accept"in a||(a.accept=t+",*/*"),l.setRequestHeader)for(var f in a)l.setRequestHeader(f,a[f]);return null!=t&&l.overrideMimeType&&l.overrideMimeType(t),null!=c&&(l.responseType=c),null!=i&&u.on("error",i).on("load",function(n){i(null,n)}),o.beforesend.call(u,l),l.send(null==r?null:r),u},u.abort=function(){return l.abort(),u},ao.rebind(u,o,"on"),null==r?u:u.get(zn(r))}function zn(n){return 1===n.length?function(t,e){n(null==t?e:null)}:n}function Ln(n){var t=n.responseType;return t&&"text"!==t?n.response:n.responseText}function qn(n,t,e){var r=arguments.length;2>r&&(t=0),3>r&&(e=Date.now());var i=e+t,u={c:n,t:i,n:null};return aa?aa.n=u:oa=u,aa=u,la||(ca=clearTimeout(ca),la=1,fa(Tn)),u}function Tn(){var n=Rn(),t=Dn()-n;t>24?(isFinite(t)&&(clearTimeout(ca),ca=setTimeout(Tn,t)),la=0):(la=1,fa(Tn))}function Rn(){for(var n=Date.now(),t=oa;t;)n>=t.t&&t.c(n-t.t)&&(t.c=null),t=t.n;return n}function Dn(){for(var n,t=oa,e=1/0;t;)t.c?(t.t<e&&(e=t.t),t=(n=t).n):t=n?n.n=t.n:oa=t.n;return aa=n,e}function Pn(n,t){return t-(n?Math.ceil(Math.log(n)/Math.LN10):1)}function Un(n,t){var e=Math.pow(10,3*xo(8-t));return{scale:t>8?function(n){return n/e}:function(n){return n*e},symbol:n}}function jn(n){var t=n.decimal,e=n.thousands,r=n.grouping,i=n.currency,u=r&&e?function(n,t){for(var i=n.length,u=[],o=0,a=r[0],l=0;i>0&&a>0&&(l+a+1>t&&(a=Math.max(1,t-l)),u.push(n.substring(i-=a,i+a)),!((l+=a+1)>t));)a=r[o=(o+1)%r.length];return u.reverse().join(e)}:m;return function(n){var e=ha.exec(n),r=e[1]||" ",o=e[2]||">",a=e[3]||"-",l=e[4]||"",c=e[5],f=+e[6],s=e[7],h=e[8],p=e[9],g=1,v="",d="",y=!1,m=!0;switch(h&&(h=+h.substring(1)),(c||"0"===r&&"="===o)&&(c=r="0",o="="),p){case"n":s=!0,p="g";break;case"%":g=100,d="%",p="f";break;case"p":g=100,d="%",p="r";break;case"b":case"o":case"x":case"X":"#"===l&&(v="0"+p.toLowerCase());case"c":m=!1;case"d":y=!0,h=0;break;case"s":g=-1,p="r"}"$"===l&&(v=i[0],d=i[1]),"r"!=p||h||(p="g"),null!=h&&("g"==p?h=Math.max(1,Math.min(21,h)):"e"!=p&&"f"!=p||(h=Math.max(0,Math.min(20,h)))),p=pa.get(p)||Fn;var M=c&&s;return function(n){var e=d;if(y&&n%1)return"";var i=0>n||0===n&&0>1/n?(n=-n,"-"):"-"===a?"":a;if(0>g){var l=ao.formatPrefix(n,h);n=l.scale(n),e=l.symbol+d}else n*=g;n=p(n,h);var x,b,_=n.lastIndexOf(".");if(0>_){var w=m?n.lastIndexOf("e"):-1;0>w?(x=n,b=""):(x=n.substring(0,w),b=n.substring(w))}else x=n.substring(0,_),b=t+n.substring(_+1);!c&&s&&(x=u(x,1/0));var S=v.length+x.length+b.length+(M?0:i.length),k=f>S?new Array(S=f-S+1).join(r):"";return M&&(x=u(k+x,k.length?f-b.length:1/0)),i+=v,n=x+b,("<"===o?i+n+k:">"===o?k+i+n:"^"===o?k.substring(0,S>>=1)+i+n+k.substring(S):i+(M?n:k+n))+e}}}function Fn(n){return n+""}function Hn(){this._=new Date(arguments.length>1?Date.UTC.apply(this,arguments):arguments[0])}function On(n,t,e){function r(t){var e=n(t),r=u(e,1);return r-t>t-e?e:r}function i(e){return t(e=n(new va(e-1)),1),e}function u(n,e){return t(n=new va(+n),e),n}function o(n,r,u){var o=i(n),a=[];if(u>1)for(;r>o;)e(o)%u||a.push(new Date(+o)),t(o,1);else for(;r>o;)a.push(new Date(+o)),t(o,1);return a}function a(n,t,e){try{va=Hn;var r=new Hn;return r._=n,o(r,t,e)}finally{va=Date}}n.floor=n,n.round=r,n.ceil=i,n.offset=u,n.range=o;var l=n.utc=In(n);return l.floor=l,l.round=In(r),l.ceil=In(i),l.offset=In(u),l.range=a,n}function In(n){return function(t,e){try{va=Hn;var r=new Hn;return r._=t,n(r,e)._}finally{va=Date}}}function Yn(n){function t(n){function t(t){for(var e,i,u,o=[],a=-1,l=0;++a<r;)37===n.charCodeAt(a)&&(o.push(n.slice(l,a)),null!=(i=ya[e=n.charAt(++a)])&&(e=n.charAt(++a)),(u=A[e])&&(e=u(t,null==i?"e"===e?" ":"0":i)),o.push(e),l=a+1);return o.push(n.slice(l,a)),o.join("")}var r=n.length;return t.parse=function(t){var r={y:1900,m:0,d:1,H:0,M:0,S:0,L:0,Z:null},i=e(r,n,t,0);if(i!=t.length)return null;"p"in r&&(r.H=r.H%12+12*r.p);var u=null!=r.Z&&va!==Hn,o=new(u?Hn:va);return"j"in r?o.setFullYear(r.y,0,r.j):"W"in r||"U"in r?("w"in r||(r.w="W"in r?1:0),o.setFullYear(r.y,0,1),o.setFullYear(r.y,0,"W"in r?(r.w+6)%7+7*r.W-(o.getDay()+5)%7:r.w+7*r.U-(o.getDay()+6)%7)):o.setFullYear(r.y,r.m,r.d),o.setHours(r.H+(r.Z/100|0),r.M+r.Z%100,r.S,r.L),u?o._:o},t.toString=function(){return n},t}function e(n,t,e,r){for(var i,u,o,a=0,l=t.length,c=e.length;l>a;){if(r>=c)return-1;if(i=t.charCodeAt(a++),37===i){if(o=t.charAt(a++),u=C[o in ya?t.charAt(a++):o],!u||(r=u(n,e,r))<0)return-1}else if(i!=e.charCodeAt(r++))return-1}return r}function r(n,t,e){_.lastIndex=0;var r=_.exec(t.slice(e));return r?(n.w=w.get(r[0].toLowerCase()),e+r[0].length):-1}function i(n,t,e){x.lastIndex=0;var r=x.exec(t.slice(e));return r?(n.w=b.get(r[0].toLowerCase()),e+r[0].length):-1}function u(n,t,e){N.lastIndex=0;var r=N.exec(t.slice(e));return r?(n.m=E.get(r[0].toLowerCase()),e+r[0].length):-1}function o(n,t,e){S.lastIndex=0;var r=S.exec(t.slice(e));return r?(n.m=k.get(r[0].toLowerCase()),e+r[0].length):-1}function a(n,t,r){return e(n,A.c.toString(),t,r)}function l(n,t,r){return e(n,A.x.toString(),t,r)}function c(n,t,r){return e(n,A.X.toString(),t,r)}function f(n,t,e){var r=M.get(t.slice(e,e+=2).toLowerCase());return null==r?-1:(n.p=r,e)}var s=n.dateTime,h=n.date,p=n.time,g=n.periods,v=n.days,d=n.shortDays,y=n.months,m=n.shortMonths;t.utc=function(n){function e(n){try{va=Hn;var t=new va;return t._=n,r(t)}finally{va=Date}}var r=t(n);return e.parse=function(n){try{va=Hn;var t=r.parse(n);return t&&t._}finally{va=Date}},e.toString=r.toString,e},t.multi=t.utc.multi=ct;var M=ao.map(),x=Vn(v),b=Xn(v),_=Vn(d),w=Xn(d),S=Vn(y),k=Xn(y),N=Vn(m),E=Xn(m);g.forEach(function(n,t){M.set(n.toLowerCase(),t)});var A={a:function(n){return d[n.getDay()]},A:function(n){return v[n.getDay()]},b:function(n){return m[n.getMonth()]},B:function(n){return y[n.getMonth()]},c:t(s),d:function(n,t){return Zn(n.getDate(),t,2)},e:function(n,t){return Zn(n.getDate(),t,2)},H:function(n,t){return Zn(n.getHours(),t,2)},I:function(n,t){return Zn(n.getHours()%12||12,t,2)},j:function(n,t){return Zn(1+ga.dayOfYear(n),t,3)},L:function(n,t){return Zn(n.getMilliseconds(),t,3)},m:function(n,t){return Zn(n.getMonth()+1,t,2)},M:function(n,t){return Zn(n.getMinutes(),t,2)},p:function(n){return g[+(n.getHours()>=12)]},S:function(n,t){return Zn(n.getSeconds(),t,2)},U:function(n,t){return Zn(ga.sundayOfYear(n),t,2)},w:function(n){return n.getDay()},W:function(n,t){return Zn(ga.mondayOfYear(n),t,2)},x:t(h),X:t(p),y:function(n,t){return Zn(n.getFullYear()%100,t,2)},Y:function(n,t){return Zn(n.getFullYear()%1e4,t,4)},Z:at,"%":function(){return"%"}},C={a:r,A:i,b:u,B:o,c:a,d:tt,e:tt,H:rt,I:rt,j:et,L:ot,m:nt,M:it,p:f,S:ut,U:Bn,w:$n,W:Wn,x:l,X:c,y:Gn,Y:Jn,Z:Kn,"%":lt};return t}function Zn(n,t,e){var r=0>n?"-":"",i=(r?-n:n)+"",u=i.length;return r+(e>u?new Array(e-u+1).join(t)+i:i)}function Vn(n){return new RegExp("^(?:"+n.map(ao.requote).join("|")+")","i")}function Xn(n){for(var t=new c,e=-1,r=n.length;++e<r;)t.set(n[e].toLowerCase(),e);return t}function $n(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+1));return r?(n.w=+r[0],e+r[0].length):-1}function Bn(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e));return r?(n.U=+r[0],e+r[0].length):-1}function Wn(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e));return r?(n.W=+r[0],e+r[0].length):-1}function Jn(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+4));return r?(n.y=+r[0],e+r[0].length):-1}function Gn(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.y=Qn(+r[0]),e+r[0].length):-1}function Kn(n,t,e){return/^[+-]\d{4}$/.test(t=t.slice(e,e+5))?(n.Z=-t,e+5):-1}function Qn(n){return n+(n>68?1900:2e3)}function nt(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.m=r[0]-1,e+r[0].length):-1}function tt(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.d=+r[0],e+r[0].length):-1}function et(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+3));return r?(n.j=+r[0],e+r[0].length):-1}function rt(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.H=+r[0],e+r[0].length):-1}function it(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.M=+r[0],e+r[0].length):-1}function ut(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.S=+r[0],e+r[0].length):-1}function ot(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+3));return r?(n.L=+r[0],e+r[0].length):-1}function at(n){var t=n.getTimezoneOffset(),e=t>0?"-":"+",r=xo(t)/60|0,i=xo(t)%60;return e+Zn(r,"0",2)+Zn(i,"0",2)}function lt(n,t,e){Ma.lastIndex=0;var r=Ma.exec(t.slice(e,e+1));return r?e+r[0].length:-1}function ct(n){for(var t=n.length,e=-1;++e<t;)n[e][0]=this(n[e][0]);return function(t){for(var e=0,r=n[e];!r[1](t);)r=n[++e];return r[0](t)}}function ft(){}function st(n,t,e){var r=e.s=n+t,i=r-n,u=r-i;e.t=n-u+(t-i)}function ht(n,t){n&&wa.hasOwnProperty(n.type)&&wa[n.type](n,t)}function pt(n,t,e){var r,i=-1,u=n.length-e;for(t.lineStart();++i<u;)r=n[i],t.point(r[0],r[1],r[2]);t.lineEnd()}function gt(n,t){var e=-1,r=n.length;for(t.polygonStart();++e<r;)pt(n[e],t,1);t.polygonEnd()}function vt(){function n(n,t){n*=Yo,t=t*Yo/2+Fo/4;var e=n-r,o=e>=0?1:-1,a=o*e,l=Math.cos(t),c=Math.sin(t),f=u*c,s=i*l+f*Math.cos(a),h=f*o*Math.sin(a);ka.add(Math.atan2(h,s)),r=n,i=l,u=c}var t,e,r,i,u;Na.point=function(o,a){Na.point=n,r=(t=o)*Yo,i=Math.cos(a=(e=a)*Yo/2+Fo/4),u=Math.sin(a)},Na.lineEnd=function(){n(t,e)}}function dt(n){var t=n[0],e=n[1],r=Math.cos(e);return[r*Math.cos(t),r*Math.sin(t),Math.sin(e)]}function yt(n,t){return n[0]*t[0]+n[1]*t[1]+n[2]*t[2]}function mt(n,t){return[n[1]*t[2]-n[2]*t[1],n[2]*t[0]-n[0]*t[2],n[0]*t[1]-n[1]*t[0]]}function Mt(n,t){n[0]+=t[0],n[1]+=t[1],n[2]+=t[2]}function xt(n,t){return[n[0]*t,n[1]*t,n[2]*t]}function bt(n){var t=Math.sqrt(n[0]*n[0]+n[1]*n[1]+n[2]*n[2]);n[0]/=t,n[1]/=t,n[2]/=t}function _t(n){return[Math.atan2(n[1],n[0]),tn(n[2])]}function wt(n,t){return xo(n[0]-t[0])<Uo&&xo(n[1]-t[1])<Uo}function St(n,t){n*=Yo;var e=Math.cos(t*=Yo);kt(e*Math.cos(n),e*Math.sin(n),Math.sin(t))}function kt(n,t,e){++Ea,Ca+=(n-Ca)/Ea,za+=(t-za)/Ea,La+=(e-La)/Ea}function Nt(){function n(n,i){n*=Yo;var u=Math.cos(i*=Yo),o=u*Math.cos(n),a=u*Math.sin(n),l=Math.sin(i),c=Math.atan2(Math.sqrt((c=e*l-r*a)*c+(c=r*o-t*l)*c+(c=t*a-e*o)*c),t*o+e*a+r*l);Aa+=c,qa+=c*(t+(t=o)),Ta+=c*(e+(e=a)),Ra+=c*(r+(r=l)),kt(t,e,r)}var t,e,r;ja.point=function(i,u){i*=Yo;var o=Math.cos(u*=Yo);t=o*Math.cos(i),e=o*Math.sin(i),r=Math.sin(u),ja.point=n,kt(t,e,r)}}function Et(){ja.point=St}function At(){function n(n,t){n*=Yo;var e=Math.cos(t*=Yo),o=e*Math.cos(n),a=e*Math.sin(n),l=Math.sin(t),c=i*l-u*a,f=u*o-r*l,s=r*a-i*o,h=Math.sqrt(c*c+f*f+s*s),p=r*o+i*a+u*l,g=h&&-nn(p)/h,v=Math.atan2(h,p);Da+=g*c,Pa+=g*f,Ua+=g*s,Aa+=v,qa+=v*(r+(r=o)),Ta+=v*(i+(i=a)),Ra+=v*(u+(u=l)),kt(r,i,u)}var t,e,r,i,u;ja.point=function(o,a){t=o,e=a,ja.point=n,o*=Yo;var l=Math.cos(a*=Yo);r=l*Math.cos(o),i=l*Math.sin(o),u=Math.sin(a),kt(r,i,u)},ja.lineEnd=function(){n(t,e),ja.lineEnd=Et,ja.point=St}}function Ct(n,t){function e(e,r){return e=n(e,r),t(e[0],e[1])}return n.invert&&t.invert&&(e.invert=function(e,r){return e=t.invert(e,r),e&&n.invert(e[0],e[1])}),e}function zt(){return!0}function Lt(n,t,e,r,i){var u=[],o=[];if(n.forEach(function(n){if(!((t=n.length-1)<=0)){var t,e=n[0],r=n[t];if(wt(e,r)){i.lineStart();for(var a=0;t>a;++a)i.point((e=n[a])[0],e[1]);return void i.lineEnd()}var l=new Tt(e,n,null,!0),c=new Tt(e,null,l,!1);l.o=c,u.push(l),o.push(c),l=new Tt(r,n,null,!1),c=new Tt(r,null,l,!0),l.o=c,u.push(l),o.push(c)}}),o.sort(t),qt(u),qt(o),u.length){for(var a=0,l=e,c=o.length;c>a;++a)o[a].e=l=!l;for(var f,s,h=u[0];;){for(var p=h,g=!0;p.v;)if((p=p.n)===h)return;f=p.z,i.lineStart();do{if(p.v=p.o.v=!0,p.e){if(g)for(var a=0,c=f.length;c>a;++a)i.point((s=f[a])[0],s[1]);else r(p.x,p.n.x,1,i);p=p.n}else{if(g){f=p.p.z;for(var a=f.length-1;a>=0;--a)i.point((s=f[a])[0],s[1])}else r(p.x,p.p.x,-1,i);p=p.p}p=p.o,f=p.z,g=!g}while(!p.v);i.lineEnd()}}}function qt(n){if(t=n.length){for(var t,e,r=0,i=n[0];++r<t;)i.n=e=n[r],e.p=i,i=e;i.n=e=n[0],e.p=i}}function Tt(n,t,e,r){this.x=n,this.z=t,this.o=e,this.e=r,this.v=!1,this.n=this.p=null}function Rt(n,t,e,r){return function(i,u){function o(t,e){var r=i(t,e);n(t=r[0],e=r[1])&&u.point(t,e)}function a(n,t){var e=i(n,t);d.point(e[0],e[1])}function l(){m.point=a,d.lineStart()}function c(){m.point=o,d.lineEnd()}function f(n,t){v.push([n,t]);var e=i(n,t);x.point(e[0],e[1])}function s(){x.lineStart(),v=[]}function h(){f(v[0][0],v[0][1]),x.lineEnd();var n,t=x.clean(),e=M.buffer(),r=e.length;if(v.pop(),g.push(v),v=null,r)if(1&t){n=e[0];var i,r=n.length-1,o=-1;if(r>0){for(b||(u.polygonStart(),b=!0),u.lineStart();++o<r;)u.point((i=n[o])[0],i[1]);u.lineEnd()}}else r>1&&2&t&&e.push(e.pop().concat(e.shift())),p.push(e.filter(Dt))}var p,g,v,d=t(u),y=i.invert(r[0],r[1]),m={point:o,lineStart:l,lineEnd:c,polygonStart:function(){m.point=f,m.lineStart=s,m.lineEnd=h,p=[],g=[]},polygonEnd:function(){m.point=o,m.lineStart=l,m.lineEnd=c,p=ao.merge(p);var n=Ot(y,g);p.length?(b||(u.polygonStart(),b=!0),Lt(p,Ut,n,e,u)):n&&(b||(u.polygonStart(),b=!0),u.lineStart(),e(null,null,1,u),u.lineEnd()),b&&(u.polygonEnd(),b=!1),p=g=null},sphere:function(){u.polygonStart(),u.lineStart(),e(null,null,1,u),u.lineEnd(),u.polygonEnd()}},M=Pt(),x=t(M),b=!1;return m}}function Dt(n){return n.length>1}function Pt(){var n,t=[];return{lineStart:function(){t.push(n=[])},point:function(t,e){n.push([t,e])},lineEnd:b,buffer:function(){var e=t;return t=[],n=null,e},rejoin:function(){t.length>1&&t.push(t.pop().concat(t.shift()))}}}function Ut(n,t){return((n=n.x)[0]<0?n[1]-Io-Uo:Io-n[1])-((t=t.x)[0]<0?t[1]-Io-Uo:Io-t[1])}function jt(n){var t,e=NaN,r=NaN,i=NaN;return{lineStart:function(){n.lineStart(),t=1},point:function(u,o){var a=u>0?Fo:-Fo,l=xo(u-e);xo(l-Fo)<Uo?(n.point(e,r=(r+o)/2>0?Io:-Io),n.point(i,r),n.lineEnd(),n.lineStart(),n.point(a,r),n.point(u,r),t=0):i!==a&&l>=Fo&&(xo(e-i)<Uo&&(e-=i*Uo),xo(u-a)<Uo&&(u-=a*Uo),r=Ft(e,r,u,o),n.point(i,r),n.lineEnd(),n.lineStart(),n.point(a,r),t=0),n.point(e=u,r=o),i=a},lineEnd:function(){n.lineEnd(),e=r=NaN},clean:function(){return 2-t}}}function Ft(n,t,e,r){var i,u,o=Math.sin(n-e);return xo(o)>Uo?Math.atan((Math.sin(t)*(u=Math.cos(r))*Math.sin(e)-Math.sin(r)*(i=Math.cos(t))*Math.sin(n))/(i*u*o)):(t+r)/2}function Ht(n,t,e,r){var i;if(null==n)i=e*Io,r.point(-Fo,i),r.point(0,i),r.point(Fo,i),r.point(Fo,0),r.point(Fo,-i),r.point(0,-i),r.point(-Fo,-i),r.point(-Fo,0),r.point(-Fo,i);else if(xo(n[0]-t[0])>Uo){var u=n[0]<t[0]?Fo:-Fo;i=e*u/2,r.point(-u,i),r.point(0,i),r.point(u,i)}else r.point(t[0],t[1])}function Ot(n,t){var e=n[0],r=n[1],i=[Math.sin(e),-Math.cos(e),0],u=0,o=0;ka.reset();for(var a=0,l=t.length;l>a;++a){var c=t[a],f=c.length;if(f)for(var s=c[0],h=s[0],p=s[1]/2+Fo/4,g=Math.sin(p),v=Math.cos(p),d=1;;){d===f&&(d=0),n=c[d];var y=n[0],m=n[1]/2+Fo/4,M=Math.sin(m),x=Math.cos(m),b=y-h,_=b>=0?1:-1,w=_*b,S=w>Fo,k=g*M;if(ka.add(Math.atan2(k*_*Math.sin(w),v*x+k*Math.cos(w))),u+=S?b+_*Ho:b,S^h>=e^y>=e){var N=mt(dt(s),dt(n));bt(N);var E=mt(i,N);bt(E);var A=(S^b>=0?-1:1)*tn(E[2]);(r>A||r===A&&(N[0]||N[1]))&&(o+=S^b>=0?1:-1)}if(!d++)break;h=y,g=M,v=x,s=n}}return(-Uo>u||Uo>u&&-Uo>ka)^1&o}function It(n){function t(n,t){return Math.cos(n)*Math.cos(t)>u}function e(n){var e,u,l,c,f;return{lineStart:function(){c=l=!1,f=1},point:function(s,h){var p,g=[s,h],v=t(s,h),d=o?v?0:i(s,h):v?i(s+(0>s?Fo:-Fo),h):0;if(!e&&(c=l=v)&&n.lineStart(),v!==l&&(p=r(e,g),(wt(e,p)||wt(g,p))&&(g[0]+=Uo,g[1]+=Uo,v=t(g[0],g[1]))),v!==l)f=0,v?(n.lineStart(),p=r(g,e),n.point(p[0],p[1])):(p=r(e,g),n.point(p[0],p[1]),n.lineEnd()),e=p;else if(a&&e&&o^v){var y;d&u||!(y=r(g,e,!0))||(f=0,o?(n.lineStart(),n.point(y[0][0],y[0][1]),n.point(y[1][0],y[1][1]),n.lineEnd()):(n.point(y[1][0],y[1][1]),n.lineEnd(),n.lineStart(),n.point(y[0][0],y[0][1])))}!v||e&&wt(e,g)||n.point(g[0],g[1]),e=g,l=v,u=d},lineEnd:function(){l&&n.lineEnd(),e=null},clean:function(){return f|(c&&l)<<1}}}function r(n,t,e){var r=dt(n),i=dt(t),o=[1,0,0],a=mt(r,i),l=yt(a,a),c=a[0],f=l-c*c;if(!f)return!e&&n;var s=u*l/f,h=-u*c/f,p=mt(o,a),g=xt(o,s),v=xt(a,h);Mt(g,v);var d=p,y=yt(g,d),m=yt(d,d),M=y*y-m*(yt(g,g)-1);if(!(0>M)){var x=Math.sqrt(M),b=xt(d,(-y-x)/m);if(Mt(b,g),b=_t(b),!e)return b;var _,w=n[0],S=t[0],k=n[1],N=t[1];w>S&&(_=w,w=S,S=_);var E=S-w,A=xo(E-Fo)<Uo,C=A||Uo>E;if(!A&&k>N&&(_=k,k=N,N=_),C?A?k+N>0^b[1]<(xo(b[0]-w)<Uo?k:N):k<=b[1]&&b[1]<=N:E>Fo^(w<=b[0]&&b[0]<=S)){var z=xt(d,(-y+x)/m);return Mt(z,g),[b,_t(z)]}}}function i(t,e){var r=o?n:Fo-n,i=0;return-r>t?i|=1:t>r&&(i|=2),-r>e?i|=4:e>r&&(i|=8),i}var u=Math.cos(n),o=u>0,a=xo(u)>Uo,l=ve(n,6*Yo);return Rt(t,e,l,o?[0,-n]:[-Fo,n-Fo])}function Yt(n,t,e,r){return function(i){var u,o=i.a,a=i.b,l=o.x,c=o.y,f=a.x,s=a.y,h=0,p=1,g=f-l,v=s-c;if(u=n-l,g||!(u>0)){if(u/=g,0>g){if(h>u)return;p>u&&(p=u)}else if(g>0){if(u>p)return;u>h&&(h=u)}if(u=e-l,g||!(0>u)){if(u/=g,0>g){if(u>p)return;u>h&&(h=u)}else if(g>0){if(h>u)return;p>u&&(p=u)}if(u=t-c,v||!(u>0)){if(u/=v,0>v){if(h>u)return;p>u&&(p=u)}else if(v>0){if(u>p)return;u>h&&(h=u)}if(u=r-c,v||!(0>u)){if(u/=v,0>v){if(u>p)return;u>h&&(h=u)}else if(v>0){if(h>u)return;p>u&&(p=u)}return h>0&&(i.a={x:l+h*g,y:c+h*v}),1>p&&(i.b={x:l+p*g,y:c+p*v}),i}}}}}}function Zt(n,t,e,r){function i(r,i){return xo(r[0]-n)<Uo?i>0?0:3:xo(r[0]-e)<Uo?i>0?2:1:xo(r[1]-t)<Uo?i>0?1:0:i>0?3:2}function u(n,t){return o(n.x,t.x)}function o(n,t){var e=i(n,1),r=i(t,1);return e!==r?e-r:0===e?t[1]-n[1]:1===e?n[0]-t[0]:2===e?n[1]-t[1]:t[0]-n[0]}return function(a){function l(n){for(var t=0,e=d.length,r=n[1],i=0;e>i;++i)for(var u,o=1,a=d[i],l=a.length,c=a[0];l>o;++o)u=a[o],c[1]<=r?u[1]>r&&Q(c,u,n)>0&&++t:u[1]<=r&&Q(c,u,n)<0&&--t,c=u;return 0!==t}function c(u,a,l,c){var f=0,s=0;if(null==u||(f=i(u,l))!==(s=i(a,l))||o(u,a)<0^l>0){do c.point(0===f||3===f?n:e,f>1?r:t);while((f=(f+l+4)%4)!==s)}else c.point(a[0],a[1])}function f(i,u){return i>=n&&e>=i&&u>=t&&r>=u}function s(n,t){f(n,t)&&a.point(n,t)}function h(){C.point=g,d&&d.push(y=[]),S=!0,w=!1,b=_=NaN}function p(){v&&(g(m,M),x&&w&&E.rejoin(),v.push(E.buffer())),C.point=s,w&&a.lineEnd()}function g(n,t){n=Math.max(-Ha,Math.min(Ha,n)),t=Math.max(-Ha,Math.min(Ha,t));var e=f(n,t);if(d&&y.push([n,t]),S)m=n,M=t,x=e,S=!1,e&&(a.lineStart(),a.point(n,t));else if(e&&w)a.point(n,t);else{var r={a:{x:b,y:_},b:{x:n,y:t}};A(r)?(w||(a.lineStart(),a.point(r.a.x,r.a.y)),a.point(r.b.x,r.b.y),e||a.lineEnd(),k=!1):e&&(a.lineStart(),a.point(n,t),k=!1)}b=n,_=t,w=e}var v,d,y,m,M,x,b,_,w,S,k,N=a,E=Pt(),A=Yt(n,t,e,r),C={point:s,lineStart:h,lineEnd:p,polygonStart:function(){a=E,v=[],d=[],k=!0},polygonEnd:function(){a=N,v=ao.merge(v);var t=l([n,r]),e=k&&t,i=v.length;(e||i)&&(a.polygonStart(),e&&(a.lineStart(),c(null,null,1,a),a.lineEnd()),i&&Lt(v,u,t,c,a),a.polygonEnd()),v=d=y=null}};return C}}function Vt(n){var t=0,e=Fo/3,r=ae(n),i=r(t,e);return i.parallels=function(n){return arguments.length?r(t=n[0]*Fo/180,e=n[1]*Fo/180):[t/Fo*180,e/Fo*180]},i}function Xt(n,t){function e(n,t){var e=Math.sqrt(u-2*i*Math.sin(t))/i;return[e*Math.sin(n*=i),o-e*Math.cos(n)]}var r=Math.sin(n),i=(r+Math.sin(t))/2,u=1+r*(2*i-r),o=Math.sqrt(u)/i;return e.invert=function(n,t){var e=o-t;return[Math.atan2(n,e)/i,tn((u-(n*n+e*e)*i*i)/(2*i))]},e}function $t(){function n(n,t){Ia+=i*n-r*t,r=n,i=t}var t,e,r,i;$a.point=function(u,o){$a.point=n,t=r=u,e=i=o},$a.lineEnd=function(){n(t,e)}}function Bt(n,t){Ya>n&&(Ya=n),n>Va&&(Va=n),Za>t&&(Za=t),t>Xa&&(Xa=t)}function Wt(){function n(n,t){o.push("M",n,",",t,u)}function t(n,t){o.push("M",n,",",t),a.point=e}function e(n,t){o.push("L",n,",",t)}function r(){a.point=n}function i(){o.push("Z")}var u=Jt(4.5),o=[],a={point:n,lineStart:function(){a.point=t},lineEnd:r,polygonStart:function(){a.lineEnd=i},polygonEnd:function(){a.lineEnd=r,a.point=n},pointRadius:function(n){return u=Jt(n),a},result:function(){if(o.length){var n=o.join("");return o=[],n}}};return a}function Jt(n){return"m0,"+n+"a"+n+","+n+" 0 1,1 0,"+-2*n+"a"+n+","+n+" 0 1,1 0,"+2*n+"z"}function Gt(n,t){Ca+=n,za+=t,++La}function Kt(){function n(n,r){var i=n-t,u=r-e,o=Math.sqrt(i*i+u*u);qa+=o*(t+n)/2,Ta+=o*(e+r)/2,Ra+=o,Gt(t=n,e=r)}var t,e;Wa.point=function(r,i){Wa.point=n,Gt(t=r,e=i)}}function Qt(){Wa.point=Gt}function ne(){function n(n,t){var e=n-r,u=t-i,o=Math.sqrt(e*e+u*u);qa+=o*(r+n)/2,Ta+=o*(i+t)/2,Ra+=o,o=i*n-r*t,Da+=o*(r+n),Pa+=o*(i+t),Ua+=3*o,Gt(r=n,i=t)}var t,e,r,i;Wa.point=function(u,o){Wa.point=n,Gt(t=r=u,e=i=o)},Wa.lineEnd=function(){n(t,e)}}function te(n){function t(t,e){n.moveTo(t+o,e),n.arc(t,e,o,0,Ho)}function e(t,e){n.moveTo(t,e),a.point=r}function r(t,e){n.lineTo(t,e)}function i(){a.point=t}function u(){n.closePath()}var o=4.5,a={point:t,lineStart:function(){a.point=e},lineEnd:i,polygonStart:function(){a.lineEnd=u},polygonEnd:function(){a.lineEnd=i,a.point=t},pointRadius:function(n){return o=n,a},result:b};return a}function ee(n){function t(n){return(a?r:e)(n)}function e(t){return ue(t,function(e,r){e=n(e,r),t.point(e[0],e[1])})}function r(t){function e(e,r){e=n(e,r),t.point(e[0],e[1])}function r(){M=NaN,S.point=u,t.lineStart()}function u(e,r){var u=dt([e,r]),o=n(e,r);i(M,x,m,b,_,w,M=o[0],x=o[1],m=e,b=u[0],_=u[1],w=u[2],a,t),t.point(M,x)}function o(){S.point=e,t.lineEnd()}function l(){

- r(),S.point=c,S.lineEnd=f}function c(n,t){u(s=n,h=t),p=M,g=x,v=b,d=_,y=w,S.point=u}function f(){i(M,x,m,b,_,w,p,g,s,v,d,y,a,t),S.lineEnd=o,o()}var s,h,p,g,v,d,y,m,M,x,b,_,w,S={point:e,lineStart:r,lineEnd:o,polygonStart:function(){t.polygonStart(),S.lineStart=l},polygonEnd:function(){t.polygonEnd(),S.lineStart=r}};return S}function i(t,e,r,a,l,c,f,s,h,p,g,v,d,y){var m=f-t,M=s-e,x=m*m+M*M;if(x>4*u&&d--){var b=a+p,_=l+g,w=c+v,S=Math.sqrt(b*b+_*_+w*w),k=Math.asin(w/=S),N=xo(xo(w)-1)<Uo||xo(r-h)<Uo?(r+h)/2:Math.atan2(_,b),E=n(N,k),A=E[0],C=E[1],z=A-t,L=C-e,q=M*z-m*L;(q*q/x>u||xo((m*z+M*L)/x-.5)>.3||o>a*p+l*g+c*v)&&(i(t,e,r,a,l,c,A,C,N,b/=S,_/=S,w,d,y),y.point(A,C),i(A,C,N,b,_,w,f,s,h,p,g,v,d,y))}}var u=.5,o=Math.cos(30*Yo),a=16;return t.precision=function(n){return arguments.length?(a=(u=n*n)>0&&16,t):Math.sqrt(u)},t}function re(n){var t=ee(function(t,e){return n([t*Zo,e*Zo])});return function(n){return le(t(n))}}function ie(n){this.stream=n}function ue(n,t){return{point:t,sphere:function(){n.sphere()},lineStart:function(){n.lineStart()},lineEnd:function(){n.lineEnd()},polygonStart:function(){n.polygonStart()},polygonEnd:function(){n.polygonEnd()}}}function oe(n){return ae(function(){return n})()}function ae(n){function t(n){return n=a(n[0]*Yo,n[1]*Yo),[n[0]*h+l,c-n[1]*h]}function e(n){return n=a.invert((n[0]-l)/h,(c-n[1])/h),n&&[n[0]*Zo,n[1]*Zo]}function r(){a=Ct(o=se(y,M,x),u);var n=u(v,d);return l=p-n[0]*h,c=g+n[1]*h,i()}function i(){return f&&(f.valid=!1,f=null),t}var u,o,a,l,c,f,s=ee(function(n,t){return n=u(n,t),[n[0]*h+l,c-n[1]*h]}),h=150,p=480,g=250,v=0,d=0,y=0,M=0,x=0,b=Fa,_=m,w=null,S=null;return t.stream=function(n){return f&&(f.valid=!1),f=le(b(o,s(_(n)))),f.valid=!0,f},t.clipAngle=function(n){return arguments.length?(b=null==n?(w=n,Fa):It((w=+n)*Yo),i()):w},t.clipExtent=function(n){return arguments.length?(S=n,_=n?Zt(n[0][0],n[0][1],n[1][0],n[1][1]):m,i()):S},t.scale=function(n){return arguments.length?(h=+n,r()):h},t.translate=function(n){return arguments.length?(p=+n[0],g=+n[1],r()):[p,g]},t.center=function(n){return arguments.length?(v=n[0]%360*Yo,d=n[1]%360*Yo,r()):[v*Zo,d*Zo]},t.rotate=function(n){return arguments.length?(y=n[0]%360*Yo,M=n[1]%360*Yo,x=n.length>2?n[2]%360*Yo:0,r()):[y*Zo,M*Zo,x*Zo]},ao.rebind(t,s,"precision"),function(){return u=n.apply(this,arguments),t.invert=u.invert&&e,r()}}function le(n){return ue(n,function(t,e){n.point(t*Yo,e*Yo)})}function ce(n,t){return[n,t]}function fe(n,t){return[n>Fo?n-Ho:-Fo>n?n+Ho:n,t]}function se(n,t,e){return n?t||e?Ct(pe(n),ge(t,e)):pe(n):t||e?ge(t,e):fe}function he(n){return function(t,e){return t+=n,[t>Fo?t-Ho:-Fo>t?t+Ho:t,e]}}function pe(n){var t=he(n);return t.invert=he(-n),t}function ge(n,t){function e(n,t){var e=Math.cos(t),a=Math.cos(n)*e,l=Math.sin(n)*e,c=Math.sin(t),f=c*r+a*i;return[Math.atan2(l*u-f*o,a*r-c*i),tn(f*u+l*o)]}var r=Math.cos(n),i=Math.sin(n),u=Math.cos(t),o=Math.sin(t);return e.invert=function(n,t){var e=Math.cos(t),a=Math.cos(n)*e,l=Math.sin(n)*e,c=Math.sin(t),f=c*u-l*o;return[Math.atan2(l*u+c*o,a*r+f*i),tn(f*r-a*i)]},e}function ve(n,t){var e=Math.cos(n),r=Math.sin(n);return function(i,u,o,a){var l=o*t;null!=i?(i=de(e,i),u=de(e,u),(o>0?u>i:i>u)&&(i+=o*Ho)):(i=n+o*Ho,u=n-.5*l);for(var c,f=i;o>0?f>u:u>f;f-=l)a.point((c=_t([e,-r*Math.cos(f),-r*Math.sin(f)]))[0],c[1])}}function de(n,t){var e=dt(t);e[0]-=n,bt(e);var r=nn(-e[1]);return((-e[2]<0?-r:r)+2*Math.PI-Uo)%(2*Math.PI)}function ye(n,t,e){var r=ao.range(n,t-Uo,e).concat(t);return function(n){return r.map(function(t){return[n,t]})}}function me(n,t,e){var r=ao.range(n,t-Uo,e).concat(t);return function(n){return r.map(function(t){return[t,n]})}}function Me(n){return n.source}function xe(n){return n.target}function be(n,t,e,r){var i=Math.cos(t),u=Math.sin(t),o=Math.cos(r),a=Math.sin(r),l=i*Math.cos(n),c=i*Math.sin(n),f=o*Math.cos(e),s=o*Math.sin(e),h=2*Math.asin(Math.sqrt(on(r-t)+i*o*on(e-n))),p=1/Math.sin(h),g=h?function(n){var t=Math.sin(n*=h)*p,e=Math.sin(h-n)*p,r=e*l+t*f,i=e*c+t*s,o=e*u+t*a;return[Math.atan2(i,r)*Zo,Math.atan2(o,Math.sqrt(r*r+i*i))*Zo]}:function(){return[n*Zo,t*Zo]};return g.distance=h,g}function _e(){function n(n,i){var u=Math.sin(i*=Yo),o=Math.cos(i),a=xo((n*=Yo)-t),l=Math.cos(a);Ja+=Math.atan2(Math.sqrt((a=o*Math.sin(a))*a+(a=r*u-e*o*l)*a),e*u+r*o*l),t=n,e=u,r=o}var t,e,r;Ga.point=function(i,u){t=i*Yo,e=Math.sin(u*=Yo),r=Math.cos(u),Ga.point=n},Ga.lineEnd=function(){Ga.point=Ga.lineEnd=b}}function we(n,t){function e(t,e){var r=Math.cos(t),i=Math.cos(e),u=n(r*i);return[u*i*Math.sin(t),u*Math.sin(e)]}return e.invert=function(n,e){var r=Math.sqrt(n*n+e*e),i=t(r),u=Math.sin(i),o=Math.cos(i);return[Math.atan2(n*u,r*o),Math.asin(r&&e*u/r)]},e}function Se(n,t){function e(n,t){o>0?-Io+Uo>t&&(t=-Io+Uo):t>Io-Uo&&(t=Io-Uo);var e=o/Math.pow(i(t),u);return[e*Math.sin(u*n),o-e*Math.cos(u*n)]}var r=Math.cos(n),i=function(n){return Math.tan(Fo/4+n/2)},u=n===t?Math.sin(n):Math.log(r/Math.cos(t))/Math.log(i(t)/i(n)),o=r*Math.pow(i(n),u)/u;return u?(e.invert=function(n,t){var e=o-t,r=K(u)*Math.sqrt(n*n+e*e);return[Math.atan2(n,e)/u,2*Math.atan(Math.pow(o/r,1/u))-Io]},e):Ne}function ke(n,t){function e(n,t){var e=u-t;return[e*Math.sin(i*n),u-e*Math.cos(i*n)]}var r=Math.cos(n),i=n===t?Math.sin(n):(r-Math.cos(t))/(t-n),u=r/i+n;return xo(i)<Uo?ce:(e.invert=function(n,t){var e=u-t;return[Math.atan2(n,e)/i,u-K(i)*Math.sqrt(n*n+e*e)]},e)}function Ne(n,t){return[n,Math.log(Math.tan(Fo/4+t/2))]}function Ee(n){var t,e=oe(n),r=e.scale,i=e.translate,u=e.clipExtent;return e.scale=function(){var n=r.apply(e,arguments);return n===e?t?e.clipExtent(null):e:n},e.translate=function(){var n=i.apply(e,arguments);return n===e?t?e.clipExtent(null):e:n},e.clipExtent=function(n){var o=u.apply(e,arguments);if(o===e){if(t=null==n){var a=Fo*r(),l=i();u([[l[0]-a,l[1]-a],[l[0]+a,l[1]+a]])}}else t&&(o=null);return o},e.clipExtent(null)}function Ae(n,t){return[Math.log(Math.tan(Fo/4+t/2)),-n]}function Ce(n){return n[0]}function ze(n){return n[1]}function Le(n){for(var t=n.length,e=[0,1],r=2,i=2;t>i;i++){for(;r>1&&Q(n[e[r-2]],n[e[r-1]],n[i])<=0;)--r;e[r++]=i}return e.slice(0,r)}function qe(n,t){return n[0]-t[0]||n[1]-t[1]}function Te(n,t,e){return(e[0]-t[0])*(n[1]-t[1])<(e[1]-t[1])*(n[0]-t[0])}function Re(n,t,e,r){var i=n[0],u=e[0],o=t[0]-i,a=r[0]-u,l=n[1],c=e[1],f=t[1]-l,s=r[1]-c,h=(a*(l-c)-s*(i-u))/(s*o-a*f);return[i+h*o,l+h*f]}function De(n){var t=n[0],e=n[n.length-1];return!(t[0]-e[0]||t[1]-e[1])}function Pe(){rr(this),this.edge=this.site=this.circle=null}function Ue(n){var t=cl.pop()||new Pe;return t.site=n,t}function je(n){Be(n),ol.remove(n),cl.push(n),rr(n)}function Fe(n){var t=n.circle,e=t.x,r=t.cy,i={x:e,y:r},u=n.P,o=n.N,a=[n];je(n);for(var l=u;l.circle&&xo(e-l.circle.x)<Uo&&xo(r-l.circle.cy)<Uo;)u=l.P,a.unshift(l),je(l),l=u;a.unshift(l),Be(l);for(var c=o;c.circle&&xo(e-c.circle.x)<Uo&&xo(r-c.circle.cy)<Uo;)o=c.N,a.push(c),je(c),c=o;a.push(c),Be(c);var f,s=a.length;for(f=1;s>f;++f)c=a[f],l=a[f-1],nr(c.edge,l.site,c.site,i);l=a[0],c=a[s-1],c.edge=Ke(l.site,c.site,null,i),$e(l),$e(c)}function He(n){for(var t,e,r,i,u=n.x,o=n.y,a=ol._;a;)if(r=Oe(a,o)-u,r>Uo)a=a.L;else{if(i=u-Ie(a,o),!(i>Uo)){r>-Uo?(t=a.P,e=a):i>-Uo?(t=a,e=a.N):t=e=a;break}if(!a.R){t=a;break}a=a.R}var l=Ue(n);if(ol.insert(t,l),t||e){if(t===e)return Be(t),e=Ue(t.site),ol.insert(l,e),l.edge=e.edge=Ke(t.site,l.site),$e(t),void $e(e);if(!e)return void(l.edge=Ke(t.site,l.site));Be(t),Be(e);var c=t.site,f=c.x,s=c.y,h=n.x-f,p=n.y-s,g=e.site,v=g.x-f,d=g.y-s,y=2*(h*d-p*v),m=h*h+p*p,M=v*v+d*d,x={x:(d*m-p*M)/y+f,y:(h*M-v*m)/y+s};nr(e.edge,c,g,x),l.edge=Ke(c,n,null,x),e.edge=Ke(n,g,null,x),$e(t),$e(e)}}function Oe(n,t){var e=n.site,r=e.x,i=e.y,u=i-t;if(!u)return r;var o=n.P;if(!o)return-(1/0);e=o.site;var a=e.x,l=e.y,c=l-t;if(!c)return a;var f=a-r,s=1/u-1/c,h=f/c;return s?(-h+Math.sqrt(h*h-2*s*(f*f/(-2*c)-l+c/2+i-u/2)))/s+r:(r+a)/2}function Ie(n,t){var e=n.N;if(e)return Oe(e,t);var r=n.site;return r.y===t?r.x:1/0}function Ye(n){this.site=n,this.edges=[]}function Ze(n){for(var t,e,r,i,u,o,a,l,c,f,s=n[0][0],h=n[1][0],p=n[0][1],g=n[1][1],v=ul,d=v.length;d--;)if(u=v[d],u&&u.prepare())for(a=u.edges,l=a.length,o=0;l>o;)f=a[o].end(),r=f.x,i=f.y,c=a[++o%l].start(),t=c.x,e=c.y,(xo(r-t)>Uo||xo(i-e)>Uo)&&(a.splice(o,0,new tr(Qe(u.site,f,xo(r-s)<Uo&&g-i>Uo?{x:s,y:xo(t-s)<Uo?e:g}:xo(i-g)<Uo&&h-r>Uo?{x:xo(e-g)<Uo?t:h,y:g}:xo(r-h)<Uo&&i-p>Uo?{x:h,y:xo(t-h)<Uo?e:p}:xo(i-p)<Uo&&r-s>Uo?{x:xo(e-p)<Uo?t:s,y:p}:null),u.site,null)),++l)}function Ve(n,t){return t.angle-n.angle}function Xe(){rr(this),this.x=this.y=this.arc=this.site=this.cy=null}function $e(n){var t=n.P,e=n.N;if(t&&e){var r=t.site,i=n.site,u=e.site;if(r!==u){var o=i.x,a=i.y,l=r.x-o,c=r.y-a,f=u.x-o,s=u.y-a,h=2*(l*s-c*f);if(!(h>=-jo)){var p=l*l+c*c,g=f*f+s*s,v=(s*p-c*g)/h,d=(l*g-f*p)/h,s=d+a,y=fl.pop()||new Xe;y.arc=n,y.site=i,y.x=v+o,y.y=s+Math.sqrt(v*v+d*d),y.cy=s,n.circle=y;for(var m=null,M=ll._;M;)if(y.y<M.y||y.y===M.y&&y.x<=M.x){if(!M.L){m=M.P;break}M=M.L}else{if(!M.R){m=M;break}M=M.R}ll.insert(m,y),m||(al=y)}}}}function Be(n){var t=n.circle;t&&(t.P||(al=t.N),ll.remove(t),fl.push(t),rr(t),n.circle=null)}function We(n){for(var t,e=il,r=Yt(n[0][0],n[0][1],n[1][0],n[1][1]),i=e.length;i--;)t=e[i],(!Je(t,n)||!r(t)||xo(t.a.x-t.b.x)<Uo&&xo(t.a.y-t.b.y)<Uo)&&(t.a=t.b=null,e.splice(i,1))}function Je(n,t){var e=n.b;if(e)return!0;var r,i,u=n.a,o=t[0][0],a=t[1][0],l=t[0][1],c=t[1][1],f=n.l,s=n.r,h=f.x,p=f.y,g=s.x,v=s.y,d=(h+g)/2,y=(p+v)/2;if(v===p){if(o>d||d>=a)return;if(h>g){if(u){if(u.y>=c)return}else u={x:d,y:l};e={x:d,y:c}}else{if(u){if(u.y<l)return}else u={x:d,y:c};e={x:d,y:l}}}else if(r=(h-g)/(v-p),i=y-r*d,-1>r||r>1)if(h>g){if(u){if(u.y>=c)return}else u={x:(l-i)/r,y:l};e={x:(c-i)/r,y:c}}else{if(u){if(u.y<l)return}else u={x:(c-i)/r,y:c};e={x:(l-i)/r,y:l}}else if(v>p){if(u){if(u.x>=a)return}else u={x:o,y:r*o+i};e={x:a,y:r*a+i}}else{if(u){if(u.x<o)return}else u={x:a,y:r*a+i};e={x:o,y:r*o+i}}return n.a=u,n.b=e,!0}function Ge(n,t){this.l=n,this.r=t,this.a=this.b=null}function Ke(n,t,e,r){var i=new Ge(n,t);return il.push(i),e&&nr(i,n,t,e),r&&nr(i,t,n,r),ul[n.i].edges.push(new tr(i,n,t)),ul[t.i].edges.push(new tr(i,t,n)),i}function Qe(n,t,e){var r=new Ge(n,null);return r.a=t,r.b=e,il.push(r),r}function nr(n,t,e,r){n.a||n.b?n.l===e?n.b=r:n.a=r:(n.a=r,n.l=t,n.r=e)}function tr(n,t,e){var r=n.a,i=n.b;this.edge=n,this.site=t,this.angle=e?Math.atan2(e.y-t.y,e.x-t.x):n.l===t?Math.atan2(i.x-r.x,r.y-i.y):Math.atan2(r.x-i.x,i.y-r.y)}function er(){this._=null}function rr(n){n.U=n.C=n.L=n.R=n.P=n.N=null}function ir(n,t){var e=t,r=t.R,i=e.U;i?i.L===e?i.L=r:i.R=r:n._=r,r.U=i,e.U=r,e.R=r.L,e.R&&(e.R.U=e),r.L=e}function ur(n,t){var e=t,r=t.L,i=e.U;i?i.L===e?i.L=r:i.R=r:n._=r,r.U=i,e.U=r,e.L=r.R,e.L&&(e.L.U=e),r.R=e}function or(n){for(;n.L;)n=n.L;return n}function ar(n,t){var e,r,i,u=n.sort(lr).pop();for(il=[],ul=new Array(n.length),ol=new er,ll=new er;;)if(i=al,u&&(!i||u.y<i.y||u.y===i.y&&u.x<i.x))u.x===e&&u.y===r||(ul[u.i]=new Ye(u),He(u),e=u.x,r=u.y),u=n.pop();else{if(!i)break;Fe(i.arc)}t&&(We(t),Ze(t));var o={cells:ul,edges:il};return ol=ll=il=ul=null,o}function lr(n,t){return t.y-n.y||t.x-n.x}function cr(n,t,e){return(n.x-e.x)*(t.y-n.y)-(n.x-t.x)*(e.y-n.y)}function fr(n){return n.x}function sr(n){return n.y}function hr(){return{leaf:!0,nodes:[],point:null,x:null,y:null}}function pr(n,t,e,r,i,u){if(!n(t,e,r,i,u)){var o=.5*(e+i),a=.5*(r+u),l=t.nodes;l[0]&&pr(n,l[0],e,r,o,a),l[1]&&pr(n,l[1],o,r,i,a),l[2]&&pr(n,l[2],e,a,o,u),l[3]&&pr(n,l[3],o,a,i,u)}}function gr(n,t,e,r,i,u,o){var a,l=1/0;return function c(n,f,s,h,p){if(!(f>u||s>o||r>h||i>p)){if(g=n.point){var g,v=t-n.x,d=e-n.y,y=v*v+d*d;if(l>y){var m=Math.sqrt(l=y);r=t-m,i=e-m,u=t+m,o=e+m,a=g}}for(var M=n.nodes,x=.5*(f+h),b=.5*(s+p),_=t>=x,w=e>=b,S=w<<1|_,k=S+4;k>S;++S)if(n=M[3&S])switch(3&S){case 0:c(n,f,s,x,b);break;case 1:c(n,x,s,h,b);break;case 2:c(n,f,b,x,p);break;case 3:c(n,x,b,h,p)}}}(n,r,i,u,o),a}function vr(n,t){n=ao.rgb(n),t=ao.rgb(t);var e=n.r,r=n.g,i=n.b,u=t.r-e,o=t.g-r,a=t.b-i;return function(n){return"#"+bn(Math.round(e+u*n))+bn(Math.round(r+o*n))+bn(Math.round(i+a*n))}}function dr(n,t){var e,r={},i={};for(e in n)e in t?r[e]=Mr(n[e],t[e]):i[e]=n[e];for(e in t)e in n||(i[e]=t[e]);return function(n){for(e in r)i[e]=r[e](n);return i}}function yr(n,t){return n=+n,t=+t,function(e){return n*(1-e)+t*e}}function mr(n,t){var e,r,i,u=hl.lastIndex=pl.lastIndex=0,o=-1,a=[],l=[];for(n+="",t+="";(e=hl.exec(n))&&(r=pl.exec(t));)(i=r.index)>u&&(i=t.slice(u,i),a[o]?a[o]+=i:a[++o]=i),(e=e[0])===(r=r[0])?a[o]?a[o]+=r:a[++o]=r:(a[++o]=null,l.push({i:o,x:yr(e,r)})),u=pl.lastIndex;return u<t.length&&(i=t.slice(u),a[o]?a[o]+=i:a[++o]=i),a.length<2?l[0]?(t=l[0].x,function(n){return t(n)+""}):function(){return t}:(t=l.length,function(n){for(var e,r=0;t>r;++r)a[(e=l[r]).i]=e.x(n);return a.join("")})}function Mr(n,t){for(var e,r=ao.interpolators.length;--r>=0&&!(e=ao.interpolators[r](n,t)););return e}function xr(n,t){var e,r=[],i=[],u=n.length,o=t.length,a=Math.min(n.length,t.length);for(e=0;a>e;++e)r.push(Mr(n[e],t[e]));for(;u>e;++e)i[e]=n[e];for(;o>e;++e)i[e]=t[e];return function(n){for(e=0;a>e;++e)i[e]=r[e](n);return i}}function br(n){return function(t){return 0>=t?0:t>=1?1:n(t)}}function _r(n){return function(t){return 1-n(1-t)}}function wr(n){return function(t){return.5*(.5>t?n(2*t):2-n(2-2*t))}}function Sr(n){return n*n}function kr(n){return n*n*n}function Nr(n){if(0>=n)return 0;if(n>=1)return 1;var t=n*n,e=t*n;return 4*(.5>n?e:3*(n-t)+e-.75)}function Er(n){return function(t){return Math.pow(t,n)}}function Ar(n){return 1-Math.cos(n*Io)}function Cr(n){return Math.pow(2,10*(n-1))}function zr(n){return 1-Math.sqrt(1-n*n)}function Lr(n,t){var e;return arguments.length<2&&(t=.45),arguments.length?e=t/Ho*Math.asin(1/n):(n=1,e=t/4),function(r){return 1+n*Math.pow(2,-10*r)*Math.sin((r-e)*Ho/t)}}function qr(n){return n||(n=1.70158),function(t){return t*t*((n+1)*t-n)}}function Tr(n){return 1/2.75>n?7.5625*n*n:2/2.75>n?7.5625*(n-=1.5/2.75)*n+.75:2.5/2.75>n?7.5625*(n-=2.25/2.75)*n+.9375:7.5625*(n-=2.625/2.75)*n+.984375}function Rr(n,t){n=ao.hcl(n),t=ao.hcl(t);var e=n.h,r=n.c,i=n.l,u=t.h-e,o=t.c-r,a=t.l-i;return isNaN(o)&&(o=0,r=isNaN(r)?t.c:r),isNaN(u)?(u=0,e=isNaN(e)?t.h:e):u>180?u-=360:-180>u&&(u+=360),function(n){return sn(e+u*n,r+o*n,i+a*n)+""}}function Dr(n,t){n=ao.hsl(n),t=ao.hsl(t);var e=n.h,r=n.s,i=n.l,u=t.h-e,o=t.s-r,a=t.l-i;return isNaN(o)&&(o=0,r=isNaN(r)?t.s:r),isNaN(u)?(u=0,e=isNaN(e)?t.h:e):u>180?u-=360:-180>u&&(u+=360),function(n){return cn(e+u*n,r+o*n,i+a*n)+""}}function Pr(n,t){n=ao.lab(n),t=ao.lab(t);var e=n.l,r=n.a,i=n.b,u=t.l-e,o=t.a-r,a=t.b-i;return function(n){return pn(e+u*n,r+o*n,i+a*n)+""}}function Ur(n,t){return t-=n,function(e){return Math.round(n+t*e)}}function jr(n){var t=[n.a,n.b],e=[n.c,n.d],r=Hr(t),i=Fr(t,e),u=Hr(Or(e,t,-i))||0;t[0]*e[1]<e[0]*t[1]&&(t[0]*=-1,t[1]*=-1,r*=-1,i*=-1),this.rotate=(r?Math.atan2(t[1],t[0]):Math.atan2(-e[0],e[1]))*Zo,this.translate=[n.e,n.f],this.scale=[r,u],this.skew=u?Math.atan2(i,u)*Zo:0}function Fr(n,t){return n[0]*t[0]+n[1]*t[1]}function Hr(n){var t=Math.sqrt(Fr(n,n));return t&&(n[0]/=t,n[1]/=t),t}function Or(n,t,e){return n[0]+=e*t[0],n[1]+=e*t[1],n}function Ir(n){return n.length?n.pop()+",":""}function Yr(n,t,e,r){if(n[0]!==t[0]||n[1]!==t[1]){var i=e.push("translate(",null,",",null,")");r.push({i:i-4,x:yr(n[0],t[0])},{i:i-2,x:yr(n[1],t[1])})}else(t[0]||t[1])&&e.push("translate("+t+")")}function Zr(n,t,e,r){n!==t?(n-t>180?t+=360:t-n>180&&(n+=360),r.push({i:e.push(Ir(e)+"rotate(",null,")")-2,x:yr(n,t)})):t&&e.push(Ir(e)+"rotate("+t+")")}function Vr(n,t,e,r){n!==t?r.push({i:e.push(Ir(e)+"skewX(",null,")")-2,x:yr(n,t)}):t&&e.push(Ir(e)+"skewX("+t+")")}function Xr(n,t,e,r){if(n[0]!==t[0]||n[1]!==t[1]){var i=e.push(Ir(e)+"scale(",null,",",null,")");r.push({i:i-4,x:yr(n[0],t[0])},{i:i-2,x:yr(n[1],t[1])})}else 1===t[0]&&1===t[1]||e.push(Ir(e)+"scale("+t+")")}function $r(n,t){var e=[],r=[];return n=ao.transform(n),t=ao.transform(t),Yr(n.translate,t.translate,e,r),Zr(n.rotate,t.rotate,e,r),Vr(n.skew,t.skew,e,r),Xr(n.scale,t.scale,e,r),n=t=null,function(n){for(var t,i=-1,u=r.length;++i<u;)e[(t=r[i]).i]=t.x(n);return e.join("")}}function Br(n,t){return t=(t-=n=+n)||1/t,function(e){return(e-n)/t}}function Wr(n,t){return t=(t-=n=+n)||1/t,function(e){return Math.max(0,Math.min(1,(e-n)/t))}}function Jr(n){for(var t=n.source,e=n.target,r=Kr(t,e),i=[t];t!==r;)t=t.parent,i.push(t);for(var u=i.length;e!==r;)i.splice(u,0,e),e=e.parent;return i}function Gr(n){for(var t=[],e=n.parent;null!=e;)t.push(n),n=e,e=e.parent;return t.push(n),t}function Kr(n,t){if(n===t)return n;for(var e=Gr(n),r=Gr(t),i=e.pop(),u=r.pop(),o=null;i===u;)o=i,i=e.pop(),u=r.pop();return o}function Qr(n){n.fixed|=2}function ni(n){n.fixed&=-7}function ti(n){n.fixed|=4,n.px=n.x,n.py=n.y}function ei(n){n.fixed&=-5}function ri(n,t,e){var r=0,i=0;if(n.charge=0,!n.leaf)for(var u,o=n.nodes,a=o.length,l=-1;++l<a;)u=o[l],null!=u&&(ri(u,t,e),n.charge+=u.charge,r+=u.charge*u.cx,i+=u.charge*u.cy);if(n.point){n.leaf||(n.point.x+=Math.random()-.5,n.point.y+=Math.random()-.5);var c=t*e[n.point.index];n.charge+=n.pointCharge=c,r+=c*n.point.x,i+=c*n.point.y}n.cx=r/n.charge,n.cy=i/n.charge}function ii(n,t){return ao.rebind(n,t,"sort","children","value"),n.nodes=n,n.links=fi,n}function ui(n,t){for(var e=[n];null!=(n=e.pop());)if(t(n),(i=n.children)&&(r=i.length))for(var r,i;--r>=0;)e.push(i[r])}function oi(n,t){for(var e=[n],r=[];null!=(n=e.pop());)if(r.push(n),(u=n.children)&&(i=u.length))for(var i,u,o=-1;++o<i;)e.push(u[o]);for(;null!=(n=r.pop());)t(n)}function ai(n){return n.children}function li(n){return n.value}function ci(n,t){return t.value-n.value}function fi(n){return ao.merge(n.map(function(n){return(n.children||[]).map(function(t){return{source:n,target:t}})}))}function si(n){return n.x}function hi(n){return n.y}function pi(n,t,e){n.y0=t,n.y=e}function gi(n){return ao.range(n.length)}function vi(n){for(var t=-1,e=n[0].length,r=[];++t<e;)r[t]=0;return r}function di(n){for(var t,e=1,r=0,i=n[0][1],u=n.length;u>e;++e)(t=n[e][1])>i&&(r=e,i=t);return r}function yi(n){return n.reduce(mi,0)}function mi(n,t){return n+t[1]}function Mi(n,t){return xi(n,Math.ceil(Math.log(t.length)/Math.LN2+1))}function xi(n,t){for(var e=-1,r=+n[0],i=(n[1]-r)/t,u=[];++e<=t;)u[e]=i*e+r;return u}function bi(n){return[ao.min(n),ao.max(n)]}function _i(n,t){return n.value-t.value}function wi(n,t){var e=n._pack_next;n._pack_next=t,t._pack_prev=n,t._pack_next=e,e._pack_prev=t}function Si(n,t){n._pack_next=t,t._pack_prev=n}function ki(n,t){var e=t.x-n.x,r=t.y-n.y,i=n.r+t.r;return.999*i*i>e*e+r*r}function Ni(n){function t(n){f=Math.min(n.x-n.r,f),s=Math.max(n.x+n.r,s),h=Math.min(n.y-n.r,h),p=Math.max(n.y+n.r,p)}if((e=n.children)&&(c=e.length)){var e,r,i,u,o,a,l,c,f=1/0,s=-(1/0),h=1/0,p=-(1/0);if(e.forEach(Ei),r=e[0],r.x=-r.r,r.y=0,t(r),c>1&&(i=e[1],i.x=i.r,i.y=0,t(i),c>2))for(u=e[2],zi(r,i,u),t(u),wi(r,u),r._pack_prev=u,wi(u,i),i=r._pack_next,o=3;c>o;o++){zi(r,i,u=e[o]);var g=0,v=1,d=1;for(a=i._pack_next;a!==i;a=a._pack_next,v++)if(ki(a,u)){g=1;break}if(1==g)for(l=r._pack_prev;l!==a._pack_prev&&!ki(l,u);l=l._pack_prev,d++);g?(d>v||v==d&&i.r<r.r?Si(r,i=a):Si(r=l,i),o--):(wi(r,u),i=u,t(u))}var y=(f+s)/2,m=(h+p)/2,M=0;for(o=0;c>o;o++)u=e[o],u.x-=y,u.y-=m,M=Math.max(M,u.r+Math.sqrt(u.x*u.x+u.y*u.y));n.r=M,e.forEach(Ai)}}function Ei(n){n._pack_next=n._pack_prev=n}function Ai(n){delete n._pack_next,delete n._pack_prev}function Ci(n,t,e,r){var i=n.children;if(n.x=t+=r*n.x,n.y=e+=r*n.y,n.r*=r,i)for(var u=-1,o=i.length;++u<o;)Ci(i[u],t,e,r)}function zi(n,t,e){var r=n.r+e.r,i=t.x-n.x,u=t.y-n.y;if(r&&(i||u)){var o=t.r+e.r,a=i*i+u*u;o*=o,r*=r;var l=.5+(r-o)/(2*a),c=Math.sqrt(Math.max(0,2*o*(r+a)-(r-=a)*r-o*o))/(2*a);e.x=n.x+l*i+c*u,e.y=n.y+l*u-c*i}else e.x=n.x+r,e.y=n.y}function Li(n,t){return n.parent==t.parent?1:2}function qi(n){var t=n.children;return t.length?t[0]:n.t}function Ti(n){var t,e=n.children;return(t=e.length)?e[t-1]:n.t}function Ri(n,t,e){var r=e/(t.i-n.i);t.c-=r,t.s+=e,n.c+=r,t.z+=e,t.m+=e}function Di(n){for(var t,e=0,r=0,i=n.children,u=i.length;--u>=0;)t=i[u],t.z+=e,t.m+=e,e+=t.s+(r+=t.c)}function Pi(n,t,e){return n.a.parent===t.parent?n.a:e}function Ui(n){return 1+ao.max(n,function(n){return n.y})}function ji(n){return n.reduce(function(n,t){return n+t.x},0)/n.length}function Fi(n){var t=n.children;return t&&t.length?Fi(t[0]):n}function Hi(n){var t,e=n.children;return e&&(t=e.length)?Hi(e[t-1]):n}function Oi(n){return{x:n.x,y:n.y,dx:n.dx,dy:n.dy}}function Ii(n,t){var e=n.x+t[3],r=n.y+t[0],i=n.dx-t[1]-t[3],u=n.dy-t[0]-t[2];return 0>i&&(e+=i/2,i=0),0>u&&(r+=u/2,u=0),{x:e,y:r,dx:i,dy:u}}function Yi(n){var t=n[0],e=n[n.length-1];return e>t?[t,e]:[e,t]}function Zi(n){return n.rangeExtent?n.rangeExtent():Yi(n.range())}function Vi(n,t,e,r){var i=e(n[0],n[1]),u=r(t[0],t[1]);return function(n){return u(i(n))}}function Xi(n,t){var e,r=0,i=n.length-1,u=n[r],o=n[i];return u>o&&(e=r,r=i,i=e,e=u,u=o,o=e),n[r]=t.floor(u),n[i]=t.ceil(o),n}function $i(n){return n?{floor:function(t){return Math.floor(t/n)*n},ceil:function(t){return Math.ceil(t/n)*n}}:Sl}function Bi(n,t,e,r){var i=[],u=[],o=0,a=Math.min(n.length,t.length)-1;for(n[a]<n[0]&&(n=n.slice().reverse(),t=t.slice().reverse());++o<=a;)i.push(e(n[o-1],n[o])),u.push(r(t[o-1],t[o]));return function(t){var e=ao.bisect(n,t,1,a)-1;return u[e](i[e](t))}}function Wi(n,t,e,r){function i(){var i=Math.min(n.length,t.length)>2?Bi:Vi,l=r?Wr:Br;return o=i(n,t,l,e),a=i(t,n,l,Mr),u}function u(n){return o(n)}var o,a;return u.invert=function(n){return a(n)},u.domain=function(t){return arguments.length?(n=t.map(Number),i()):n},u.range=function(n){return arguments.length?(t=n,i()):t},u.rangeRound=function(n){return u.range(n).interpolate(Ur)},u.clamp=function(n){return arguments.length?(r=n,i()):r},u.interpolate=function(n){return arguments.length?(e=n,i()):e},u.ticks=function(t){return Qi(n,t)},u.tickFormat=function(t,e){return nu(n,t,e)},u.nice=function(t){return Gi(n,t),i()},u.copy=function(){return Wi(n,t,e,r)},i()}function Ji(n,t){return ao.rebind(n,t,"range","rangeRound","interpolate","clamp")}function Gi(n,t){return Xi(n,$i(Ki(n,t)[2])),Xi(n,$i(Ki(n,t)[2])),n}function Ki(n,t){null==t&&(t=10);var e=Yi(n),r=e[1]-e[0],i=Math.pow(10,Math.floor(Math.log(r/t)/Math.LN10)),u=t/r*i;return.15>=u?i*=10:.35>=u?i*=5:.75>=u&&(i*=2),e[0]=Math.ceil(e[0]/i)*i,e[1]=Math.floor(e[1]/i)*i+.5*i,e[2]=i,e}function Qi(n,t){return ao.range.apply(ao,Ki(n,t))}function nu(n,t,e){var r=Ki(n,t);if(e){var i=ha.exec(e);if(i.shift(),"s"===i[8]){var u=ao.formatPrefix(Math.max(xo(r[0]),xo(r[1])));return i[7]||(i[7]="."+tu(u.scale(r[2]))),i[8]="f",e=ao.format(i.join("")),function(n){return e(u.scale(n))+u.symbol}}i[7]||(i[7]="."+eu(i[8],r)),e=i.join("")}else e=",."+tu(r[2])+"f";return ao.format(e)}function tu(n){return-Math.floor(Math.log(n)/Math.LN10+.01)}function eu(n,t){var e=tu(t[2]);return n in kl?Math.abs(e-tu(Math.max(xo(t[0]),xo(t[1]))))+ +("e"!==n):e-2*("%"===n)}function ru(n,t,e,r){function i(n){return(e?Math.log(0>n?0:n):-Math.log(n>0?0:-n))/Math.log(t)}function u(n){return e?Math.pow(t,n):-Math.pow(t,-n)}function o(t){return n(i(t))}return o.invert=function(t){return u(n.invert(t))},o.domain=function(t){return arguments.length?(e=t[0]>=0,n.domain((r=t.map(Number)).map(i)),o):r},o.base=function(e){return arguments.length?(t=+e,n.domain(r.map(i)),o):t},o.nice=function(){var t=Xi(r.map(i),e?Math:El);return n.domain(t),r=t.map(u),o},o.ticks=function(){var n=Yi(r),o=[],a=n[0],l=n[1],c=Math.floor(i(a)),f=Math.ceil(i(l)),s=t%1?2:t;if(isFinite(f-c)){if(e){for(;f>c;c++)for(var h=1;s>h;h++)o.push(u(c)*h);o.push(u(c))}else for(o.push(u(c));c++<f;)for(var h=s-1;h>0;h--)o.push(u(c)*h);for(c=0;o[c]<a;c++);for(f=o.length;o[f-1]>l;f--);o=o.slice(c,f)}return o},o.tickFormat=function(n,e){if(!arguments.length)return Nl;arguments.length<2?e=Nl:"function"!=typeof e&&(e=ao.format(e));var r=Math.max(1,t*n/o.ticks().length);return function(n){var o=n/u(Math.round(i(n)));return t-.5>o*t&&(o*=t),r>=o?e(n):""}},o.copy=function(){return ru(n.copy(),t,e,r)},Ji(o,n)}function iu(n,t,e){function r(t){return n(i(t))}var i=uu(t),u=uu(1/t);return r.invert=function(t){return u(n.invert(t))},r.domain=function(t){return arguments.length?(n.domain((e=t.map(Number)).map(i)),r):e},r.ticks=function(n){return Qi(e,n)},r.tickFormat=function(n,t){return nu(e,n,t)},r.nice=function(n){return r.domain(Gi(e,n))},r.exponent=function(o){return arguments.length?(i=uu(t=o),u=uu(1/t),n.domain(e.map(i)),r):t},r.copy=function(){return iu(n.copy(),t,e)},Ji(r,n)}function uu(n){return function(t){return 0>t?-Math.pow(-t,n):Math.pow(t,n)}}function ou(n,t){function e(e){return u[((i.get(e)||("range"===t.t?i.set(e,n.push(e)):NaN))-1)%u.length]}function r(t,e){return ao.range(n.length).map(function(n){return t+e*n})}var i,u,o;return e.domain=function(r){if(!arguments.length)return n;n=[],i=new c;for(var u,o=-1,a=r.length;++o<a;)i.has(u=r[o])||i.set(u,n.push(u));return e[t.t].apply(e,t.a)},e.range=function(n){return arguments.length?(u=n,o=0,t={t:"range",a:arguments},e):u},e.rangePoints=function(i,a){arguments.length<2&&(a=0);var l=i[0],c=i[1],f=n.length<2?(l=(l+c)/2,0):(c-l)/(n.length-1+a);return u=r(l+f*a/2,f),o=0,t={t:"rangePoints",a:arguments},e},e.rangeRoundPoints=function(i,a){arguments.length<2&&(a=0);var l=i[0],c=i[1],f=n.length<2?(l=c=Math.round((l+c)/2),0):(c-l)/(n.length-1+a)|0;return u=r(l+Math.round(f*a/2+(c-l-(n.length-1+a)*f)/2),f),o=0,t={t:"rangeRoundPoints",a:arguments},e},e.rangeBands=function(i,a,l){arguments.length<2&&(a=0),arguments.length<3&&(l=a);var c=i[1]<i[0],f=i[c-0],s=i[1-c],h=(s-f)/(n.length-a+2*l);return u=r(f+h*l,h),c&&u.reverse(),o=h*(1-a),t={t:"rangeBands",a:arguments},e},e.rangeRoundBands=function(i,a,l){arguments.length<2&&(a=0),arguments.length<3&&(l=a);var c=i[1]<i[0],f=i[c-0],s=i[1-c],h=Math.floor((s-f)/(n.length-a+2*l));return u=r(f+Math.round((s-f-(n.length-a)*h)/2),h),c&&u.reverse(),o=Math.round(h*(1-a)),t={t:"rangeRoundBands",a:arguments},e},e.rangeBand=function(){return o},e.rangeExtent=function(){return Yi(t.a[0])},e.copy=function(){return ou(n,t)},e.domain(n)}function au(n,t){function u(){var e=0,r=t.length;for(a=[];++e<r;)a[e-1]=ao.quantile(n,e/r);return o}function o(n){return isNaN(n=+n)?void 0:t[ao.bisect(a,n)]}var a;return o.domain=function(t){return arguments.length?(n=t.map(r).filter(i).sort(e),u()):n},o.range=function(n){return arguments.length?(t=n,u()):t},o.quantiles=function(){return a},o.invertExtent=function(e){return e=t.indexOf(e),0>e?[NaN,NaN]:[e>0?a[e-1]:n[0],e<a.length?a[e]:n[n.length-1]]},o.copy=function(){return au(n,t)},u()}function lu(n,t,e){function r(t){return e[Math.max(0,Math.min(o,Math.floor(u*(t-n))))]}function i(){return u=e.length/(t-n),o=e.length-1,r}var u,o;return r.domain=function(e){return arguments.length?(n=+e[0],t=+e[e.length-1],i()):[n,t]},r.range=function(n){return arguments.length?(e=n,i()):e},r.invertExtent=function(t){return t=e.indexOf(t),t=0>t?NaN:t/u+n,[t,t+1/u]},r.copy=function(){return lu(n,t,e)},i()}function cu(n,t){function e(e){return e>=e?t[ao.bisect(n,e)]:void 0}return e.domain=function(t){return arguments.length?(n=t,e):n},e.range=function(n){return arguments.length?(t=n,e):t},e.invertExtent=function(e){return e=t.indexOf(e),[n[e-1],n[e]]},e.copy=function(){return cu(n,t)},e}function fu(n){function t(n){return+n}return t.invert=t,t.domain=t.range=function(e){return arguments.length?(n=e.map(t),t):n},t.ticks=function(t){return Qi(n,t)},t.tickFormat=function(t,e){return nu(n,t,e)},t.copy=function(){return fu(n)},t}function su(){return 0}function hu(n){return n.innerRadius}function pu(n){return n.outerRadius}function gu(n){return n.startAngle}function vu(n){return n.endAngle}function du(n){return n&&n.padAngle}function yu(n,t,e,r){return(n-e)*t-(t-r)*n>0?0:1}function mu(n,t,e,r,i){var u=n[0]-t[0],o=n[1]-t[1],a=(i?r:-r)/Math.sqrt(u*u+o*o),l=a*o,c=-a*u,f=n[0]+l,s=n[1]+c,h=t[0]+l,p=t[1]+c,g=(f+h)/2,v=(s+p)/2,d=h-f,y=p-s,m=d*d+y*y,M=e-r,x=f*p-h*s,b=(0>y?-1:1)*Math.sqrt(Math.max(0,M*M*m-x*x)),_=(x*y-d*b)/m,w=(-x*d-y*b)/m,S=(x*y+d*b)/m,k=(-x*d+y*b)/m,N=_-g,E=w-v,A=S-g,C=k-v;return N*N+E*E>A*A+C*C&&(_=S,w=k),[[_-l,w-c],[_*e/M,w*e/M]]}function Mu(n){function t(t){function o(){c.push("M",u(n(f),a))}for(var l,c=[],f=[],s=-1,h=t.length,p=En(e),g=En(r);++s<h;)i.call(this,l=t[s],s)?f.push([+p.call(this,l,s),+g.call(this,l,s)]):f.length&&(o(),f=[]);return f.length&&o(),c.length?c.join(""):null}var e=Ce,r=ze,i=zt,u=xu,o=u.key,a=.7;return t.x=function(n){return arguments.length?(e=n,t):e},t.y=function(n){return arguments.length?(r=n,t):r},t.defined=function(n){return arguments.length?(i=n,t):i},t.interpolate=function(n){return arguments.length?(o="function"==typeof n?u=n:(u=Tl.get(n)||xu).key,t):o},t.tension=function(n){return arguments.length?(a=n,t):a},t}function xu(n){return n.length>1?n.join("L"):n+"Z"}function bu(n){return n.join("L")+"Z"}function _u(n){for(var t=0,e=n.length,r=n[0],i=[r[0],",",r[1]];++t<e;)i.push("H",(r[0]+(r=n[t])[0])/2,"V",r[1]);return e>1&&i.push("H",r[0]),i.join("")}function wu(n){for(var t=0,e=n.length,r=n[0],i=[r[0],",",r[1]];++t<e;)i.push("V",(r=n[t])[1],"H",r[0]);return i.join("")}function Su(n){for(var t=0,e=n.length,r=n[0],i=[r[0],",",r[1]];++t<e;)i.push("H",(r=n[t])[0],"V",r[1]);return i.join("")}function ku(n,t){return n.length<4?xu(n):n[1]+Au(n.slice(1,-1),Cu(n,t))}function Nu(n,t){return n.length<3?bu(n):n[0]+Au((n.push(n[0]),n),Cu([n[n.length-2]].concat(n,[n[1]]),t))}function Eu(n,t){return n.length<3?xu(n):n[0]+Au(n,Cu(n,t))}function Au(n,t){if(t.length<1||n.length!=t.length&&n.length!=t.length+2)return xu(n);var e=n.length!=t.length,r="",i=n[0],u=n[1],o=t[0],a=o,l=1;if(e&&(r+="Q"+(u[0]-2*o[0]/3)+","+(u[1]-2*o[1]/3)+","+u[0]+","+u[1],i=n[1],l=2),t.length>1){a=t[1],u=n[l],l++,r+="C"+(i[0]+o[0])+","+(i[1]+o[1])+","+(u[0]-a[0])+","+(u[1]-a[1])+","+u[0]+","+u[1];for(var c=2;c<t.length;c++,l++)u=n[l],a=t[c],r+="S"+(u[0]-a[0])+","+(u[1]-a[1])+","+u[0]+","+u[1]}if(e){var f=n[l];r+="Q"+(u[0]+2*a[0]/3)+","+(u[1]+2*a[1]/3)+","+f[0]+","+f[1]}return r}function Cu(n,t){for(var e,r=[],i=(1-t)/2,u=n[0],o=n[1],a=1,l=n.length;++a<l;)e=u,u=o,o=n[a],r.push([i*(o[0]-e[0]),i*(o[1]-e[1])]);return r}function zu(n){if(n.length<3)return xu(n);var t=1,e=n.length,r=n[0],i=r[0],u=r[1],o=[i,i,i,(r=n[1])[0]],a=[u,u,u,r[1]],l=[i,",",u,"L",Ru(Pl,o),",",Ru(Pl,a)];for(n.push(n[e-1]);++t<=e;)r=n[t],o.shift(),o.push(r[0]),a.shift(),a.push(r[1]),Du(l,o,a);return n.pop(),l.push("L",r),l.join("")}function Lu(n){if(n.length<4)return xu(n);for(var t,e=[],r=-1,i=n.length,u=[0],o=[0];++r<3;)t=n[r],u.push(t[0]),o.push(t[1]);for(e.push(Ru(Pl,u)+","+Ru(Pl,o)),--r;++r<i;)t=n[r],u.shift(),u.push(t[0]),o.shift(),o.push(t[1]),Du(e,u,o);return e.join("")}function qu(n){for(var t,e,r=-1,i=n.length,u=i+4,o=[],a=[];++r<4;)e=n[r%i],o.push(e[0]),a.push(e[1]);for(t=[Ru(Pl,o),",",Ru(Pl,a)],--r;++r<u;)e=n[r%i],o.shift(),o.push(e[0]),a.shift(),a.push(e[1]),Du(t,o,a);return t.join("")}function Tu(n,t){var e=n.length-1;if(e)for(var r,i,u=n[0][0],o=n[0][1],a=n[e][0]-u,l=n[e][1]-o,c=-1;++c<=e;)r=n[c],i=c/e,r[0]=t*r[0]+(1-t)*(u+i*a),r[1]=t*r[1]+(1-t)*(o+i*l);return zu(n)}function Ru(n,t){return n[0]*t[0]+n[1]*t[1]+n[2]*t[2]+n[3]*t[3]}function Du(n,t,e){n.push("C",Ru(Rl,t),",",Ru(Rl,e),",",Ru(Dl,t),",",Ru(Dl,e),",",Ru(Pl,t),",",Ru(Pl,e))}function Pu(n,t){return(t[1]-n[1])/(t[0]-n[0])}function Uu(n){for(var t=0,e=n.length-1,r=[],i=n[0],u=n[1],o=r[0]=Pu(i,u);++t<e;)r[t]=(o+(o=Pu(i=u,u=n[t+1])))/2;return r[t]=o,r}function ju(n){for(var t,e,r,i,u=[],o=Uu(n),a=-1,l=n.length-1;++a<l;)t=Pu(n[a],n[a+1]),xo(t)<Uo?o[a]=o[a+1]=0:(e=o[a]/t,r=o[a+1]/t,i=e*e+r*r,i>9&&(i=3*t/Math.sqrt(i),o[a]=i*e,o[a+1]=i*r));for(a=-1;++a<=l;)i=(n[Math.min(l,a+1)][0]-n[Math.max(0,a-1)][0])/(6*(1+o[a]*o[a])),u.push([i||0,o[a]*i||0]);return u}function Fu(n){return n.length<3?xu(n):n[0]+Au(n,ju(n))}function Hu(n){for(var t,e,r,i=-1,u=n.length;++i<u;)t=n[i],e=t[0],r=t[1]-Io,t[0]=e*Math.cos(r),t[1]=e*Math.sin(r);return n}function Ou(n){function t(t){function l(){v.push("M",a(n(y),s),f,c(n(d.reverse()),s),"Z")}for(var h,p,g,v=[],d=[],y=[],m=-1,M=t.length,x=En(e),b=En(i),_=e===r?function(){

- return p}:En(r),w=i===u?function(){return g}:En(u);++m<M;)o.call(this,h=t[m],m)?(d.push([p=+x.call(this,h,m),g=+b.call(this,h,m)]),y.push([+_.call(this,h,m),+w.call(this,h,m)])):d.length&&(l(),d=[],y=[]);return d.length&&l(),v.length?v.join(""):null}var e=Ce,r=Ce,i=0,u=ze,o=zt,a=xu,l=a.key,c=a,f="L",s=.7;return t.x=function(n){return arguments.length?(e=r=n,t):r},t.x0=function(n){return arguments.length?(e=n,t):e},t.x1=function(n){return arguments.length?(r=n,t):r},t.y=function(n){return arguments.length?(i=u=n,t):u},t.y0=function(n){return arguments.length?(i=n,t):i},t.y1=function(n){return arguments.length?(u=n,t):u},t.defined=function(n){return arguments.length?(o=n,t):o},t.interpolate=function(n){return arguments.length?(l="function"==typeof n?a=n:(a=Tl.get(n)||xu).key,c=a.reverse||a,f=a.closed?"M":"L",t):l},t.tension=function(n){return arguments.length?(s=n,t):s},t}function Iu(n){return n.radius}function Yu(n){return[n.x,n.y]}function Zu(n){return function(){var t=n.apply(this,arguments),e=t[0],r=t[1]-Io;return[e*Math.cos(r),e*Math.sin(r)]}}function Vu(){return 64}function Xu(){return"circle"}function $u(n){var t=Math.sqrt(n/Fo);return"M0,"+t+"A"+t+","+t+" 0 1,1 0,"+-t+"A"+t+","+t+" 0 1,1 0,"+t+"Z"}function Bu(n){return function(){var t,e,r;(t=this[n])&&(r=t[e=t.active])&&(r.timer.c=null,r.timer.t=NaN,--t.count?delete t[e]:delete this[n],t.active+=.5,r.event&&r.event.interrupt.call(this,this.__data__,r.index))}}function Wu(n,t,e){return ko(n,Yl),n.namespace=t,n.id=e,n}function Ju(n,t,e,r){var i=n.id,u=n.namespace;return Y(n,"function"==typeof e?function(n,o,a){n[u][i].tween.set(t,r(e.call(n,n.__data__,o,a)))}:(e=r(e),function(n){n[u][i].tween.set(t,e)}))}function Gu(n){return null==n&&(n=""),function(){this.textContent=n}}function Ku(n){return null==n?"__transition__":"__transition_"+n+"__"}function Qu(n,t,e,r,i){function u(n){var t=v.delay;return f.t=t+l,n>=t?o(n-t):void(f.c=o)}function o(e){var i=g.active,u=g[i];u&&(u.timer.c=null,u.timer.t=NaN,--g.count,delete g[i],u.event&&u.event.interrupt.call(n,n.__data__,u.index));for(var o in g)if(r>+o){var c=g[o];c.timer.c=null,c.timer.t=NaN,--g.count,delete g[o]}f.c=a,qn(function(){return f.c&&a(e||1)&&(f.c=null,f.t=NaN),1},0,l),g.active=r,v.event&&v.event.start.call(n,n.__data__,t),p=[],v.tween.forEach(function(e,r){(r=r.call(n,n.__data__,t))&&p.push(r)}),h=v.ease,s=v.duration}function a(i){for(var u=i/s,o=h(u),a=p.length;a>0;)p[--a].call(n,o);return u>=1?(v.event&&v.event.end.call(n,n.__data__,t),--g.count?delete g[r]:delete n[e],1):void 0}var l,f,s,h,p,g=n[e]||(n[e]={active:0,count:0}),v=g[r];v||(l=i.time,f=qn(u,0,l),v=g[r]={tween:new c,time:l,timer:f,delay:i.delay,duration:i.duration,ease:i.ease,index:t},i=null,++g.count)}function no(n,t,e){n.attr("transform",function(n){var r=t(n);return"translate("+(isFinite(r)?r:e(n))+",0)"})}function to(n,t,e){n.attr("transform",function(n){var r=t(n);return"translate(0,"+(isFinite(r)?r:e(n))+")"})}function eo(n){return n.toISOString()}function ro(n,t,e){function r(t){return n(t)}function i(n,e){var r=n[1]-n[0],i=r/e,u=ao.bisect(Kl,i);return u==Kl.length?[t.year,Ki(n.map(function(n){return n/31536e6}),e)[2]]:u?t[i/Kl[u-1]<Kl[u]/i?u-1:u]:[tc,Ki(n,e)[2]]}return r.invert=function(t){return io(n.invert(t))},r.domain=function(t){return arguments.length?(n.domain(t),r):n.domain().map(io)},r.nice=function(n,t){function e(e){return!isNaN(e)&&!n.range(e,io(+e+1),t).length}var u=r.domain(),o=Yi(u),a=null==n?i(o,10):"number"==typeof n&&i(o,n);return a&&(n=a[0],t=a[1]),r.domain(Xi(u,t>1?{floor:function(t){for(;e(t=n.floor(t));)t=io(t-1);return t},ceil:function(t){for(;e(t=n.ceil(t));)t=io(+t+1);return t}}:n))},r.ticks=function(n,t){var e=Yi(r.domain()),u=null==n?i(e,10):"number"==typeof n?i(e,n):!n.range&&[{range:n},t];return u&&(n=u[0],t=u[1]),n.range(e[0],io(+e[1]+1),1>t?1:t)},r.tickFormat=function(){return e},r.copy=function(){return ro(n.copy(),t,e)},Ji(r,n)}function io(n){return new Date(n)}function uo(n){return JSON.parse(n.responseText)}function oo(n){var t=fo.createRange();return t.selectNode(fo.body),t.createContextualFragment(n.responseText)}var ao={version:"3.5.17"},lo=[].slice,co=function(n){return lo.call(n)},fo=this.document;if(fo)try{co(fo.documentElement.childNodes)[0].nodeType}catch(so){co=function(n){for(var t=n.length,e=new Array(t);t--;)e[t]=n[t];return e}}if(Date.now||(Date.now=function(){return+new Date}),fo)try{fo.createElement("DIV").style.setProperty("opacity",0,"")}catch(ho){var po=this.Element.prototype,go=po.setAttribute,vo=po.setAttributeNS,yo=this.CSSStyleDeclaration.prototype,mo=yo.setProperty;po.setAttribute=function(n,t){go.call(this,n,t+"")},po.setAttributeNS=function(n,t,e){vo.call(this,n,t,e+"")},yo.setProperty=function(n,t,e){mo.call(this,n,t+"",e)}}ao.ascending=e,ao.descending=function(n,t){return n>t?-1:t>n?1:t>=n?0:NaN},ao.min=function(n,t){var e,r,i=-1,u=n.length;if(1===arguments.length){for(;++i<u;)if(null!=(r=n[i])&&r>=r){e=r;break}for(;++i<u;)null!=(r=n[i])&&e>r&&(e=r)}else{for(;++i<u;)if(null!=(r=t.call(n,n[i],i))&&r>=r){e=r;break}for(;++i<u;)null!=(r=t.call(n,n[i],i))&&e>r&&(e=r)}return e},ao.max=function(n,t){var e,r,i=-1,u=n.length;if(1===arguments.length){for(;++i<u;)if(null!=(r=n[i])&&r>=r){e=r;break}for(;++i<u;)null!=(r=n[i])&&r>e&&(e=r)}else{for(;++i<u;)if(null!=(r=t.call(n,n[i],i))&&r>=r){e=r;break}for(;++i<u;)null!=(r=t.call(n,n[i],i))&&r>e&&(e=r)}return e},ao.extent=function(n,t){var e,r,i,u=-1,o=n.length;if(1===arguments.length){for(;++u<o;)if(null!=(r=n[u])&&r>=r){e=i=r;break}for(;++u<o;)null!=(r=n[u])&&(e>r&&(e=r),r>i&&(i=r))}else{for(;++u<o;)if(null!=(r=t.call(n,n[u],u))&&r>=r){e=i=r;break}for(;++u<o;)null!=(r=t.call(n,n[u],u))&&(e>r&&(e=r),r>i&&(i=r))}return[e,i]},ao.sum=function(n,t){var e,r=0,u=n.length,o=-1;if(1===arguments.length)for(;++o<u;)i(e=+n[o])&&(r+=e);else for(;++o<u;)i(e=+t.call(n,n[o],o))&&(r+=e);return r},ao.mean=function(n,t){var e,u=0,o=n.length,a=-1,l=o;if(1===arguments.length)for(;++a<o;)i(e=r(n[a]))?u+=e:--l;else for(;++a<o;)i(e=r(t.call(n,n[a],a)))?u+=e:--l;return l?u/l:void 0},ao.quantile=function(n,t){var e=(n.length-1)*t+1,r=Math.floor(e),i=+n[r-1],u=e-r;return u?i+u*(n[r]-i):i},ao.median=function(n,t){var u,o=[],a=n.length,l=-1;if(1===arguments.length)for(;++l<a;)i(u=r(n[l]))&&o.push(u);else for(;++l<a;)i(u=r(t.call(n,n[l],l)))&&o.push(u);return o.length?ao.quantile(o.sort(e),.5):void 0},ao.variance=function(n,t){var e,u,o=n.length,a=0,l=0,c=-1,f=0;if(1===arguments.length)for(;++c<o;)i(e=r(n[c]))&&(u=e-a,a+=u/++f,l+=u*(e-a));else for(;++c<o;)i(e=r(t.call(n,n[c],c)))&&(u=e-a,a+=u/++f,l+=u*(e-a));return f>1?l/(f-1):void 0},ao.deviation=function(){var n=ao.variance.apply(this,arguments);return n?Math.sqrt(n):n};var Mo=u(e);ao.bisectLeft=Mo.left,ao.bisect=ao.bisectRight=Mo.right,ao.bisector=function(n){return u(1===n.length?function(t,r){return e(n(t),r)}:n)},ao.shuffle=function(n,t,e){(u=arguments.length)<3&&(e=n.length,2>u&&(t=0));for(var r,i,u=e-t;u;)i=Math.random()*u--|0,r=n[u+t],n[u+t]=n[i+t],n[i+t]=r;return n},ao.permute=function(n,t){for(var e=t.length,r=new Array(e);e--;)r[e]=n[t[e]];return r},ao.pairs=function(n){for(var t,e=0,r=n.length-1,i=n[0],u=new Array(0>r?0:r);r>e;)u[e]=[t=i,i=n[++e]];return u},ao.transpose=function(n){if(!(i=n.length))return[];for(var t=-1,e=ao.min(n,o),r=new Array(e);++t<e;)for(var i,u=-1,a=r[t]=new Array(i);++u<i;)a[u]=n[u][t];return r},ao.zip=function(){return ao.transpose(arguments)},ao.keys=function(n){var t=[];for(var e in n)t.push(e);return t},ao.values=function(n){var t=[];for(var e in n)t.push(n[e]);return t},ao.entries=function(n){var t=[];for(var e in n)t.push({key:e,value:n[e]});return t},ao.merge=function(n){for(var t,e,r,i=n.length,u=-1,o=0;++u<i;)o+=n[u].length;for(e=new Array(o);--i>=0;)for(r=n[i],t=r.length;--t>=0;)e[--o]=r[t];return e};var xo=Math.abs;ao.range=function(n,t,e){if(arguments.length<3&&(e=1,arguments.length<2&&(t=n,n=0)),(t-n)/e===1/0)throw new Error("infinite range");var r,i=[],u=a(xo(e)),o=-1;if(n*=u,t*=u,e*=u,0>e)for(;(r=n+e*++o)>t;)i.push(r/u);else for(;(r=n+e*++o)<t;)i.push(r/u);return i},ao.map=function(n,t){var e=new c;if(n instanceof c)n.forEach(function(n,t){e.set(n,t)});else if(Array.isArray(n)){var r,i=-1,u=n.length;if(1===arguments.length)for(;++i<u;)e.set(i,n[i]);else for(;++i<u;)e.set(t.call(n,r=n[i],i),r)}else for(var o in n)e.set(o,n[o]);return e};var bo="__proto__",_o="\x00";l(c,{has:h,get:function(n){return this._[f(n)]},set:function(n,t){return this._[f(n)]=t},remove:p,keys:g,values:function(){var n=[];for(var t in this._)n.push(this._[t]);return n},entries:function(){var n=[];for(var t in this._)n.push({key:s(t),value:this._[t]});return n},size:v,empty:d,forEach:function(n){for(var t in this._)n.call(this,s(t),this._[t])}}),ao.nest=function(){function n(t,o,a){if(a>=u.length)return r?r.call(i,o):e?o.sort(e):o;for(var l,f,s,h,p=-1,g=o.length,v=u[a++],d=new c;++p<g;)(h=d.get(l=v(f=o[p])))?h.push(f):d.set(l,[f]);return t?(f=t(),s=function(e,r){f.set(e,n(t,r,a))}):(f={},s=function(e,r){f[e]=n(t,r,a)}),d.forEach(s),f}function t(n,e){if(e>=u.length)return n;var r=[],i=o[e++];return n.forEach(function(n,i){r.push({key:n,values:t(i,e)})}),i?r.sort(function(n,t){return i(n.key,t.key)}):r}var e,r,i={},u=[],o=[];return i.map=function(t,e){return n(e,t,0)},i.entries=function(e){return t(n(ao.map,e,0),0)},i.key=function(n){return u.push(n),i},i.sortKeys=function(n){return o[u.length-1]=n,i},i.sortValues=function(n){return e=n,i},i.rollup=function(n){return r=n,i},i},ao.set=function(n){var t=new y;if(n)for(var e=0,r=n.length;r>e;++e)t.add(n[e]);return t},l(y,{has:h,add:function(n){return this._[f(n+="")]=!0,n},remove:p,values:g,size:v,empty:d,forEach:function(n){for(var t in this._)n.call(this,s(t))}}),ao.behavior={},ao.rebind=function(n,t){for(var e,r=1,i=arguments.length;++r<i;)n[e=arguments[r]]=M(n,t,t[e]);return n};var wo=["webkit","ms","moz","Moz","o","O"];ao.dispatch=function(){for(var n=new _,t=-1,e=arguments.length;++t<e;)n[arguments[t]]=w(n);return n},_.prototype.on=function(n,t){var e=n.indexOf("."),r="";if(e>=0&&(r=n.slice(e+1),n=n.slice(0,e)),n)return arguments.length<2?this[n].on(r):this[n].on(r,t);if(2===arguments.length){if(null==t)for(n in this)this.hasOwnProperty(n)&&this[n].on(r,null);return this}},ao.event=null,ao.requote=function(n){return n.replace(So,"\\$&")};var So=/[\\\^\$\*\+\?\|\[\]\(\)\.\{\}]/g,ko={}.__proto__?function(n,t){n.__proto__=t}:function(n,t){for(var e in t)n[e]=t[e]},No=function(n,t){return t.querySelector(n)},Eo=function(n,t){return t.querySelectorAll(n)},Ao=function(n,t){var e=n.matches||n[x(n,"matchesSelector")];return(Ao=function(n,t){return e.call(n,t)})(n,t)};"function"==typeof Sizzle&&(No=function(n,t){return Sizzle(n,t)[0]||null},Eo=Sizzle,Ao=Sizzle.matchesSelector),ao.selection=function(){return ao.select(fo.documentElement)};var Co=ao.selection.prototype=[];Co.select=function(n){var t,e,r,i,u=[];n=A(n);for(var o=-1,a=this.length;++o<a;){u.push(t=[]),t.parentNode=(r=this[o]).parentNode;for(var l=-1,c=r.length;++l<c;)(i=r[l])?(t.push(e=n.call(i,i.__data__,l,o)),e&&"__data__"in i&&(e.__data__=i.__data__)):t.push(null)}return E(u)},Co.selectAll=function(n){var t,e,r=[];n=C(n);for(var i=-1,u=this.length;++i<u;)for(var o=this[i],a=-1,l=o.length;++a<l;)(e=o[a])&&(r.push(t=co(n.call(e,e.__data__,a,i))),t.parentNode=e);return E(r)};var zo="http://www.w3.org/1999/xhtml",Lo={svg:"http://www.w3.org/2000/svg",xhtml:zo,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};ao.ns={prefix:Lo,qualify:function(n){var t=n.indexOf(":"),e=n;return t>=0&&"xmlns"!==(e=n.slice(0,t))&&(n=n.slice(t+1)),Lo.hasOwnProperty(e)?{space:Lo[e],local:n}:n}},Co.attr=function(n,t){if(arguments.length<2){if("string"==typeof n){var e=this.node();return n=ao.ns.qualify(n),n.local?e.getAttributeNS(n.space,n.local):e.getAttribute(n)}for(t in n)this.each(z(t,n[t]));return this}return this.each(z(n,t))},Co.classed=function(n,t){if(arguments.length<2){if("string"==typeof n){var e=this.node(),r=(n=T(n)).length,i=-1;if(t=e.classList){for(;++i<r;)if(!t.contains(n[i]))return!1}else for(t=e.getAttribute("class");++i<r;)if(!q(n[i]).test(t))return!1;return!0}for(t in n)this.each(R(t,n[t]));return this}return this.each(R(n,t))},Co.style=function(n,e,r){var i=arguments.length;if(3>i){if("string"!=typeof n){2>i&&(e="");for(r in n)this.each(P(r,n[r],e));return this}if(2>i){var u=this.node();return t(u).getComputedStyle(u,null).getPropertyValue(n)}r=""}return this.each(P(n,e,r))},Co.property=function(n,t){if(arguments.length<2){if("string"==typeof n)return this.node()[n];for(t in n)this.each(U(t,n[t]));return this}return this.each(U(n,t))},Co.text=function(n){return arguments.length?this.each("function"==typeof n?function(){var t=n.apply(this,arguments);this.textContent=null==t?"":t}:null==n?function(){this.textContent=""}:function(){this.textContent=n}):this.node().textContent},Co.html=function(n){return arguments.length?this.each("function"==typeof n?function(){var t=n.apply(this,arguments);this.innerHTML=null==t?"":t}:null==n?function(){this.innerHTML=""}:function(){this.innerHTML=n}):this.node().innerHTML},Co.append=function(n){return n=j(n),this.select(function(){return this.appendChild(n.apply(this,arguments))})},Co.insert=function(n,t){return n=j(n),t=A(t),this.select(function(){return this.insertBefore(n.apply(this,arguments),t.apply(this,arguments)||null)})},Co.remove=function(){return this.each(F)},Co.data=function(n,t){function e(n,e){var r,i,u,o=n.length,s=e.length,h=Math.min(o,s),p=new Array(s),g=new Array(s),v=new Array(o);if(t){var d,y=new c,m=new Array(o);for(r=-1;++r<o;)(i=n[r])&&(y.has(d=t.call(i,i.__data__,r))?v[r]=i:y.set(d,i),m[r]=d);for(r=-1;++r<s;)(i=y.get(d=t.call(e,u=e[r],r)))?i!==!0&&(p[r]=i,i.__data__=u):g[r]=H(u),y.set(d,!0);for(r=-1;++r<o;)r in m&&y.get(m[r])!==!0&&(v[r]=n[r])}else{for(r=-1;++r<h;)i=n[r],u=e[r],i?(i.__data__=u,p[r]=i):g[r]=H(u);for(;s>r;++r)g[r]=H(e[r]);for(;o>r;++r)v[r]=n[r]}g.update=p,g.parentNode=p.parentNode=v.parentNode=n.parentNode,a.push(g),l.push(p),f.push(v)}var r,i,u=-1,o=this.length;if(!arguments.length){for(n=new Array(o=(r=this[0]).length);++u<o;)(i=r[u])&&(n[u]=i.__data__);return n}var a=Z([]),l=E([]),f=E([]);if("function"==typeof n)for(;++u<o;)e(r=this[u],n.call(r,r.parentNode.__data__,u));else for(;++u<o;)e(r=this[u],n);return l.enter=function(){return a},l.exit=function(){return f},l},Co.datum=function(n){return arguments.length?this.property("__data__",n):this.property("__data__")},Co.filter=function(n){var t,e,r,i=[];"function"!=typeof n&&(n=O(n));for(var u=0,o=this.length;o>u;u++){i.push(t=[]),t.parentNode=(e=this[u]).parentNode;for(var a=0,l=e.length;l>a;a++)(r=e[a])&&n.call(r,r.__data__,a,u)&&t.push(r)}return E(i)},Co.order=function(){for(var n=-1,t=this.length;++n<t;)for(var e,r=this[n],i=r.length-1,u=r[i];--i>=0;)(e=r[i])&&(u&&u!==e.nextSibling&&u.parentNode.insertBefore(e,u),u=e);return this},Co.sort=function(n){n=I.apply(this,arguments);for(var t=-1,e=this.length;++t<e;)this[t].sort(n);return this.order()},Co.each=function(n){return Y(this,function(t,e,r){n.call(t,t.__data__,e,r)})},Co.call=function(n){var t=co(arguments);return n.apply(t[0]=this,t),this},Co.empty=function(){return!this.node()},Co.node=function(){for(var n=0,t=this.length;t>n;n++)for(var e=this[n],r=0,i=e.length;i>r;r++){var u=e[r];if(u)return u}return null},Co.size=function(){var n=0;return Y(this,function(){++n}),n};var qo=[];ao.selection.enter=Z,ao.selection.enter.prototype=qo,qo.append=Co.append,qo.empty=Co.empty,qo.node=Co.node,qo.call=Co.call,qo.size=Co.size,qo.select=function(n){for(var t,e,r,i,u,o=[],a=-1,l=this.length;++a<l;){r=(i=this[a]).update,o.push(t=[]),t.parentNode=i.parentNode;for(var c=-1,f=i.length;++c<f;)(u=i[c])?(t.push(r[c]=e=n.call(i.parentNode,u.__data__,c,a)),e.__data__=u.__data__):t.push(null)}return E(o)},qo.insert=function(n,t){return arguments.length<2&&(t=V(this)),Co.insert.call(this,n,t)},ao.select=function(t){var e;return"string"==typeof t?(e=[No(t,fo)],e.parentNode=fo.documentElement):(e=[t],e.parentNode=n(t)),E([e])},ao.selectAll=function(n){var t;return"string"==typeof n?(t=co(Eo(n,fo)),t.parentNode=fo.documentElement):(t=co(n),t.parentNode=null),E([t])},Co.on=function(n,t,e){var r=arguments.length;if(3>r){if("string"!=typeof n){2>r&&(t=!1);for(e in n)this.each(X(e,n[e],t));return this}if(2>r)return(r=this.node()["__on"+n])&&r._;e=!1}return this.each(X(n,t,e))};var To=ao.map({mouseenter:"mouseover",mouseleave:"mouseout"});fo&&To.forEach(function(n){"on"+n in fo&&To.remove(n)});var Ro,Do=0;ao.mouse=function(n){return J(n,k())};var Po=this.navigator&&/WebKit/.test(this.navigator.userAgent)?-1:0;ao.touch=function(n,t,e){if(arguments.length<3&&(e=t,t=k().changedTouches),t)for(var r,i=0,u=t.length;u>i;++i)if((r=t[i]).identifier===e)return J(n,r)},ao.behavior.drag=function(){function n(){this.on("mousedown.drag",u).on("touchstart.drag",o)}function e(n,t,e,u,o){return function(){function a(){var n,e,r=t(h,v);r&&(n=r[0]-M[0],e=r[1]-M[1],g|=n|e,M=r,p({type:"drag",x:r[0]+c[0],y:r[1]+c[1],dx:n,dy:e}))}function l(){t(h,v)&&(y.on(u+d,null).on(o+d,null),m(g),p({type:"dragend"}))}var c,f=this,s=ao.event.target.correspondingElement||ao.event.target,h=f.parentNode,p=r.of(f,arguments),g=0,v=n(),d=".drag"+(null==v?"":"-"+v),y=ao.select(e(s)).on(u+d,a).on(o+d,l),m=W(s),M=t(h,v);i?(c=i.apply(f,arguments),c=[c.x-M[0],c.y-M[1]]):c=[0,0],p({type:"dragstart"})}}var r=N(n,"drag","dragstart","dragend"),i=null,u=e(b,ao.mouse,t,"mousemove","mouseup"),o=e(G,ao.touch,m,"touchmove","touchend");return n.origin=function(t){return arguments.length?(i=t,n):i},ao.rebind(n,r,"on")},ao.touches=function(n,t){return arguments.length<2&&(t=k().touches),t?co(t).map(function(t){var e=J(n,t);return e.identifier=t.identifier,e}):[]};var Uo=1e-6,jo=Uo*Uo,Fo=Math.PI,Ho=2*Fo,Oo=Ho-Uo,Io=Fo/2,Yo=Fo/180,Zo=180/Fo,Vo=Math.SQRT2,Xo=2,$o=4;ao.interpolateZoom=function(n,t){var e,r,i=n[0],u=n[1],o=n[2],a=t[0],l=t[1],c=t[2],f=a-i,s=l-u,h=f*f+s*s;if(jo>h)r=Math.log(c/o)/Vo,e=function(n){return[i+n*f,u+n*s,o*Math.exp(Vo*n*r)]};else{var p=Math.sqrt(h),g=(c*c-o*o+$o*h)/(2*o*Xo*p),v=(c*c-o*o-$o*h)/(2*c*Xo*p),d=Math.log(Math.sqrt(g*g+1)-g),y=Math.log(Math.sqrt(v*v+1)-v);r=(y-d)/Vo,e=function(n){var t=n*r,e=rn(d),a=o/(Xo*p)*(e*un(Vo*t+d)-en(d));return[i+a*f,u+a*s,o*e/rn(Vo*t+d)]}}return e.duration=1e3*r,e},ao.behavior.zoom=function(){function n(n){n.on(L,s).on(Wo+".zoom",p).on("dblclick.zoom",g).on(R,h)}function e(n){return[(n[0]-k.x)/k.k,(n[1]-k.y)/k.k]}function r(n){return[n[0]*k.k+k.x,n[1]*k.k+k.y]}function i(n){k.k=Math.max(A[0],Math.min(A[1],n))}function u(n,t){t=r(t),k.x+=n[0]-t[0],k.y+=n[1]-t[1]}function o(t,e,r,o){t.__chart__={x:k.x,y:k.y,k:k.k},i(Math.pow(2,o)),u(d=e,r),t=ao.select(t),C>0&&(t=t.transition().duration(C)),t.call(n.event)}function a(){b&&b.domain(x.range().map(function(n){return(n-k.x)/k.k}).map(x.invert)),w&&w.domain(_.range().map(function(n){return(n-k.y)/k.k}).map(_.invert))}function l(n){z++||n({type:"zoomstart"})}function c(n){a(),n({type:"zoom",scale:k.k,translate:[k.x,k.y]})}function f(n){--z||(n({type:"zoomend"}),d=null)}function s(){function n(){a=1,u(ao.mouse(i),h),c(o)}function r(){s.on(q,null).on(T,null),p(a),f(o)}var i=this,o=D.of(i,arguments),a=0,s=ao.select(t(i)).on(q,n).on(T,r),h=e(ao.mouse(i)),p=W(i);Il.call(i),l(o)}function h(){function n(){var n=ao.touches(g);return p=k.k,n.forEach(function(n){n.identifier in d&&(d[n.identifier]=e(n))}),n}function t(){var t=ao.event.target;ao.select(t).on(x,r).on(b,a),_.push(t);for(var e=ao.event.changedTouches,i=0,u=e.length;u>i;++i)d[e[i].identifier]=null;var l=n(),c=Date.now();if(1===l.length){if(500>c-M){var f=l[0];o(g,f,d[f.identifier],Math.floor(Math.log(k.k)/Math.LN2)+1),S()}M=c}else if(l.length>1){var f=l[0],s=l[1],h=f[0]-s[0],p=f[1]-s[1];y=h*h+p*p}}function r(){var n,t,e,r,o=ao.touches(g);Il.call(g);for(var a=0,l=o.length;l>a;++a,r=null)if(e=o[a],r=d[e.identifier]){if(t)break;n=e,t=r}if(r){var f=(f=e[0]-n[0])*f+(f=e[1]-n[1])*f,s=y&&Math.sqrt(f/y);n=[(n[0]+e[0])/2,(n[1]+e[1])/2],t=[(t[0]+r[0])/2,(t[1]+r[1])/2],i(s*p)}M=null,u(n,t),c(v)}function a(){if(ao.event.touches.length){for(var t=ao.event.changedTouches,e=0,r=t.length;r>e;++e)delete d[t[e].identifier];for(var i in d)return void n()}ao.selectAll(_).on(m,null),w.on(L,s).on(R,h),N(),f(v)}var p,g=this,v=D.of(g,arguments),d={},y=0,m=".zoom-"+ao.event.changedTouches[0].identifier,x="touchmove"+m,b="touchend"+m,_=[],w=ao.select(g),N=W(g);t(),l(v),w.on(L,null).on(R,t)}function p(){var n=D.of(this,arguments);m?clearTimeout(m):(Il.call(this),v=e(d=y||ao.mouse(this)),l(n)),m=setTimeout(function(){m=null,f(n)},50),S(),i(Math.pow(2,.002*Bo())*k.k),u(d,v),c(n)}function g(){var n=ao.mouse(this),t=Math.log(k.k)/Math.LN2;o(this,n,e(n),ao.event.shiftKey?Math.ceil(t)-1:Math.floor(t)+1)}var v,d,y,m,M,x,b,_,w,k={x:0,y:0,k:1},E=[960,500],A=Jo,C=250,z=0,L="mousedown.zoom",q="mousemove.zoom",T="mouseup.zoom",R="touchstart.zoom",D=N(n,"zoomstart","zoom","zoomend");return Wo||(Wo="onwheel"in fo?(Bo=function(){return-ao.event.deltaY*(ao.event.deltaMode?120:1)},"wheel"):"onmousewheel"in fo?(Bo=function(){return ao.event.wheelDelta},"mousewheel"):(Bo=function(){return-ao.event.detail},"MozMousePixelScroll")),n.event=function(n){n.each(function(){var n=D.of(this,arguments),t=k;Hl?ao.select(this).transition().each("start.zoom",function(){k=this.__chart__||{x:0,y:0,k:1},l(n)}).tween("zoom:zoom",function(){var e=E[0],r=E[1],i=d?d[0]:e/2,u=d?d[1]:r/2,o=ao.interpolateZoom([(i-k.x)/k.k,(u-k.y)/k.k,e/k.k],[(i-t.x)/t.k,(u-t.y)/t.k,e/t.k]);return function(t){var r=o(t),a=e/r[2];this.__chart__=k={x:i-r[0]*a,y:u-r[1]*a,k:a},c(n)}}).each("interrupt.zoom",function(){f(n)}).each("end.zoom",function(){f(n)}):(this.__chart__=k,l(n),c(n),f(n))})},n.translate=function(t){return arguments.length?(k={x:+t[0],y:+t[1],k:k.k},a(),n):[k.x,k.y]},n.scale=function(t){return arguments.length?(k={x:k.x,y:k.y,k:null},i(+t),a(),n):k.k},n.scaleExtent=function(t){return arguments.length?(A=null==t?Jo:[+t[0],+t[1]],n):A},n.center=function(t){return arguments.length?(y=t&&[+t[0],+t[1]],n):y},n.size=function(t){return arguments.length?(E=t&&[+t[0],+t[1]],n):E},n.duration=function(t){return arguments.length?(C=+t,n):C},n.x=function(t){return arguments.length?(b=t,x=t.copy(),k={x:0,y:0,k:1},n):b},n.y=function(t){return arguments.length?(w=t,_=t.copy(),k={x:0,y:0,k:1},n):w},ao.rebind(n,D,"on")};var Bo,Wo,Jo=[0,1/0];ao.color=an,an.prototype.toString=function(){return this.rgb()+""},ao.hsl=ln;var Go=ln.prototype=new an;Go.brighter=function(n){return n=Math.pow(.7,arguments.length?n:1),new ln(this.h,this.s,this.l/n)},Go.darker=function(n){return n=Math.pow(.7,arguments.length?n:1),new ln(this.h,this.s,n*this.l)},Go.rgb=function(){return cn(this.h,this.s,this.l)},ao.hcl=fn;var Ko=fn.prototype=new an;Ko.brighter=function(n){return new fn(this.h,this.c,Math.min(100,this.l+Qo*(arguments.length?n:1)))},Ko.darker=function(n){return new fn(this.h,this.c,Math.max(0,this.l-Qo*(arguments.length?n:1)))},Ko.rgb=function(){return sn(this.h,this.c,this.l).rgb()},ao.lab=hn;var Qo=18,na=.95047,ta=1,ea=1.08883,ra=hn.prototype=new an;ra.brighter=function(n){return new hn(Math.min(100,this.l+Qo*(arguments.length?n:1)),this.a,this.b)},ra.darker=function(n){return new hn(Math.max(0,this.l-Qo*(arguments.length?n:1)),this.a,this.b)},ra.rgb=function(){return pn(this.l,this.a,this.b)},ao.rgb=mn;var ia=mn.prototype=new an;ia.brighter=function(n){n=Math.pow(.7,arguments.length?n:1);var t=this.r,e=this.g,r=this.b,i=30;return t||e||r?(t&&i>t&&(t=i),e&&i>e&&(e=i),r&&i>r&&(r=i),new mn(Math.min(255,t/n),Math.min(255,e/n),Math.min(255,r/n))):new mn(i,i,i)},ia.darker=function(n){return n=Math.pow(.7,arguments.length?n:1),new mn(n*this.r,n*this.g,n*this.b)},ia.hsl=function(){return wn(this.r,this.g,this.b)},ia.toString=function(){return"#"+bn(this.r)+bn(this.g)+bn(this.b)};var ua=ao.map({aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074});ua.forEach(function(n,t){ua.set(n,Mn(t))}),ao.functor=En,ao.xhr=An(m),ao.dsv=function(n,t){function e(n,e,u){arguments.length<3&&(u=e,e=null);var o=Cn(n,t,null==e?r:i(e),u);return o.row=function(n){return arguments.length?o.response(null==(e=n)?r:i(n)):e},o}function r(n){return e.parse(n.responseText)}function i(n){return function(t){return e.parse(t.responseText,n)}}function u(t){return t.map(o).join(n)}function o(n){return a.test(n)?'"'+n.replace(/\"/g,'""')+'"':n}var a=new RegExp('["'+n+"\n]"),l=n.charCodeAt(0);return e.parse=function(n,t){var r;return e.parseRows(n,function(n,e){if(r)return r(n,e-1);var i=new Function("d","return {"+n.map(function(n,t){return JSON.stringify(n)+": d["+t+"]"}).join(",")+"}");r=t?function(n,e){return t(i(n),e)}:i})},e.parseRows=function(n,t){function e(){if(f>=c)return o;if(i)return i=!1,u;var t=f;if(34===n.charCodeAt(t)){for(var e=t;e++<c;)if(34===n.charCodeAt(e)){if(34!==n.charCodeAt(e+1))break;++e}f=e+2;var r=n.charCodeAt(e+1);return 13===r?(i=!0,10===n.charCodeAt(e+2)&&++f):10===r&&(i=!0),n.slice(t+1,e).replace(/""/g,'"')}for(;c>f;){var r=n.charCodeAt(f++),a=1;if(10===r)i=!0;else if(13===r)i=!0,10===n.charCodeAt(f)&&(++f,++a);else if(r!==l)continue;return n.slice(t,f-a)}return n.slice(t)}for(var r,i,u={},o={},a=[],c=n.length,f=0,s=0;(r=e())!==o;){for(var h=[];r!==u&&r!==o;)h.push(r),r=e();t&&null==(h=t(h,s++))||a.push(h)}return a},e.format=function(t){if(Array.isArray(t[0]))return e.formatRows(t);var r=new y,i=[];return t.forEach(function(n){for(var t in n)r.has(t)||i.push(r.add(t))}),[i.map(o).join(n)].concat(t.map(function(t){return i.map(function(n){return o(t[n])}).join(n)})).join("\n")},e.formatRows=function(n){return n.map(u).join("\n")},e},ao.csv=ao.dsv(",","text/csv"),ao.tsv=ao.dsv("	","text/tab-separated-values");var oa,aa,la,ca,fa=this[x(this,"requestAnimationFrame")]||function(n){setTimeout(n,17)};ao.timer=function(){qn.apply(this,arguments)},ao.timer.flush=function(){Rn(),Dn()},ao.round=function(n,t){return t?Math.round(n*(t=Math.pow(10,t)))/t:Math.round(n)};var sa=["y","z","a","f","p","n","\xb5","m","","k","M","G","T","P","E","Z","Y"].map(Un);ao.formatPrefix=function(n,t){var e=0;return(n=+n)&&(0>n&&(n*=-1),t&&(n=ao.round(n,Pn(n,t))),e=1+Math.floor(1e-12+Math.log(n)/Math.LN10),e=Math.max(-24,Math.min(24,3*Math.floor((e-1)/3)))),sa[8+e/3]};var ha=/(?:([^{])?([<>=^]))?([+\- ])?([$#])?(0)?(\d+)?(,)?(\.-?\d+)?([a-z%])?/i,pa=ao.map({b:function(n){return n.toString(2)},c:function(n){return String.fromCharCode(n)},o:function(n){return n.toString(8)},x:function(n){return n.toString(16)},X:function(n){return n.toString(16).toUpperCase()},g:function(n,t){return n.toPrecision(t)},e:function(n,t){return n.toExponential(t)},f:function(n,t){return n.toFixed(t)},r:function(n,t){return(n=ao.round(n,Pn(n,t))).toFixed(Math.max(0,Math.min(20,Pn(n*(1+1e-15),t))))}}),ga=ao.time={},va=Date;Hn.prototype={getDate:function(){return this._.getUTCDate()},getDay:function(){return this._.getUTCDay()},getFullYear:function(){return this._.getUTCFullYear()},getHours:function(){return this._.getUTCHours()},getMilliseconds:function(){return this._.getUTCMilliseconds()},getMinutes:function(){return this._.getUTCMinutes()},getMonth:function(){return this._.getUTCMonth()},getSeconds:function(){return this._.getUTCSeconds()},getTime:function(){return this._.getTime()},getTimezoneOffset:function(){return 0},valueOf:function(){return this._.valueOf()},setDate:function(){da.setUTCDate.apply(this._,arguments)},setDay:function(){da.setUTCDay.apply(this._,arguments)},setFullYear:function(){da.setUTCFullYear.apply(this._,arguments)},setHours:function(){da.setUTCHours.apply(this._,arguments)},setMilliseconds:function(){da.setUTCMilliseconds.apply(this._,arguments)},setMinutes:function(){da.setUTCMinutes.apply(this._,arguments)},setMonth:function(){da.setUTCMonth.apply(this._,arguments)},setSeconds:function(){da.setUTCSeconds.apply(this._,arguments)},setTime:function(){da.setTime.apply(this._,arguments)}};var da=Date.prototype;ga.year=On(function(n){return n=ga.day(n),n.setMonth(0,1),n},function(n,t){n.setFullYear(n.getFullYear()+t)},function(n){return n.getFullYear()}),ga.years=ga.year.range,ga.years.utc=ga.year.utc.range,ga.day=On(function(n){var t=new va(2e3,0);return t.setFullYear(n.getFullYear(),n.getMonth(),n.getDate()),t},function(n,t){n.setDate(n.getDate()+t)},function(n){return n.getDate()-1}),ga.days=ga.day.range,ga.days.utc=ga.day.utc.range,ga.dayOfYear=function(n){var t=ga.year(n);return Math.floor((n-t-6e4*(n.getTimezoneOffset()-t.getTimezoneOffset()))/864e5)},["sunday","monday","tuesday","wednesday","thursday","friday","saturday"].forEach(function(n,t){t=7-t;var e=ga[n]=On(function(n){return(n=ga.day(n)).setDate(n.getDate()-(n.getDay()+t)%7),n},function(n,t){n.setDate(n.getDate()+7*Math.floor(t))},function(n){var e=ga.year(n).getDay();return Math.floor((ga.dayOfYear(n)+(e+t)%7)/7)-(e!==t)});ga[n+"s"]=e.range,ga[n+"s"].utc=e.utc.range,ga[n+"OfYear"]=function(n){var e=ga.year(n).getDay();return Math.floor((ga.dayOfYear(n)+(e+t)%7)/7)}}),ga.week=ga.sunday,ga.weeks=ga.sunday.range,ga.weeks.utc=ga.sunday.utc.range,ga.weekOfYear=ga.sundayOfYear;var ya={"-":"",_:" ",0:"0"},ma=/^\s*\d+/,Ma=/^%/;ao.locale=function(n){return{numberFormat:jn(n),timeFormat:Yn(n)}};var xa=ao.locale({decimal:".",thousands:",",grouping:[3],currency:["$",""],dateTime:"%a %b %e %X %Y",date:"%m/%d/%Y",time:"%H:%M:%S",periods:["AM","PM"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],

- shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]});ao.format=xa.numberFormat,ao.geo={},ft.prototype={s:0,t:0,add:function(n){st(n,this.t,ba),st(ba.s,this.s,this),this.s?this.t+=ba.t:this.s=ba.t},reset:function(){this.s=this.t=0},valueOf:function(){return this.s}};var ba=new ft;ao.geo.stream=function(n,t){n&&_a.hasOwnProperty(n.type)?_a[n.type](n,t):ht(n,t)};var _a={Feature:function(n,t){ht(n.geometry,t)},FeatureCollection:function(n,t){for(var e=n.features,r=-1,i=e.length;++r<i;)ht(e[r].geometry,t)}},wa={Sphere:function(n,t){t.sphere()},Point:function(n,t){n=n.coordinates,t.point(n[0],n[1],n[2])},MultiPoint:function(n,t){for(var e=n.coordinates,r=-1,i=e.length;++r<i;)n=e[r],t.point(n[0],n[1],n[2])},LineString:function(n,t){pt(n.coordinates,t,0)},MultiLineString:function(n,t){for(var e=n.coordinates,r=-1,i=e.length;++r<i;)pt(e[r],t,0)},Polygon:function(n,t){gt(n.coordinates,t)},MultiPolygon:function(n,t){for(var e=n.coordinates,r=-1,i=e.length;++r<i;)gt(e[r],t)},GeometryCollection:function(n,t){for(var e=n.geometries,r=-1,i=e.length;++r<i;)ht(e[r],t)}};ao.geo.area=function(n){return Sa=0,ao.geo.stream(n,Na),Sa};var Sa,ka=new ft,Na={sphere:function(){Sa+=4*Fo},point:b,lineStart:b,lineEnd:b,polygonStart:function(){ka.reset(),Na.lineStart=vt},polygonEnd:function(){var n=2*ka;Sa+=0>n?4*Fo+n:n,Na.lineStart=Na.lineEnd=Na.point=b}};ao.geo.bounds=function(){function n(n,t){M.push(x=[f=n,h=n]),s>t&&(s=t),t>p&&(p=t)}function t(t,e){var r=dt([t*Yo,e*Yo]);if(y){var i=mt(y,r),u=[i[1],-i[0],0],o=mt(u,i);bt(o),o=_t(o);var l=t-g,c=l>0?1:-1,v=o[0]*Zo*c,d=xo(l)>180;if(d^(v>c*g&&c*t>v)){var m=o[1]*Zo;m>p&&(p=m)}else if(v=(v+360)%360-180,d^(v>c*g&&c*t>v)){var m=-o[1]*Zo;s>m&&(s=m)}else s>e&&(s=e),e>p&&(p=e);d?g>t?a(f,t)>a(f,h)&&(h=t):a(t,h)>a(f,h)&&(f=t):h>=f?(f>t&&(f=t),t>h&&(h=t)):t>g?a(f,t)>a(f,h)&&(h=t):a(t,h)>a(f,h)&&(f=t)}else n(t,e);y=r,g=t}function e(){b.point=t}function r(){x[0]=f,x[1]=h,b.point=n,y=null}function i(n,e){if(y){var r=n-g;m+=xo(r)>180?r+(r>0?360:-360):r}else v=n,d=e;Na.point(n,e),t(n,e)}function u(){Na.lineStart()}function o(){i(v,d),Na.lineEnd(),xo(m)>Uo&&(f=-(h=180)),x[0]=f,x[1]=h,y=null}function a(n,t){return(t-=n)<0?t+360:t}function l(n,t){return n[0]-t[0]}function c(n,t){return t[0]<=t[1]?t[0]<=n&&n<=t[1]:n<t[0]||t[1]<n}var f,s,h,p,g,v,d,y,m,M,x,b={point:n,lineStart:e,lineEnd:r,polygonStart:function(){b.point=i,b.lineStart=u,b.lineEnd=o,m=0,Na.polygonStart()},polygonEnd:function(){Na.polygonEnd(),b.point=n,b.lineStart=e,b.lineEnd=r,0>ka?(f=-(h=180),s=-(p=90)):m>Uo?p=90:-Uo>m&&(s=-90),x[0]=f,x[1]=h}};return function(n){p=h=-(f=s=1/0),M=[],ao.geo.stream(n,b);var t=M.length;if(t){M.sort(l);for(var e,r=1,i=M[0],u=[i];t>r;++r)e=M[r],c(e[0],i)||c(e[1],i)?(a(i[0],e[1])>a(i[0],i[1])&&(i[1]=e[1]),a(e[0],i[1])>a(i[0],i[1])&&(i[0]=e[0])):u.push(i=e);for(var o,e,g=-(1/0),t=u.length-1,r=0,i=u[t];t>=r;i=e,++r)e=u[r],(o=a(i[1],e[0]))>g&&(g=o,f=e[0],h=i[1])}return M=x=null,f===1/0||s===1/0?[[NaN,NaN],[NaN,NaN]]:[[f,s],[h,p]]}}(),ao.geo.centroid=function(n){Ea=Aa=Ca=za=La=qa=Ta=Ra=Da=Pa=Ua=0,ao.geo.stream(n,ja);var t=Da,e=Pa,r=Ua,i=t*t+e*e+r*r;return jo>i&&(t=qa,e=Ta,r=Ra,Uo>Aa&&(t=Ca,e=za,r=La),i=t*t+e*e+r*r,jo>i)?[NaN,NaN]:[Math.atan2(e,t)*Zo,tn(r/Math.sqrt(i))*Zo]};var Ea,Aa,Ca,za,La,qa,Ta,Ra,Da,Pa,Ua,ja={sphere:b,point:St,lineStart:Nt,lineEnd:Et,polygonStart:function(){ja.lineStart=At},polygonEnd:function(){ja.lineStart=Nt}},Fa=Rt(zt,jt,Ht,[-Fo,-Fo/2]),Ha=1e9;ao.geo.clipExtent=function(){var n,t,e,r,i,u,o={stream:function(n){return i&&(i.valid=!1),i=u(n),i.valid=!0,i},extent:function(a){return arguments.length?(u=Zt(n=+a[0][0],t=+a[0][1],e=+a[1][0],r=+a[1][1]),i&&(i.valid=!1,i=null),o):[[n,t],[e,r]]}};return o.extent([[0,0],[960,500]])},(ao.geo.conicEqualArea=function(){return Vt(Xt)}).raw=Xt,ao.geo.albers=function(){return ao.geo.conicEqualArea().rotate([96,0]).center([-.6,38.7]).parallels([29.5,45.5]).scale(1070)},ao.geo.albersUsa=function(){function n(n){var u=n[0],o=n[1];return t=null,e(u,o),t||(r(u,o),t)||i(u,o),t}var t,e,r,i,u=ao.geo.albers(),o=ao.geo.conicEqualArea().rotate([154,0]).center([-2,58.5]).parallels([55,65]),a=ao.geo.conicEqualArea().rotate([157,0]).center([-3,19.9]).parallels([8,18]),l={point:function(n,e){t=[n,e]}};return n.invert=function(n){var t=u.scale(),e=u.translate(),r=(n[0]-e[0])/t,i=(n[1]-e[1])/t;return(i>=.12&&.234>i&&r>=-.425&&-.214>r?o:i>=.166&&.234>i&&r>=-.214&&-.115>r?a:u).invert(n)},n.stream=function(n){var t=u.stream(n),e=o.stream(n),r=a.stream(n);return{point:function(n,i){t.point(n,i),e.point(n,i),r.point(n,i)},sphere:function(){t.sphere(),e.sphere(),r.sphere()},lineStart:function(){t.lineStart(),e.lineStart(),r.lineStart()},lineEnd:function(){t.lineEnd(),e.lineEnd(),r.lineEnd()},polygonStart:function(){t.polygonStart(),e.polygonStart(),r.polygonStart()},polygonEnd:function(){t.polygonEnd(),e.polygonEnd(),r.polygonEnd()}}},n.precision=function(t){return arguments.length?(u.precision(t),o.precision(t),a.precision(t),n):u.precision()},n.scale=function(t){return arguments.length?(u.scale(t),o.scale(.35*t),a.scale(t),n.translate(u.translate())):u.scale()},n.translate=function(t){if(!arguments.length)return u.translate();var c=u.scale(),f=+t[0],s=+t[1];return e=u.translate(t).clipExtent([[f-.455*c,s-.238*c],[f+.455*c,s+.238*c]]).stream(l).point,r=o.translate([f-.307*c,s+.201*c]).clipExtent([[f-.425*c+Uo,s+.12*c+Uo],[f-.214*c-Uo,s+.234*c-Uo]]).stream(l).point,i=a.translate([f-.205*c,s+.212*c]).clipExtent([[f-.214*c+Uo,s+.166*c+Uo],[f-.115*c-Uo,s+.234*c-Uo]]).stream(l).point,n},n.scale(1070)};var Oa,Ia,Ya,Za,Va,Xa,$a={point:b,lineStart:b,lineEnd:b,polygonStart:function(){Ia=0,$a.lineStart=$t},polygonEnd:function(){$a.lineStart=$a.lineEnd=$a.point=b,Oa+=xo(Ia/2)}},Ba={point:Bt,lineStart:b,lineEnd:b,polygonStart:b,polygonEnd:b},Wa={point:Gt,lineStart:Kt,lineEnd:Qt,polygonStart:function(){Wa.lineStart=ne},polygonEnd:function(){Wa.point=Gt,Wa.lineStart=Kt,Wa.lineEnd=Qt}};ao.geo.path=function(){function n(n){return n&&("function"==typeof a&&u.pointRadius(+a.apply(this,arguments)),o&&o.valid||(o=i(u)),ao.geo.stream(n,o)),u.result()}function t(){return o=null,n}var e,r,i,u,o,a=4.5;return n.area=function(n){return Oa=0,ao.geo.stream(n,i($a)),Oa},n.centroid=function(n){return Ca=za=La=qa=Ta=Ra=Da=Pa=Ua=0,ao.geo.stream(n,i(Wa)),Ua?[Da/Ua,Pa/Ua]:Ra?[qa/Ra,Ta/Ra]:La?[Ca/La,za/La]:[NaN,NaN]},n.bounds=function(n){return Va=Xa=-(Ya=Za=1/0),ao.geo.stream(n,i(Ba)),[[Ya,Za],[Va,Xa]]},n.projection=function(n){return arguments.length?(i=(e=n)?n.stream||re(n):m,t()):e},n.context=function(n){return arguments.length?(u=null==(r=n)?new Wt:new te(n),"function"!=typeof a&&u.pointRadius(a),t()):r},n.pointRadius=function(t){return arguments.length?(a="function"==typeof t?t:(u.pointRadius(+t),+t),n):a},n.projection(ao.geo.albersUsa()).context(null)},ao.geo.transform=function(n){return{stream:function(t){var e=new ie(t);for(var r in n)e[r]=n[r];return e}}},ie.prototype={point:function(n,t){this.stream.point(n,t)},sphere:function(){this.stream.sphere()},lineStart:function(){this.stream.lineStart()},lineEnd:function(){this.stream.lineEnd()},polygonStart:function(){this.stream.polygonStart()},polygonEnd:function(){this.stream.polygonEnd()}},ao.geo.projection=oe,ao.geo.projectionMutator=ae,(ao.geo.equirectangular=function(){return oe(ce)}).raw=ce.invert=ce,ao.geo.rotation=function(n){function t(t){return t=n(t[0]*Yo,t[1]*Yo),t[0]*=Zo,t[1]*=Zo,t}return n=se(n[0]%360*Yo,n[1]*Yo,n.length>2?n[2]*Yo:0),t.invert=function(t){return t=n.invert(t[0]*Yo,t[1]*Yo),t[0]*=Zo,t[1]*=Zo,t},t},fe.invert=ce,ao.geo.circle=function(){function n(){var n="function"==typeof r?r.apply(this,arguments):r,t=se(-n[0]*Yo,-n[1]*Yo,0).invert,i=[];return e(null,null,1,{point:function(n,e){i.push(n=t(n,e)),n[0]*=Zo,n[1]*=Zo}}),{type:"Polygon",coordinates:[i]}}var t,e,r=[0,0],i=6;return n.origin=function(t){return arguments.length?(r=t,n):r},n.angle=function(r){return arguments.length?(e=ve((t=+r)*Yo,i*Yo),n):t},n.precision=function(r){return arguments.length?(e=ve(t*Yo,(i=+r)*Yo),n):i},n.angle(90)},ao.geo.distance=function(n,t){var e,r=(t[0]-n[0])*Yo,i=n[1]*Yo,u=t[1]*Yo,o=Math.sin(r),a=Math.cos(r),l=Math.sin(i),c=Math.cos(i),f=Math.sin(u),s=Math.cos(u);return Math.atan2(Math.sqrt((e=s*o)*e+(e=c*f-l*s*a)*e),l*f+c*s*a)},ao.geo.graticule=function(){function n(){return{type:"MultiLineString",coordinates:t()}}function t(){return ao.range(Math.ceil(u/d)*d,i,d).map(h).concat(ao.range(Math.ceil(c/y)*y,l,y).map(p)).concat(ao.range(Math.ceil(r/g)*g,e,g).filter(function(n){return xo(n%d)>Uo}).map(f)).concat(ao.range(Math.ceil(a/v)*v,o,v).filter(function(n){return xo(n%y)>Uo}).map(s))}var e,r,i,u,o,a,l,c,f,s,h,p,g=10,v=g,d=90,y=360,m=2.5;return n.lines=function(){return t().map(function(n){return{type:"LineString",coordinates:n}})},n.outline=function(){return{type:"Polygon",coordinates:[h(u).concat(p(l).slice(1),h(i).reverse().slice(1),p(c).reverse().slice(1))]}},n.extent=function(t){return arguments.length?n.majorExtent(t).minorExtent(t):n.minorExtent()},n.majorExtent=function(t){return arguments.length?(u=+t[0][0],i=+t[1][0],c=+t[0][1],l=+t[1][1],u>i&&(t=u,u=i,i=t),c>l&&(t=c,c=l,l=t),n.precision(m)):[[u,c],[i,l]]},n.minorExtent=function(t){return arguments.length?(r=+t[0][0],e=+t[1][0],a=+t[0][1],o=+t[1][1],r>e&&(t=r,r=e,e=t),a>o&&(t=a,a=o,o=t),n.precision(m)):[[r,a],[e,o]]},n.step=function(t){return arguments.length?n.majorStep(t).minorStep(t):n.minorStep()},n.majorStep=function(t){return arguments.length?(d=+t[0],y=+t[1],n):[d,y]},n.minorStep=function(t){return arguments.length?(g=+t[0],v=+t[1],n):[g,v]},n.precision=function(t){return arguments.length?(m=+t,f=ye(a,o,90),s=me(r,e,m),h=ye(c,l,90),p=me(u,i,m),n):m},n.majorExtent([[-180,-90+Uo],[180,90-Uo]]).minorExtent([[-180,-80-Uo],[180,80+Uo]])},ao.geo.greatArc=function(){function n(){return{type:"LineString",coordinates:[t||r.apply(this,arguments),e||i.apply(this,arguments)]}}var t,e,r=Me,i=xe;return n.distance=function(){return ao.geo.distance(t||r.apply(this,arguments),e||i.apply(this,arguments))},n.source=function(e){return arguments.length?(r=e,t="function"==typeof e?null:e,n):r},n.target=function(t){return arguments.length?(i=t,e="function"==typeof t?null:t,n):i},n.precision=function(){return arguments.length?n:0},n},ao.geo.interpolate=function(n,t){return be(n[0]*Yo,n[1]*Yo,t[0]*Yo,t[1]*Yo)},ao.geo.length=function(n){return Ja=0,ao.geo.stream(n,Ga),Ja};var Ja,Ga={sphere:b,point:b,lineStart:_e,lineEnd:b,polygonStart:b,polygonEnd:b},Ka=we(function(n){return Math.sqrt(2/(1+n))},function(n){return 2*Math.asin(n/2)});(ao.geo.azimuthalEqualArea=function(){return oe(Ka)}).raw=Ka;var Qa=we(function(n){var t=Math.acos(n);return t&&t/Math.sin(t)},m);(ao.geo.azimuthalEquidistant=function(){return oe(Qa)}).raw=Qa,(ao.geo.conicConformal=function(){return Vt(Se)}).raw=Se,(ao.geo.conicEquidistant=function(){return Vt(ke)}).raw=ke;var nl=we(function(n){return 1/n},Math.atan);(ao.geo.gnomonic=function(){return oe(nl)}).raw=nl,Ne.invert=function(n,t){return[n,2*Math.atan(Math.exp(t))-Io]},(ao.geo.mercator=function(){return Ee(Ne)}).raw=Ne;var tl=we(function(){return 1},Math.asin);(ao.geo.orthographic=function(){return oe(tl)}).raw=tl;var el=we(function(n){return 1/(1+n)},function(n){return 2*Math.atan(n)});(ao.geo.stereographic=function(){return oe(el)}).raw=el,Ae.invert=function(n,t){return[-t,2*Math.atan(Math.exp(n))-Io]},(ao.geo.transverseMercator=function(){var n=Ee(Ae),t=n.center,e=n.rotate;return n.center=function(n){return n?t([-n[1],n[0]]):(n=t(),[n[1],-n[0]])},n.rotate=function(n){return n?e([n[0],n[1],n.length>2?n[2]+90:90]):(n=e(),[n[0],n[1],n[2]-90])},e([0,0,90])}).raw=Ae,ao.geom={},ao.geom.hull=function(n){function t(n){if(n.length<3)return[];var t,i=En(e),u=En(r),o=n.length,a=[],l=[];for(t=0;o>t;t++)a.push([+i.call(this,n[t],t),+u.call(this,n[t],t),t]);for(a.sort(qe),t=0;o>t;t++)l.push([a[t][0],-a[t][1]]);var c=Le(a),f=Le(l),s=f[0]===c[0],h=f[f.length-1]===c[c.length-1],p=[];for(t=c.length-1;t>=0;--t)p.push(n[a[c[t]][2]]);for(t=+s;t<f.length-h;++t)p.push(n[a[f[t]][2]]);return p}var e=Ce,r=ze;return arguments.length?t(n):(t.x=function(n){return arguments.length?(e=n,t):e},t.y=function(n){return arguments.length?(r=n,t):r},t)},ao.geom.polygon=function(n){return ko(n,rl),n};var rl=ao.geom.polygon.prototype=[];rl.area=function(){for(var n,t=-1,e=this.length,r=this[e-1],i=0;++t<e;)n=r,r=this[t],i+=n[1]*r[0]-n[0]*r[1];return.5*i},rl.centroid=function(n){var t,e,r=-1,i=this.length,u=0,o=0,a=this[i-1];for(arguments.length||(n=-1/(6*this.area()));++r<i;)t=a,a=this[r],e=t[0]*a[1]-a[0]*t[1],u+=(t[0]+a[0])*e,o+=(t[1]+a[1])*e;return[u*n,o*n]},rl.clip=function(n){for(var t,e,r,i,u,o,a=De(n),l=-1,c=this.length-De(this),f=this[c-1];++l<c;){for(t=n.slice(),n.length=0,i=this[l],u=t[(r=t.length-a)-1],e=-1;++e<r;)o=t[e],Te(o,f,i)?(Te(u,f,i)||n.push(Re(u,o,f,i)),n.push(o)):Te(u,f,i)&&n.push(Re(u,o,f,i)),u=o;a&&n.push(n[0]),f=i}return n};var il,ul,ol,al,ll,cl=[],fl=[];Ye.prototype.prepare=function(){for(var n,t=this.edges,e=t.length;e--;)n=t[e].edge,n.b&&n.a||t.splice(e,1);return t.sort(Ve),t.length},tr.prototype={start:function(){return this.edge.l===this.site?this.edge.a:this.edge.b},end:function(){return this.edge.l===this.site?this.edge.b:this.edge.a}},er.prototype={insert:function(n,t){var e,r,i;if(n){if(t.P=n,t.N=n.N,n.N&&(n.N.P=t),n.N=t,n.R){for(n=n.R;n.L;)n=n.L;n.L=t}else n.R=t;e=n}else this._?(n=or(this._),t.P=null,t.N=n,n.P=n.L=t,e=n):(t.P=t.N=null,this._=t,e=null);for(t.L=t.R=null,t.U=e,t.C=!0,n=t;e&&e.C;)r=e.U,e===r.L?(i=r.R,i&&i.C?(e.C=i.C=!1,r.C=!0,n=r):(n===e.R&&(ir(this,e),n=e,e=n.U),e.C=!1,r.C=!0,ur(this,r))):(i=r.L,i&&i.C?(e.C=i.C=!1,r.C=!0,n=r):(n===e.L&&(ur(this,e),n=e,e=n.U),e.C=!1,r.C=!0,ir(this,r))),e=n.U;this._.C=!1},remove:function(n){n.N&&(n.N.P=n.P),n.P&&(n.P.N=n.N),n.N=n.P=null;var t,e,r,i=n.U,u=n.L,o=n.R;if(e=u?o?or(o):u:o,i?i.L===n?i.L=e:i.R=e:this._=e,u&&o?(r=e.C,e.C=n.C,e.L=u,u.U=e,e!==o?(i=e.U,e.U=n.U,n=e.R,i.L=n,e.R=o,o.U=e):(e.U=i,i=e,n=e.R)):(r=n.C,n=e),n&&(n.U=i),!r){if(n&&n.C)return void(n.C=!1);do{if(n===this._)break;if(n===i.L){if(t=i.R,t.C&&(t.C=!1,i.C=!0,ir(this,i),t=i.R),t.L&&t.L.C||t.R&&t.R.C){t.R&&t.R.C||(t.L.C=!1,t.C=!0,ur(this,t),t=i.R),t.C=i.C,i.C=t.R.C=!1,ir(this,i),n=this._;break}}else if(t=i.L,t.C&&(t.C=!1,i.C=!0,ur(this,i),t=i.L),t.L&&t.L.C||t.R&&t.R.C){t.L&&t.L.C||(t.R.C=!1,t.C=!0,ir(this,t),t=i.L),t.C=i.C,i.C=t.L.C=!1,ur(this,i),n=this._;break}t.C=!0,n=i,i=i.U}while(!n.C);n&&(n.C=!1)}}},ao.geom.voronoi=function(n){function t(n){var t=new Array(n.length),r=a[0][0],i=a[0][1],u=a[1][0],o=a[1][1];return ar(e(n),a).cells.forEach(function(e,a){var l=e.edges,c=e.site,f=t[a]=l.length?l.map(function(n){var t=n.start();return[t.x,t.y]}):c.x>=r&&c.x<=u&&c.y>=i&&c.y<=o?[[r,o],[u,o],[u,i],[r,i]]:[];f.point=n[a]}),t}function e(n){return n.map(function(n,t){return{x:Math.round(u(n,t)/Uo)*Uo,y:Math.round(o(n,t)/Uo)*Uo,i:t}})}var r=Ce,i=ze,u=r,o=i,a=sl;return n?t(n):(t.links=function(n){return ar(e(n)).edges.filter(function(n){return n.l&&n.r}).map(function(t){return{source:n[t.l.i],target:n[t.r.i]}})},t.triangles=function(n){var t=[];return ar(e(n)).cells.forEach(function(e,r){for(var i,u,o=e.site,a=e.edges.sort(Ve),l=-1,c=a.length,f=a[c-1].edge,s=f.l===o?f.r:f.l;++l<c;)i=f,u=s,f=a[l].edge,s=f.l===o?f.r:f.l,r<u.i&&r<s.i&&cr(o,u,s)<0&&t.push([n[r],n[u.i],n[s.i]])}),t},t.x=function(n){return arguments.length?(u=En(r=n),t):r},t.y=function(n){return arguments.length?(o=En(i=n),t):i},t.clipExtent=function(n){return arguments.length?(a=null==n?sl:n,t):a===sl?null:a},t.size=function(n){return arguments.length?t.clipExtent(n&&[[0,0],n]):a===sl?null:a&&a[1]},t)};var sl=[[-1e6,-1e6],[1e6,1e6]];ao.geom.delaunay=function(n){return ao.geom.voronoi().triangles(n)},ao.geom.quadtree=function(n,t,e,r,i){function u(n){function u(n,t,e,r,i,u,o,a){if(!isNaN(e)&&!isNaN(r))if(n.leaf){var l=n.x,f=n.y;if(null!=l)if(xo(l-e)+xo(f-r)<.01)c(n,t,e,r,i,u,o,a);else{var s=n.point;n.x=n.y=n.point=null,c(n,s,l,f,i,u,o,a),c(n,t,e,r,i,u,o,a)}else n.x=e,n.y=r,n.point=t}else c(n,t,e,r,i,u,o,a)}function c(n,t,e,r,i,o,a,l){var c=.5*(i+a),f=.5*(o+l),s=e>=c,h=r>=f,p=h<<1|s;n.leaf=!1,n=n.nodes[p]||(n.nodes[p]=hr()),s?i=c:a=c,h?o=f:l=f,u(n,t,e,r,i,o,a,l)}var f,s,h,p,g,v,d,y,m,M=En(a),x=En(l);if(null!=t)v=t,d=e,y=r,m=i;else if(y=m=-(v=d=1/0),s=[],h=[],g=n.length,o)for(p=0;g>p;++p)f=n[p],f.x<v&&(v=f.x),f.y<d&&(d=f.y),f.x>y&&(y=f.x),f.y>m&&(m=f.y),s.push(f.x),h.push(f.y);else for(p=0;g>p;++p){var b=+M(f=n[p],p),_=+x(f,p);v>b&&(v=b),d>_&&(d=_),b>y&&(y=b),_>m&&(m=_),s.push(b),h.push(_)}var w=y-v,S=m-d;w>S?m=d+w:y=v+S;var k=hr();if(k.add=function(n){u(k,n,+M(n,++p),+x(n,p),v,d,y,m)},k.visit=function(n){pr(n,k,v,d,y,m)},k.find=function(n){return gr(k,n[0],n[1],v,d,y,m)},p=-1,null==t){for(;++p<g;)u(k,n[p],s[p],h[p],v,d,y,m);--p}else n.forEach(k.add);return s=h=n=f=null,k}var o,a=Ce,l=ze;return(o=arguments.length)?(a=fr,l=sr,3===o&&(i=e,r=t,e=t=0),u(n)):(u.x=function(n){return arguments.length?(a=n,u):a},u.y=function(n){return arguments.length?(l=n,u):l},u.extent=function(n){return arguments.length?(null==n?t=e=r=i=null:(t=+n[0][0],e=+n[0][1],r=+n[1][0],i=+n[1][1]),u):null==t?null:[[t,e],[r,i]]},u.size=function(n){return arguments.length?(null==n?t=e=r=i=null:(t=e=0,r=+n[0],i=+n[1]),u):null==t?null:[r-t,i-e]},u)},ao.interpolateRgb=vr,ao.interpolateObject=dr,ao.interpolateNumber=yr,ao.interpolateString=mr;var hl=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,pl=new RegExp(hl.source,"g");ao.interpolate=Mr,ao.interpolators=[function(n,t){var e=typeof t;return("string"===e?ua.has(t.toLowerCase())||/^(#|rgb\(|hsl\()/i.test(t)?vr:mr:t instanceof an?vr:Array.isArray(t)?xr:"object"===e&&isNaN(t)?dr:yr)(n,t)}],ao.interpolateArray=xr;var gl=function(){return m},vl=ao.map({linear:gl,poly:Er,quad:function(){return Sr},cubic:function(){return kr},sin:function(){return Ar},exp:function(){return Cr},circle:function(){return zr},elastic:Lr,back:qr,bounce:function(){return Tr}}),dl=ao.map({"in":m,out:_r,"in-out":wr,"out-in":function(n){return wr(_r(n))}});ao.ease=function(n){var t=n.indexOf("-"),e=t>=0?n.slice(0,t):n,r=t>=0?n.slice(t+1):"in";return e=vl.get(e)||gl,r=dl.get(r)||m,br(r(e.apply(null,lo.call(arguments,1))))},ao.interpolateHcl=Rr,ao.interpolateHsl=Dr,ao.interpolateLab=Pr,ao.interpolateRound=Ur,ao.transform=function(n){var t=fo.createElementNS(ao.ns.prefix.svg,"g");return(ao.transform=function(n){if(null!=n){t.setAttribute("transform",n);var e=t.transform.baseVal.consolidate()}return new jr(e?e.matrix:yl)})(n)},jr.prototype.toString=function(){return"translate("+this.translate+")rotate("+this.rotate+")skewX("+this.skew+")scale("+this.scale+")"};var yl={a:1,b:0,c:0,d:1,e:0,f:0};ao.interpolateTransform=$r,ao.layout={},ao.layout.bundle=function(){return function(n){for(var t=[],e=-1,r=n.length;++e<r;)t.push(Jr(n[e]));return t}},ao.layout.chord=function(){function n(){var n,c,s,h,p,g={},v=[],d=ao.range(u),y=[];for(e=[],r=[],n=0,h=-1;++h<u;){for(c=0,p=-1;++p<u;)c+=i[h][p];v.push(c),y.push(ao.range(u)),n+=c}for(o&&d.sort(function(n,t){return o(v[n],v[t])}),a&&y.forEach(function(n,t){n.sort(function(n,e){return a(i[t][n],i[t][e])})}),n=(Ho-f*u)/n,c=0,h=-1;++h<u;){for(s=c,p=-1;++p<u;){var m=d[h],M=y[m][p],x=i[m][M],b=c,_=c+=x*n;g[m+"-"+M]={index:m,subindex:M,startAngle:b,endAngle:_,value:x}}r[m]={index:m,startAngle:s,endAngle:c,value:v[m]},c+=f}for(h=-1;++h<u;)for(p=h-1;++p<u;){var w=g[h+"-"+p],S=g[p+"-"+h];(w.value||S.value)&&e.push(w.value<S.value?{source:S,target:w}:{source:w,target:S})}l&&t()}function t(){e.sort(function(n,t){return l((n.source.value+n.target.value)/2,(t.source.value+t.target.value)/2)})}var e,r,i,u,o,a,l,c={},f=0;return c.matrix=function(n){return arguments.length?(u=(i=n)&&i.length,e=r=null,c):i},c.padding=function(n){return arguments.length?(f=n,e=r=null,c):f},c.sortGroups=function(n){return arguments.length?(o=n,e=r=null,c):o},c.sortSubgroups=function(n){return arguments.length?(a=n,e=null,c):a},c.sortChords=function(n){return arguments.length?(l=n,e&&t(),c):l},c.chords=function(){return e||n(),e},c.groups=function(){return r||n(),r},c},ao.layout.force=function(){function n(n){return function(t,e,r,i){if(t.point!==n){var u=t.cx-n.x,o=t.cy-n.y,a=i-e,l=u*u+o*o;if(l>a*a/y){if(v>l){var c=t.charge/l;n.px-=u*c,n.py-=o*c}return!0}if(t.point&&l&&v>l){var c=t.pointCharge/l;n.px-=u*c,n.py-=o*c}}return!t.charge}}function t(n){n.px=ao.event.x,n.py=ao.event.y,l.resume()}var e,r,i,u,o,a,l={},c=ao.dispatch("start","tick","end"),f=[1,1],s=.9,h=ml,p=Ml,g=-30,v=xl,d=.1,y=.64,M=[],x=[];return l.tick=function(){if((i*=.99)<.005)return e=null,c.end({type:"end",alpha:i=0}),!0;var t,r,l,h,p,v,y,m,b,_=M.length,w=x.length;for(r=0;w>r;++r)l=x[r],h=l.source,p=l.target,m=p.x-h.x,b=p.y-h.y,(v=m*m+b*b)&&(v=i*o[r]*((v=Math.sqrt(v))-u[r])/v,m*=v,b*=v,p.x-=m*(y=h.weight+p.weight?h.weight/(h.weight+p.weight):.5),p.y-=b*y,h.x+=m*(y=1-y),h.y+=b*y);if((y=i*d)&&(m=f[0]/2,b=f[1]/2,r=-1,y))for(;++r<_;)l=M[r],l.x+=(m-l.x)*y,l.y+=(b-l.y)*y;if(g)for(ri(t=ao.geom.quadtree(M),i,a),r=-1;++r<_;)(l=M[r]).fixed||t.visit(n(l));for(r=-1;++r<_;)l=M[r],l.fixed?(l.x=l.px,l.y=l.py):(l.x-=(l.px-(l.px=l.x))*s,l.y-=(l.py-(l.py=l.y))*s);c.tick({type:"tick",alpha:i})},l.nodes=function(n){return arguments.length?(M=n,l):M},l.links=function(n){return arguments.length?(x=n,l):x},l.size=function(n){return arguments.length?(f=n,l):f},l.linkDistance=function(n){return arguments.length?(h="function"==typeof n?n:+n,l):h},l.distance=l.linkDistance,l.linkStrength=function(n){return arguments.length?(p="function"==typeof n?n:+n,l):p},l.friction=function(n){return arguments.length?(s=+n,l):s},l.charge=function(n){return arguments.length?(g="function"==typeof n?n:+n,l):g},l.chargeDistance=function(n){return arguments.length?(v=n*n,l):Math.sqrt(v)},l.gravity=function(n){return arguments.length?(d=+n,l):d},l.theta=function(n){return arguments.length?(y=n*n,l):Math.sqrt(y)},l.alpha=function(n){return arguments.length?(n=+n,i?n>0?i=n:(e.c=null,e.t=NaN,e=null,c.end({type:"end",alpha:i=0})):n>0&&(c.start({type:"start",alpha:i=n}),e=qn(l.tick)),l):i},l.start=function(){function n(n,r){if(!e){for(e=new Array(i),l=0;i>l;++l)e[l]=[];for(l=0;c>l;++l){var u=x[l];e[u.source.index].push(u.target),e[u.target.index].push(u.source)}}for(var o,a=e[t],l=-1,f=a.length;++l<f;)if(!isNaN(o=a[l][n]))return o;return Math.random()*r}var t,e,r,i=M.length,c=x.length,s=f[0],v=f[1];for(t=0;i>t;++t)(r=M[t]).index=t,r.weight=0;for(t=0;c>t;++t)r=x[t],"number"==typeof r.source&&(r.source=M[r.source]),"number"==typeof r.target&&(r.target=M[r.target]),++r.source.weight,++r.target.weight;for(t=0;i>t;++t)r=M[t],isNaN(r.x)&&(r.x=n("x",s)),isNaN(r.y)&&(r.y=n("y",v)),isNaN(r.px)&&(r.px=r.x),isNaN(r.py)&&(r.py=r.y);if(u=[],"function"==typeof h)for(t=0;c>t;++t)u[t]=+h.call(this,x[t],t);else for(t=0;c>t;++t)u[t]=h;if(o=[],"function"==typeof p)for(t=0;c>t;++t)o[t]=+p.call(this,x[t],t);else for(t=0;c>t;++t)o[t]=p;if(a=[],"function"==typeof g)for(t=0;i>t;++t)a[t]=+g.call(this,M[t],t);else for(t=0;i>t;++t)a[t]=g;return l.resume()},l.resume=function(){return l.alpha(.1)},l.stop=function(){return l.alpha(0)},l.drag=function(){return r||(r=ao.behavior.drag().origin(m).on("dragstart.force",Qr).on("drag.force",t).on("dragend.force",ni)),arguments.length?void this.on("mouseover.force",ti).on("mouseout.force",ei).call(r):r},ao.rebind(l,c,"on")};var ml=20,Ml=1,xl=1/0;ao.layout.hierarchy=function(){function n(i){var u,o=[i],a=[];for(i.depth=0;null!=(u=o.pop());)if(a.push(u),(c=e.call(n,u,u.depth))&&(l=c.length)){for(var l,c,f;--l>=0;)o.push(f=c[l]),f.parent=u,f.depth=u.depth+1;r&&(u.value=0),u.children=c}else r&&(u.value=+r.call(n,u,u.depth)||0),delete u.children;return oi(i,function(n){var e,i;t&&(e=n.children)&&e.sort(t),r&&(i=n.parent)&&(i.value+=n.value)}),a}var t=ci,e=ai,r=li;return n.sort=function(e){return arguments.length?(t=e,n):t},n.children=function(t){return arguments.length?(e=t,n):e},n.value=function(t){return arguments.length?(r=t,n):r},n.revalue=function(t){return r&&(ui(t,function(n){n.children&&(n.value=0)}),oi(t,function(t){var e;t.children||(t.value=+r.call(n,t,t.depth)||0),(e=t.parent)&&(e.value+=t.value)})),t},n},ao.layout.partition=function(){function n(t,e,r,i){var u=t.children;if(t.x=e,t.y=t.depth*i,t.dx=r,t.dy=i,u&&(o=u.length)){var o,a,l,c=-1;for(r=t.value?r/t.value:0;++c<o;)n(a=u[c],e,l=a.value*r,i),e+=l}}function t(n){var e=n.children,r=0;if(e&&(i=e.length))for(var i,u=-1;++u<i;)r=Math.max(r,t(e[u]));return 1+r}function e(e,u){var o=r.call(this,e,u);return n(o[0],0,i[0],i[1]/t(o[0])),o}var r=ao.layout.hierarchy(),i=[1,1];return e.size=function(n){return arguments.length?(i=n,e):i},ii(e,r)},ao.layout.pie=function(){function n(o){var a,l=o.length,c=o.map(function(e,r){return+t.call(n,e,r)}),f=+("function"==typeof r?r.apply(this,arguments):r),s=("function"==typeof i?i.apply(this,arguments):i)-f,h=Math.min(Math.abs(s)/l,+("function"==typeof u?u.apply(this,arguments):u)),p=h*(0>s?-1:1),g=ao.sum(c),v=g?(s-l*p)/g:0,d=ao.range(l),y=[];return null!=e&&d.sort(e===bl?function(n,t){return c[t]-c[n]}:function(n,t){return e(o[n],o[t])}),d.forEach(function(n){y[n]={data:o[n],value:a=c[n],startAngle:f,endAngle:f+=a*v+p,padAngle:h}}),y}var t=Number,e=bl,r=0,i=Ho,u=0;return n.value=function(e){return arguments.length?(t=e,n):t},n.sort=function(t){return arguments.length?(e=t,n):e},n.startAngle=function(t){return arguments.length?(r=t,n):r},n.endAngle=function(t){return arguments.length?(i=t,n):i},n.padAngle=function(t){return arguments.length?(u=t,n):u},n};var bl={};ao.layout.stack=function(){function n(a,l){if(!(h=a.length))return a;var c=a.map(function(e,r){return t.call(n,e,r)}),f=c.map(function(t){return t.map(function(t,e){return[u.call(n,t,e),o.call(n,t,e)]})}),s=e.call(n,f,l);c=ao.permute(c,s),f=ao.permute(f,s);var h,p,g,v,d=r.call(n,f,l),y=c[0].length;for(g=0;y>g;++g)for(i.call(n,c[0][g],v=d[g],f[0][g][1]),p=1;h>p;++p)i.call(n,c[p][g],v+=f[p-1][g][1],f[p][g][1]);return a}var t=m,e=gi,r=vi,i=pi,u=si,o=hi;return n.values=function(e){return arguments.length?(t=e,n):t},n.order=function(t){return arguments.length?(e="function"==typeof t?t:_l.get(t)||gi,n):e},n.offset=function(t){return arguments.length?(r="function"==typeof t?t:wl.get(t)||vi,n):r},n.x=function(t){return arguments.length?(u=t,n):u},n.y=function(t){return arguments.length?(o=t,n):o},n.out=function(t){return arguments.length?(i=t,n):i},n};var _l=ao.map({"inside-out":function(n){var t,e,r=n.length,i=n.map(di),u=n.map(yi),o=ao.range(r).sort(function(n,t){return i[n]-i[t]}),a=0,l=0,c=[],f=[];for(t=0;r>t;++t)e=o[t],l>a?(a+=u[e],c.push(e)):(l+=u[e],f.push(e));return f.reverse().concat(c)},reverse:function(n){return ao.range(n.length).reverse()},"default":gi}),wl=ao.map({silhouette:function(n){var t,e,r,i=n.length,u=n[0].length,o=[],a=0,l=[];for(e=0;u>e;++e){for(t=0,r=0;i>t;t++)r+=n[t][e][1];r>a&&(a=r),o.push(r)}for(e=0;u>e;++e)l[e]=(a-o[e])/2;return l},wiggle:function(n){var t,e,r,i,u,o,a,l,c,f=n.length,s=n[0],h=s.length,p=[];for(p[0]=l=c=0,e=1;h>e;++e){for(t=0,i=0;f>t;++t)i+=n[t][e][1];for(t=0,u=0,a=s[e][0]-s[e-1][0];f>t;++t){for(r=0,o=(n[t][e][1]-n[t][e-1][1])/(2*a);t>r;++r)o+=(n[r][e][1]-n[r][e-1][1])/a;u+=o*n[t][e][1]}p[e]=l-=i?u/i*a:0,c>l&&(c=l)}for(e=0;h>e;++e)p[e]-=c;return p},expand:function(n){var t,e,r,i=n.length,u=n[0].length,o=1/i,a=[];for(e=0;u>e;++e){for(t=0,r=0;i>t;t++)r+=n[t][e][1];if(r)for(t=0;i>t;t++)n[t][e][1]/=r;else for(t=0;i>t;t++)n[t][e][1]=o}for(e=0;u>e;++e)a[e]=0;return a},zero:vi});ao.layout.histogram=function(){function n(n,u){for(var o,a,l=[],c=n.map(e,this),f=r.call(this,c,u),s=i.call(this,f,c,u),u=-1,h=c.length,p=s.length-1,g=t?1:1/h;++u<p;)o=l[u]=[],o.dx=s[u+1]-(o.x=s[u]),o.y=0;if(p>0)for(u=-1;++u<h;)a=c[u],a>=f[0]&&a<=f[1]&&(o=l[ao.bisect(s,a,1,p)-1],o.y+=g,o.push(n[u]));return l}var t=!0,e=Number,r=bi,i=Mi;return n.value=function(t){return arguments.length?(e=t,n):e},n.range=function(t){return arguments.length?(r=En(t),n):r},n.bins=function(t){return arguments.length?(i="number"==typeof t?function(n){return xi(n,t)}:En(t),n):i},n.frequency=function(e){return arguments.length?(t=!!e,n):t},n},ao.layout.pack=function(){function n(n,u){var o=e.call(this,n,u),a=o[0],l=i[0],c=i[1],f=null==t?Math.sqrt:"function"==typeof t?t:function(){return t};if(a.x=a.y=0,oi(a,function(n){n.r=+f(n.value)}),oi(a,Ni),r){var s=r*(t?1:Math.max(2*a.r/l,2*a.r/c))/2;oi(a,function(n){n.r+=s}),oi(a,Ni),oi(a,function(n){n.r-=s})}return Ci(a,l/2,c/2,t?1:1/Math.max(2*a.r/l,2*a.r/c)),o}var t,e=ao.layout.hierarchy().sort(_i),r=0,i=[1,1];return n.size=function(t){return arguments.length?(i=t,n):i},n.radius=function(e){return arguments.length?(t=null==e||"function"==typeof e?e:+e,n):t},n.padding=function(t){return arguments.length?(r=+t,n):r},ii(n,e)},ao.layout.tree=function(){function n(n,i){var f=o.call(this,n,i),s=f[0],h=t(s);if(oi(h,e),h.parent.m=-h.z,ui(h,r),c)ui(s,u);else{var p=s,g=s,v=s;ui(s,function(n){n.x<p.x&&(p=n),n.x>g.x&&(g=n),n.depth>v.depth&&(v=n)});var d=a(p,g)/2-p.x,y=l[0]/(g.x+a(g,p)/2+d),m=l[1]/(v.depth||1);ui(s,function(n){n.x=(n.x+d)*y,n.y=n.depth*m})}return f}function t(n){for(var t,e={A:null,children:[n]},r=[e];null!=(t=r.pop());)for(var i,u=t.children,o=0,a=u.length;a>o;++o)r.push((u[o]=i={_:u[o],parent:t,children:(i=u[o].children)&&i.slice()||[],A:null,a:null,z:0,m:0,c:0,s:0,t:null,i:o}).a=i);return e.children[0]}function e(n){var t=n.children,e=n.parent.children,r=n.i?e[n.i-1]:null;if(t.length){Di(n);var u=(t[0].z+t[t.length-1].z)/2;r?(n.z=r.z+a(n._,r._),n.m=n.z-u):n.z=u}else r&&(n.z=r.z+a(n._,r._));n.parent.A=i(n,r,n.parent.A||e[0])}function r(n){n._.x=n.z+n.parent.m,n.m+=n.parent.m}function i(n,t,e){if(t){for(var r,i=n,u=n,o=t,l=i.parent.children[0],c=i.m,f=u.m,s=o.m,h=l.m;o=Ti(o),i=qi(i),o&&i;)l=qi(l),u=Ti(u),u.a=n,r=o.z+s-i.z-c+a(o._,i._),r>0&&(Ri(Pi(o,n,e),n,r),c+=r,f+=r),s+=o.m,c+=i.m,h+=l.m,f+=u.m;o&&!Ti(u)&&(u.t=o,u.m+=s-f),i&&!qi(l)&&(l.t=i,l.m+=c-h,e=n)}return e}function u(n){n.x*=l[0],n.y=n.depth*l[1]}var o=ao.layout.hierarchy().sort(null).value(null),a=Li,l=[1,1],c=null;return n.separation=function(t){return arguments.length?(a=t,n):a},n.size=function(t){return arguments.length?(c=null==(l=t)?u:null,n):c?null:l},n.nodeSize=function(t){return arguments.length?(c=null==(l=t)?null:u,n):c?l:null},ii(n,o)},ao.layout.cluster=function(){function n(n,u){var o,a=t.call(this,n,u),l=a[0],c=0;oi(l,function(n){var t=n.children;t&&t.length?(n.x=ji(t),n.y=Ui(t)):(n.x=o?c+=e(n,o):0,n.y=0,o=n)});var f=Fi(l),s=Hi(l),h=f.x-e(f,s)/2,p=s.x+e(s,f)/2;return oi(l,i?function(n){n.x=(n.x-l.x)*r[0],n.y=(l.y-n.y)*r[1]}:function(n){n.x=(n.x-h)/(p-h)*r[0],n.y=(1-(l.y?n.y/l.y:1))*r[1]}),a}var t=ao.layout.hierarchy().sort(null).value(null),e=Li,r=[1,1],i=!1;return n.separation=function(t){return arguments.length?(e=t,n):e},n.size=function(t){return arguments.length?(i=null==(r=t),n):i?null:r},n.nodeSize=function(t){return arguments.length?(i=null!=(r=t),n):i?r:null},ii(n,t)},ao.layout.treemap=function(){function n(n,t){for(var e,r,i=-1,u=n.length;++i<u;)r=(e=n[i]).value*(0>t?0:t),e.area=isNaN(r)||0>=r?0:r}function t(e){var u=e.children;if(u&&u.length){var o,a,l,c=s(e),f=[],h=u.slice(),g=1/0,v="slice"===p?c.dx:"dice"===p?c.dy:"slice-dice"===p?1&e.depth?c.dy:c.dx:Math.min(c.dx,c.dy);for(n(h,c.dx*c.dy/e.value),f.area=0;(l=h.length)>0;)f.push(o=h[l-1]),f.area+=o.area,"squarify"!==p||(a=r(f,v))<=g?(h.pop(),g=a):(f.area-=f.pop().area,i(f,v,c,!1),v=Math.min(c.dx,c.dy),f.length=f.area=0,g=1/0);f.length&&(i(f,v,c,!0),f.length=f.area=0),u.forEach(t)}}function e(t){var r=t.children;if(r&&r.length){var u,o=s(t),a=r.slice(),l=[];for(n(a,o.dx*o.dy/t.value),l.area=0;u=a.pop();)l.push(u),l.area+=u.area,null!=u.z&&(i(l,u.z?o.dx:o.dy,o,!a.length),l.length=l.area=0);r.forEach(e)}}function r(n,t){for(var e,r=n.area,i=0,u=1/0,o=-1,a=n.length;++o<a;)(e=n[o].area)&&(u>e&&(u=e),e>i&&(i=e));return r*=r,t*=t,r?Math.max(t*i*g/r,r/(t*u*g)):1/0}function i(n,t,e,r){var i,u=-1,o=n.length,a=e.x,c=e.y,f=t?l(n.area/t):0;

- if(t==e.dx){for((r||f>e.dy)&&(f=e.dy);++u<o;)i=n[u],i.x=a,i.y=c,i.dy=f,a+=i.dx=Math.min(e.x+e.dx-a,f?l(i.area/f):0);i.z=!0,i.dx+=e.x+e.dx-a,e.y+=f,e.dy-=f}else{for((r||f>e.dx)&&(f=e.dx);++u<o;)i=n[u],i.x=a,i.y=c,i.dx=f,c+=i.dy=Math.min(e.y+e.dy-c,f?l(i.area/f):0);i.z=!1,i.dy+=e.y+e.dy-c,e.x+=f,e.dx-=f}}function u(r){var i=o||a(r),u=i[0];return u.x=u.y=0,u.value?(u.dx=c[0],u.dy=c[1]):u.dx=u.dy=0,o&&a.revalue(u),n([u],u.dx*u.dy/u.value),(o?e:t)(u),h&&(o=i),i}var o,a=ao.layout.hierarchy(),l=Math.round,c=[1,1],f=null,s=Oi,h=!1,p="squarify",g=.5*(1+Math.sqrt(5));return u.size=function(n){return arguments.length?(c=n,u):c},u.padding=function(n){function t(t){var e=n.call(u,t,t.depth);return null==e?Oi(t):Ii(t,"number"==typeof e?[e,e,e,e]:e)}function e(t){return Ii(t,n)}if(!arguments.length)return f;var r;return s=null==(f=n)?Oi:"function"==(r=typeof n)?t:"number"===r?(n=[n,n,n,n],e):e,u},u.round=function(n){return arguments.length?(l=n?Math.round:Number,u):l!=Number},u.sticky=function(n){return arguments.length?(h=n,o=null,u):h},u.ratio=function(n){return arguments.length?(g=n,u):g},u.mode=function(n){return arguments.length?(p=n+"",u):p},ii(u,a)},ao.random={normal:function(n,t){var e=arguments.length;return 2>e&&(t=1),1>e&&(n=0),function(){var e,r,i;do e=2*Math.random()-1,r=2*Math.random()-1,i=e*e+r*r;while(!i||i>1);return n+t*e*Math.sqrt(-2*Math.log(i)/i)}},logNormal:function(){var n=ao.random.normal.apply(ao,arguments);return function(){return Math.exp(n())}},bates:function(n){var t=ao.random.irwinHall(n);return function(){return t()/n}},irwinHall:function(n){return function(){for(var t=0,e=0;n>e;e++)t+=Math.random();return t}}},ao.scale={};var Sl={floor:m,ceil:m};ao.scale.linear=function(){return Wi([0,1],[0,1],Mr,!1)};var kl={s:1,g:1,p:1,r:1,e:1};ao.scale.log=function(){return ru(ao.scale.linear().domain([0,1]),10,!0,[1,10])};var Nl=ao.format(".0e"),El={floor:function(n){return-Math.ceil(-n)},ceil:function(n){return-Math.floor(-n)}};ao.scale.pow=function(){return iu(ao.scale.linear(),1,[0,1])},ao.scale.sqrt=function(){return ao.scale.pow().exponent(.5)},ao.scale.ordinal=function(){return ou([],{t:"range",a:[[]]})},ao.scale.category10=function(){return ao.scale.ordinal().range(Al)},ao.scale.category20=function(){return ao.scale.ordinal().range(Cl)},ao.scale.category20b=function(){return ao.scale.ordinal().range(zl)},ao.scale.category20c=function(){return ao.scale.ordinal().range(Ll)};var Al=[2062260,16744206,2924588,14034728,9725885,9197131,14907330,8355711,12369186,1556175].map(xn),Cl=[2062260,11454440,16744206,16759672,2924588,10018698,14034728,16750742,9725885,12955861,9197131,12885140,14907330,16234194,8355711,13092807,12369186,14408589,1556175,10410725].map(xn),zl=[3750777,5395619,7040719,10264286,6519097,9216594,11915115,13556636,9202993,12426809,15186514,15190932,8666169,11356490,14049643,15177372,8077683,10834324,13528509,14589654].map(xn),Ll=[3244733,7057110,10406625,13032431,15095053,16616764,16625259,16634018,3253076,7652470,10607003,13101504,7695281,10394312,12369372,14342891,6513507,9868950,12434877,14277081].map(xn);ao.scale.quantile=function(){return au([],[])},ao.scale.quantize=function(){return lu(0,1,[0,1])},ao.scale.threshold=function(){return cu([.5],[0,1])},ao.scale.identity=function(){return fu([0,1])},ao.svg={},ao.svg.arc=function(){function n(){var n=Math.max(0,+e.apply(this,arguments)),c=Math.max(0,+r.apply(this,arguments)),f=o.apply(this,arguments)-Io,s=a.apply(this,arguments)-Io,h=Math.abs(s-f),p=f>s?0:1;if(n>c&&(g=c,c=n,n=g),h>=Oo)return t(c,p)+(n?t(n,1-p):"")+"Z";var g,v,d,y,m,M,x,b,_,w,S,k,N=0,E=0,A=[];if((y=(+l.apply(this,arguments)||0)/2)&&(d=u===ql?Math.sqrt(n*n+c*c):+u.apply(this,arguments),p||(E*=-1),c&&(E=tn(d/c*Math.sin(y))),n&&(N=tn(d/n*Math.sin(y)))),c){m=c*Math.cos(f+E),M=c*Math.sin(f+E),x=c*Math.cos(s-E),b=c*Math.sin(s-E);var C=Math.abs(s-f-2*E)<=Fo?0:1;if(E&&yu(m,M,x,b)===p^C){var z=(f+s)/2;m=c*Math.cos(z),M=c*Math.sin(z),x=b=null}}else m=M=0;if(n){_=n*Math.cos(s-N),w=n*Math.sin(s-N),S=n*Math.cos(f+N),k=n*Math.sin(f+N);var L=Math.abs(f-s+2*N)<=Fo?0:1;if(N&&yu(_,w,S,k)===1-p^L){var q=(f+s)/2;_=n*Math.cos(q),w=n*Math.sin(q),S=k=null}}else _=w=0;if(h>Uo&&(g=Math.min(Math.abs(c-n)/2,+i.apply(this,arguments)))>.001){v=c>n^p?0:1;var T=g,R=g;if(Fo>h){var D=null==S?[_,w]:null==x?[m,M]:Re([m,M],[S,k],[x,b],[_,w]),P=m-D[0],U=M-D[1],j=x-D[0],F=b-D[1],H=1/Math.sin(Math.acos((P*j+U*F)/(Math.sqrt(P*P+U*U)*Math.sqrt(j*j+F*F)))/2),O=Math.sqrt(D[0]*D[0]+D[1]*D[1]);R=Math.min(g,(n-O)/(H-1)),T=Math.min(g,(c-O)/(H+1))}if(null!=x){var I=mu(null==S?[_,w]:[S,k],[m,M],c,T,p),Y=mu([x,b],[_,w],c,T,p);g===T?A.push("M",I[0],"A",T,",",T," 0 0,",v," ",I[1],"A",c,",",c," 0 ",1-p^yu(I[1][0],I[1][1],Y[1][0],Y[1][1]),",",p," ",Y[1],"A",T,",",T," 0 0,",v," ",Y[0]):A.push("M",I[0],"A",T,",",T," 0 1,",v," ",Y[0])}else A.push("M",m,",",M);if(null!=S){var Z=mu([m,M],[S,k],n,-R,p),V=mu([_,w],null==x?[m,M]:[x,b],n,-R,p);g===R?A.push("L",V[0],"A",R,",",R," 0 0,",v," ",V[1],"A",n,",",n," 0 ",p^yu(V[1][0],V[1][1],Z[1][0],Z[1][1]),",",1-p," ",Z[1],"A",R,",",R," 0 0,",v," ",Z[0]):A.push("L",V[0],"A",R,",",R," 0 0,",v," ",Z[0])}else A.push("L",_,",",w)}else A.push("M",m,",",M),null!=x&&A.push("A",c,",",c," 0 ",C,",",p," ",x,",",b),A.push("L",_,",",w),null!=S&&A.push("A",n,",",n," 0 ",L,",",1-p," ",S,",",k);return A.push("Z"),A.join("")}function t(n,t){return"M0,"+n+"A"+n+","+n+" 0 1,"+t+" 0,"+-n+"A"+n+","+n+" 0 1,"+t+" 0,"+n}var e=hu,r=pu,i=su,u=ql,o=gu,a=vu,l=du;return n.innerRadius=function(t){return arguments.length?(e=En(t),n):e},n.outerRadius=function(t){return arguments.length?(r=En(t),n):r},n.cornerRadius=function(t){return arguments.length?(i=En(t),n):i},n.padRadius=function(t){return arguments.length?(u=t==ql?ql:En(t),n):u},n.startAngle=function(t){return arguments.length?(o=En(t),n):o},n.endAngle=function(t){return arguments.length?(a=En(t),n):a},n.padAngle=function(t){return arguments.length?(l=En(t),n):l},n.centroid=function(){var n=(+e.apply(this,arguments)+ +r.apply(this,arguments))/2,t=(+o.apply(this,arguments)+ +a.apply(this,arguments))/2-Io;return[Math.cos(t)*n,Math.sin(t)*n]},n};var ql="auto";ao.svg.line=function(){return Mu(m)};var Tl=ao.map({linear:xu,"linear-closed":bu,step:_u,"step-before":wu,"step-after":Su,basis:zu,"basis-open":Lu,"basis-closed":qu,bundle:Tu,cardinal:Eu,"cardinal-open":ku,"cardinal-closed":Nu,monotone:Fu});Tl.forEach(function(n,t){t.key=n,t.closed=/-closed$/.test(n)});var Rl=[0,2/3,1/3,0],Dl=[0,1/3,2/3,0],Pl=[0,1/6,2/3,1/6];ao.svg.line.radial=function(){var n=Mu(Hu);return n.radius=n.x,delete n.x,n.angle=n.y,delete n.y,n},wu.reverse=Su,Su.reverse=wu,ao.svg.area=function(){return Ou(m)},ao.svg.area.radial=function(){var n=Ou(Hu);return n.radius=n.x,delete n.x,n.innerRadius=n.x0,delete n.x0,n.outerRadius=n.x1,delete n.x1,n.angle=n.y,delete n.y,n.startAngle=n.y0,delete n.y0,n.endAngle=n.y1,delete n.y1,n},ao.svg.chord=function(){function n(n,a){var l=t(this,u,n,a),c=t(this,o,n,a);return"M"+l.p0+r(l.r,l.p1,l.a1-l.a0)+(e(l,c)?i(l.r,l.p1,l.r,l.p0):i(l.r,l.p1,c.r,c.p0)+r(c.r,c.p1,c.a1-c.a0)+i(c.r,c.p1,l.r,l.p0))+"Z"}function t(n,t,e,r){var i=t.call(n,e,r),u=a.call(n,i,r),o=l.call(n,i,r)-Io,f=c.call(n,i,r)-Io;return{r:u,a0:o,a1:f,p0:[u*Math.cos(o),u*Math.sin(o)],p1:[u*Math.cos(f),u*Math.sin(f)]}}function e(n,t){return n.a0==t.a0&&n.a1==t.a1}function r(n,t,e){return"A"+n+","+n+" 0 "+ +(e>Fo)+",1 "+t}function i(n,t,e,r){return"Q 0,0 "+r}var u=Me,o=xe,a=Iu,l=gu,c=vu;return n.radius=function(t){return arguments.length?(a=En(t),n):a},n.source=function(t){return arguments.length?(u=En(t),n):u},n.target=function(t){return arguments.length?(o=En(t),n):o},n.startAngle=function(t){return arguments.length?(l=En(t),n):l},n.endAngle=function(t){return arguments.length?(c=En(t),n):c},n},ao.svg.diagonal=function(){function n(n,i){var u=t.call(this,n,i),o=e.call(this,n,i),a=(u.y+o.y)/2,l=[u,{x:u.x,y:a},{x:o.x,y:a},o];return l=l.map(r),"M"+l[0]+"C"+l[1]+" "+l[2]+" "+l[3]}var t=Me,e=xe,r=Yu;return n.source=function(e){return arguments.length?(t=En(e),n):t},n.target=function(t){return arguments.length?(e=En(t),n):e},n.projection=function(t){return arguments.length?(r=t,n):r},n},ao.svg.diagonal.radial=function(){var n=ao.svg.diagonal(),t=Yu,e=n.projection;return n.projection=function(n){return arguments.length?e(Zu(t=n)):t},n},ao.svg.symbol=function(){function n(n,r){return(Ul.get(t.call(this,n,r))||$u)(e.call(this,n,r))}var t=Xu,e=Vu;return n.type=function(e){return arguments.length?(t=En(e),n):t},n.size=function(t){return arguments.length?(e=En(t),n):e},n};var Ul=ao.map({circle:$u,cross:function(n){var t=Math.sqrt(n/5)/2;return"M"+-3*t+","+-t+"H"+-t+"V"+-3*t+"H"+t+"V"+-t+"H"+3*t+"V"+t+"H"+t+"V"+3*t+"H"+-t+"V"+t+"H"+-3*t+"Z"},diamond:function(n){var t=Math.sqrt(n/(2*Fl)),e=t*Fl;return"M0,"+-t+"L"+e+",0 0,"+t+" "+-e+",0Z"},square:function(n){var t=Math.sqrt(n)/2;return"M"+-t+","+-t+"L"+t+","+-t+" "+t+","+t+" "+-t+","+t+"Z"},"triangle-down":function(n){var t=Math.sqrt(n/jl),e=t*jl/2;return"M0,"+e+"L"+t+","+-e+" "+-t+","+-e+"Z"},"triangle-up":function(n){var t=Math.sqrt(n/jl),e=t*jl/2;return"M0,"+-e+"L"+t+","+e+" "+-t+","+e+"Z"}});ao.svg.symbolTypes=Ul.keys();var jl=Math.sqrt(3),Fl=Math.tan(30*Yo);Co.transition=function(n){for(var t,e,r=Hl||++Zl,i=Ku(n),u=[],o=Ol||{time:Date.now(),ease:Nr,delay:0,duration:250},a=-1,l=this.length;++a<l;){u.push(t=[]);for(var c=this[a],f=-1,s=c.length;++f<s;)(e=c[f])&&Qu(e,f,i,r,o),t.push(e)}return Wu(u,i,r)},Co.interrupt=function(n){return this.each(null==n?Il:Bu(Ku(n)))};var Hl,Ol,Il=Bu(Ku()),Yl=[],Zl=0;Yl.call=Co.call,Yl.empty=Co.empty,Yl.node=Co.node,Yl.size=Co.size,ao.transition=function(n,t){return n&&n.transition?Hl?n.transition(t):n:ao.selection().transition(n)},ao.transition.prototype=Yl,Yl.select=function(n){var t,e,r,i=this.id,u=this.namespace,o=[];n=A(n);for(var a=-1,l=this.length;++a<l;){o.push(t=[]);for(var c=this[a],f=-1,s=c.length;++f<s;)(r=c[f])&&(e=n.call(r,r.__data__,f,a))?("__data__"in r&&(e.__data__=r.__data__),Qu(e,f,u,i,r[u][i]),t.push(e)):t.push(null)}return Wu(o,u,i)},Yl.selectAll=function(n){var t,e,r,i,u,o=this.id,a=this.namespace,l=[];n=C(n);for(var c=-1,f=this.length;++c<f;)for(var s=this[c],h=-1,p=s.length;++h<p;)if(r=s[h]){u=r[a][o],e=n.call(r,r.__data__,h,c),l.push(t=[]);for(var g=-1,v=e.length;++g<v;)(i=e[g])&&Qu(i,g,a,o,u),t.push(i)}return Wu(l,a,o)},Yl.filter=function(n){var t,e,r,i=[];"function"!=typeof n&&(n=O(n));for(var u=0,o=this.length;o>u;u++){i.push(t=[]);for(var e=this[u],a=0,l=e.length;l>a;a++)(r=e[a])&&n.call(r,r.__data__,a,u)&&t.push(r)}return Wu(i,this.namespace,this.id)},Yl.tween=function(n,t){var e=this.id,r=this.namespace;return arguments.length<2?this.node()[r][e].tween.get(n):Y(this,null==t?function(t){t[r][e].tween.remove(n)}:function(i){i[r][e].tween.set(n,t)})},Yl.attr=function(n,t){function e(){this.removeAttribute(a)}function r(){this.removeAttributeNS(a.space,a.local)}function i(n){return null==n?e:(n+="",function(){var t,e=this.getAttribute(a);return e!==n&&(t=o(e,n),function(n){this.setAttribute(a,t(n))})})}function u(n){return null==n?r:(n+="",function(){var t,e=this.getAttributeNS(a.space,a.local);return e!==n&&(t=o(e,n),function(n){this.setAttributeNS(a.space,a.local,t(n))})})}if(arguments.length<2){for(t in n)this.attr(t,n[t]);return this}var o="transform"==n?$r:Mr,a=ao.ns.qualify(n);return Ju(this,"attr."+n,t,a.local?u:i)},Yl.attrTween=function(n,t){function e(n,e){var r=t.call(this,n,e,this.getAttribute(i));return r&&function(n){this.setAttribute(i,r(n))}}function r(n,e){var r=t.call(this,n,e,this.getAttributeNS(i.space,i.local));return r&&function(n){this.setAttributeNS(i.space,i.local,r(n))}}var i=ao.ns.qualify(n);return this.tween("attr."+n,i.local?r:e)},Yl.style=function(n,e,r){function i(){this.style.removeProperty(n)}function u(e){return null==e?i:(e+="",function(){var i,u=t(this).getComputedStyle(this,null).getPropertyValue(n);return u!==e&&(i=Mr(u,e),function(t){this.style.setProperty(n,i(t),r)})})}var o=arguments.length;if(3>o){if("string"!=typeof n){2>o&&(e="");for(r in n)this.style(r,n[r],e);return this}r=""}return Ju(this,"style."+n,e,u)},Yl.styleTween=function(n,e,r){function i(i,u){var o=e.call(this,i,u,t(this).getComputedStyle(this,null).getPropertyValue(n));return o&&function(t){this.style.setProperty(n,o(t),r)}}return arguments.length<3&&(r=""),this.tween("style."+n,i)},Yl.text=function(n){return Ju(this,"text",n,Gu)},Yl.remove=function(){var n=this.namespace;return this.each("end.transition",function(){var t;this[n].count<2&&(t=this.parentNode)&&t.removeChild(this)})},Yl.ease=function(n){var t=this.id,e=this.namespace;return arguments.length<1?this.node()[e][t].ease:("function"!=typeof n&&(n=ao.ease.apply(ao,arguments)),Y(this,function(r){r[e][t].ease=n}))},Yl.delay=function(n){var t=this.id,e=this.namespace;return arguments.length<1?this.node()[e][t].delay:Y(this,"function"==typeof n?function(r,i,u){r[e][t].delay=+n.call(r,r.__data__,i,u)}:(n=+n,function(r){r[e][t].delay=n}))},Yl.duration=function(n){var t=this.id,e=this.namespace;return arguments.length<1?this.node()[e][t].duration:Y(this,"function"==typeof n?function(r,i,u){r[e][t].duration=Math.max(1,n.call(r,r.__data__,i,u))}:(n=Math.max(1,n),function(r){r[e][t].duration=n}))},Yl.each=function(n,t){var e=this.id,r=this.namespace;if(arguments.length<2){var i=Ol,u=Hl;try{Hl=e,Y(this,function(t,i,u){Ol=t[r][e],n.call(t,t.__data__,i,u)})}finally{Ol=i,Hl=u}}else Y(this,function(i){var u=i[r][e];(u.event||(u.event=ao.dispatch("start","end","interrupt"))).on(n,t)});return this},Yl.transition=function(){for(var n,t,e,r,i=this.id,u=++Zl,o=this.namespace,a=[],l=0,c=this.length;c>l;l++){a.push(n=[]);for(var t=this[l],f=0,s=t.length;s>f;f++)(e=t[f])&&(r=e[o][i],Qu(e,f,o,u,{time:r.time,ease:r.ease,delay:r.delay+r.duration,duration:r.duration})),n.push(e)}return Wu(a,o,u)},ao.svg.axis=function(){function n(n){n.each(function(){var n,c=ao.select(this),f=this.__chart__||e,s=this.__chart__=e.copy(),h=null==l?s.ticks?s.ticks.apply(s,a):s.domain():l,p=null==t?s.tickFormat?s.tickFormat.apply(s,a):m:t,g=c.selectAll(".tick").data(h,s),v=g.enter().insert("g",".domain").attr("class","tick").style("opacity",Uo),d=ao.transition(g.exit()).style("opacity",Uo).remove(),y=ao.transition(g.order()).style("opacity",1),M=Math.max(i,0)+o,x=Zi(s),b=c.selectAll(".domain").data([0]),_=(b.enter().append("path").attr("class","domain"),ao.transition(b));v.append("line"),v.append("text");var w,S,k,N,E=v.select("line"),A=y.select("line"),C=g.select("text").text(p),z=v.select("text"),L=y.select("text"),q="top"===r||"left"===r?-1:1;if("bottom"===r||"top"===r?(n=no,w="x",k="y",S="x2",N="y2",C.attr("dy",0>q?"0em":".71em").style("text-anchor","middle"),_.attr("d","M"+x[0]+","+q*u+"V0H"+x[1]+"V"+q*u)):(n=to,w="y",k="x",S="y2",N="x2",C.attr("dy",".32em").style("text-anchor",0>q?"end":"start"),_.attr("d","M"+q*u+","+x[0]+"H0V"+x[1]+"H"+q*u)),E.attr(N,q*i),z.attr(k,q*M),A.attr(S,0).attr(N,q*i),L.attr(w,0).attr(k,q*M),s.rangeBand){var T=s,R=T.rangeBand()/2;f=s=function(n){return T(n)+R}}else f.rangeBand?f=s:d.call(n,s,f);v.call(n,f,s),y.call(n,s,s)})}var t,e=ao.scale.linear(),r=Vl,i=6,u=6,o=3,a=[10],l=null;return n.scale=function(t){return arguments.length?(e=t,n):e},n.orient=function(t){return arguments.length?(r=t in Xl?t+"":Vl,n):r},n.ticks=function(){return arguments.length?(a=co(arguments),n):a},n.tickValues=function(t){return arguments.length?(l=t,n):l},n.tickFormat=function(e){return arguments.length?(t=e,n):t},n.tickSize=function(t){var e=arguments.length;return e?(i=+t,u=+arguments[e-1],n):i},n.innerTickSize=function(t){return arguments.length?(i=+t,n):i},n.outerTickSize=function(t){return arguments.length?(u=+t,n):u},n.tickPadding=function(t){return arguments.length?(o=+t,n):o},n.tickSubdivide=function(){return arguments.length&&n},n};var Vl="bottom",Xl={top:1,right:1,bottom:1,left:1};ao.svg.brush=function(){function n(t){t.each(function(){var t=ao.select(this).style("pointer-events","all").style("-webkit-tap-highlight-color","rgba(0,0,0,0)").on("mousedown.brush",u).on("touchstart.brush",u),o=t.selectAll(".background").data([0]);o.enter().append("rect").attr("class","background").style("visibility","hidden").style("cursor","crosshair"),t.selectAll(".extent").data([0]).enter().append("rect").attr("class","extent").style("cursor","move");var a=t.selectAll(".resize").data(v,m);a.exit().remove(),a.enter().append("g").attr("class",function(n){return"resize "+n}).style("cursor",function(n){return $l[n]}).append("rect").attr("x",function(n){return/[ew]$/.test(n)?-3:null}).attr("y",function(n){return/^[ns]/.test(n)?-3:null}).attr("width",6).attr("height",6).style("visibility","hidden"),a.style("display",n.empty()?"none":null);var l,s=ao.transition(t),h=ao.transition(o);c&&(l=Zi(c),h.attr("x",l[0]).attr("width",l[1]-l[0]),r(s)),f&&(l=Zi(f),h.attr("y",l[0]).attr("height",l[1]-l[0]),i(s)),e(s)})}function e(n){n.selectAll(".resize").attr("transform",function(n){return"translate("+s[+/e$/.test(n)]+","+h[+/^s/.test(n)]+")"})}function r(n){n.select(".extent").attr("x",s[0]),n.selectAll(".extent,.n>rect,.s>rect").attr("width",s[1]-s[0])}function i(n){n.select(".extent").attr("y",h[0]),n.selectAll(".extent,.e>rect,.w>rect").attr("height",h[1]-h[0])}function u(){function u(){32==ao.event.keyCode&&(C||(M=null,L[0]-=s[1],L[1]-=h[1],C=2),S())}function v(){32==ao.event.keyCode&&2==C&&(L[0]+=s[1],L[1]+=h[1],C=0,S())}function d(){var n=ao.mouse(b),t=!1;x&&(n[0]+=x[0],n[1]+=x[1]),C||(ao.event.altKey?(M||(M=[(s[0]+s[1])/2,(h[0]+h[1])/2]),L[0]=s[+(n[0]<M[0])],L[1]=h[+(n[1]<M[1])]):M=null),E&&y(n,c,0)&&(r(k),t=!0),A&&y(n,f,1)&&(i(k),t=!0),t&&(e(k),w({type:"brush",mode:C?"move":"resize"}))}function y(n,t,e){var r,i,u=Zi(t),l=u[0],c=u[1],f=L[e],v=e?h:s,d=v[1]-v[0];return C&&(l-=f,c-=d+f),r=(e?g:p)?Math.max(l,Math.min(c,n[e])):n[e],C?i=(r+=f)+d:(M&&(f=Math.max(l,Math.min(c,2*M[e]-r))),r>f?(i=r,r=f):i=f),v[0]!=r||v[1]!=i?(e?a=null:o=null,v[0]=r,v[1]=i,!0):void 0}function m(){d(),k.style("pointer-events","all").selectAll(".resize").style("display",n.empty()?"none":null),ao.select("body").style("cursor",null),q.on("mousemove.brush",null).on("mouseup.brush",null).on("touchmove.brush",null).on("touchend.brush",null).on("keydown.brush",null).on("keyup.brush",null),z(),w({type:"brushend"})}var M,x,b=this,_=ao.select(ao.event.target),w=l.of(b,arguments),k=ao.select(b),N=_.datum(),E=!/^(n|s)$/.test(N)&&c,A=!/^(e|w)$/.test(N)&&f,C=_.classed("extent"),z=W(b),L=ao.mouse(b),q=ao.select(t(b)).on("keydown.brush",u).on("keyup.brush",v);if(ao.event.changedTouches?q.on("touchmove.brush",d).on("touchend.brush",m):q.on("mousemove.brush",d).on("mouseup.brush",m),k.interrupt().selectAll("*").interrupt(),C)L[0]=s[0]-L[0],L[1]=h[0]-L[1];else if(N){var T=+/w$/.test(N),R=+/^n/.test(N);x=[s[1-T]-L[0],h[1-R]-L[1]],L[0]=s[T],L[1]=h[R]}else ao.event.altKey&&(M=L.slice());k.style("pointer-events","none").selectAll(".resize").style("display",null),ao.select("body").style("cursor",_.style("cursor")),w({type:"brushstart"}),d()}var o,a,l=N(n,"brushstart","brush","brushend"),c=null,f=null,s=[0,0],h=[0,0],p=!0,g=!0,v=Bl[0];return n.event=function(n){n.each(function(){var n=l.of(this,arguments),t={x:s,y:h,i:o,j:a},e=this.__chart__||t;this.__chart__=t,Hl?ao.select(this).transition().each("start.brush",function(){o=e.i,a=e.j,s=e.x,h=e.y,n({type:"brushstart"})}).tween("brush:brush",function(){var e=xr(s,t.x),r=xr(h,t.y);return o=a=null,function(i){s=t.x=e(i),h=t.y=r(i),n({type:"brush",mode:"resize"})}}).each("end.brush",function(){o=t.i,a=t.j,n({type:"brush",mode:"resize"}),n({type:"brushend"})}):(n({type:"brushstart"}),n({type:"brush",mode:"resize"}),n({type:"brushend"}))})},n.x=function(t){return arguments.length?(c=t,v=Bl[!c<<1|!f],n):c},n.y=function(t){return arguments.length?(f=t,v=Bl[!c<<1|!f],n):f},n.clamp=function(t){return arguments.length?(c&&f?(p=!!t[0],g=!!t[1]):c?p=!!t:f&&(g=!!t),n):c&&f?[p,g]:c?p:f?g:null},n.extent=function(t){var e,r,i,u,l;return arguments.length?(c&&(e=t[0],r=t[1],f&&(e=e[0],r=r[0]),o=[e,r],c.invert&&(e=c(e),r=c(r)),e>r&&(l=e,e=r,r=l),e==s[0]&&r==s[1]||(s=[e,r])),f&&(i=t[0],u=t[1],c&&(i=i[1],u=u[1]),a=[i,u],f.invert&&(i=f(i),u=f(u)),i>u&&(l=i,i=u,u=l),i==h[0]&&u==h[1]||(h=[i,u])),n):(c&&(o?(e=o[0],r=o[1]):(e=s[0],r=s[1],c.invert&&(e=c.invert(e),r=c.invert(r)),e>r&&(l=e,e=r,r=l))),f&&(a?(i=a[0],u=a[1]):(i=h[0],u=h[1],f.invert&&(i=f.invert(i),u=f.invert(u)),i>u&&(l=i,i=u,u=l))),c&&f?[[e,i],[r,u]]:c?[e,r]:f&&[i,u])},n.clear=function(){return n.empty()||(s=[0,0],h=[0,0],o=a=null),n},n.empty=function(){return!!c&&s[0]==s[1]||!!f&&h[0]==h[1]},ao.rebind(n,l,"on")};var $l={n:"ns-resize",e:"ew-resize",s:"ns-resize",w:"ew-resize",nw:"nwse-resize",ne:"nesw-resize",se:"nwse-resize",sw:"nesw-resize"},Bl=[["n","e","s","w","nw","ne","se","sw"],["e","w"],["n","s"],[]],Wl=ga.format=xa.timeFormat,Jl=Wl.utc,Gl=Jl("%Y-%m-%dT%H:%M:%S.%LZ");Wl.iso=Date.prototype.toISOString&&+new Date("2000-01-01T00:00:00.000Z")?eo:Gl,eo.parse=function(n){var t=new Date(n);return isNaN(t)?null:t},eo.toString=Gl.toString,ga.second=On(function(n){return new va(1e3*Math.floor(n/1e3))},function(n,t){n.setTime(n.getTime()+1e3*Math.floor(t))},function(n){return n.getSeconds()}),ga.seconds=ga.second.range,ga.seconds.utc=ga.second.utc.range,ga.minute=On(function(n){return new va(6e4*Math.floor(n/6e4))},function(n,t){n.setTime(n.getTime()+6e4*Math.floor(t))},function(n){return n.getMinutes()}),ga.minutes=ga.minute.range,ga.minutes.utc=ga.minute.utc.range,ga.hour=On(function(n){var t=n.getTimezoneOffset()/60;return new va(36e5*(Math.floor(n/36e5-t)+t))},function(n,t){n.setTime(n.getTime()+36e5*Math.floor(t))},function(n){return n.getHours()}),ga.hours=ga.hour.range,ga.hours.utc=ga.hour.utc.range,ga.month=On(function(n){return n=ga.day(n),n.setDate(1),n},function(n,t){n.setMonth(n.getMonth()+t)},function(n){return n.getMonth()}),ga.months=ga.month.range,ga.months.utc=ga.month.utc.range;var Kl=[1e3,5e3,15e3,3e4,6e4,3e5,9e5,18e5,36e5,108e5,216e5,432e5,864e5,1728e5,6048e5,2592e6,7776e6,31536e6],Ql=[[ga.second,1],[ga.second,5],[ga.second,15],[ga.second,30],[ga.minute,1],[ga.minute,5],[ga.minute,15],[ga.minute,30],[ga.hour,1],[ga.hour,3],[ga.hour,6],[ga.hour,12],[ga.day,1],[ga.day,2],[ga.week,1],[ga.month,1],[ga.month,3],[ga.year,1]],nc=Wl.multi([[".%L",function(n){return n.getMilliseconds()}],[":%S",function(n){return n.getSeconds()}],["%I:%M",function(n){return n.getMinutes()}],["%I %p",function(n){return n.getHours()}],["%a %d",function(n){return n.getDay()&&1!=n.getDate()}],["%b %d",function(n){return 1!=n.getDate()}],["%B",function(n){return n.getMonth()}],["%Y",zt]]),tc={range:function(n,t,e){return ao.range(Math.ceil(n/e)*e,+t,e).map(io)},floor:m,ceil:m};Ql.year=ga.year,ga.scale=function(){return ro(ao.scale.linear(),Ql,nc)};var ec=Ql.map(function(n){return[n[0].utc,n[1]]}),rc=Jl.multi([[".%L",function(n){return n.getUTCMilliseconds()}],[":%S",function(n){return n.getUTCSeconds()}],["%I:%M",function(n){return n.getUTCMinutes()}],["%I %p",function(n){return n.getUTCHours()}],["%a %d",function(n){return n.getUTCDay()&&1!=n.getUTCDate()}],["%b %d",function(n){return 1!=n.getUTCDate()}],["%B",function(n){return n.getUTCMonth()}],["%Y",zt]]);ec.year=ga.year.utc,ga.scale.utc=function(){return ro(ao.scale.linear(),ec,rc)},ao.text=An(function(n){return n.responseText}),ao.json=function(n,t){return Cn(n,"application/json",uo,t)},ao.html=function(n,t){return Cn(n,"text/html",oo,t)},ao.xml=An(function(n){return n.responseXML}),"function"==typeof define&&define.amd?(this.d3=ao,define(ao)):"object"==typeof module&&module.exports?module.exports=ao:this.d3=ao}(); 

\ No newline at end of file

@@ -1,17020 +0,0 @@ 

- // https://d3js.org Version 4.11.0. Copyright 2017 Mike Bostock.

- (function (global, factory) {

- 	typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :

- 	typeof define === 'function' && define.amd ? define(['exports'], factory) :

- 	(factory((global.d3 = global.d3 || {})));

- }(this, (function (exports) { 'use strict';

- 

- var version = "4.11.0";

- 

- var ascending = function(a, b) {

-   return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;

- };

- 

- var bisector = function(compare) {

-   if (compare.length === 1) compare = ascendingComparator(compare);

-   return {

-     left: function(a, x, lo, hi) {

-       if (lo == null) lo = 0;

-       if (hi == null) hi = a.length;

-       while (lo < hi) {

-         var mid = lo + hi >>> 1;

-         if (compare(a[mid], x) < 0) lo = mid + 1;

-         else hi = mid;

-       }

-       return lo;

-     },

-     right: function(a, x, lo, hi) {

-       if (lo == null) lo = 0;

-       if (hi == null) hi = a.length;

-       while (lo < hi) {

-         var mid = lo + hi >>> 1;

-         if (compare(a[mid], x) > 0) hi = mid;

-         else lo = mid + 1;

-       }

-       return lo;

-     }

-   };

- };

- 

- function ascendingComparator(f) {

-   return function(d, x) {

-     return ascending(f(d), x);

-   };

- }

- 

- var ascendingBisect = bisector(ascending);

- var bisectRight = ascendingBisect.right;

- var bisectLeft = ascendingBisect.left;

- 

- var pairs = function(array, f) {

-   if (f == null) f = pair;

-   var i = 0, n = array.length - 1, p = array[0], pairs = new Array(n < 0 ? 0 : n);

-   while (i < n) pairs[i] = f(p, p = array[++i]);

-   return pairs;

- };

- 

- function pair(a, b) {

-   return [a, b];

- }

- 

- var cross = function(values0, values1, reduce) {

-   var n0 = values0.length,

-       n1 = values1.length,

-       values = new Array(n0 * n1),

-       i0,

-       i1,

-       i,

-       value0;

- 

-   if (reduce == null) reduce = pair;

- 

-   for (i0 = i = 0; i0 < n0; ++i0) {

-     for (value0 = values0[i0], i1 = 0; i1 < n1; ++i1, ++i) {

-       values[i] = reduce(value0, values1[i1]);

-     }

-   }

- 

-   return values;

- };

- 

- var descending = function(a, b) {

-   return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;

- };

- 

- var number = function(x) {

-   return x === null ? NaN : +x;

- };

- 

- var variance = function(values, valueof) {

-   var n = values.length,

-       m = 0,

-       i = -1,

-       mean = 0,

-       value,

-       delta,

-       sum = 0;

- 

-   if (valueof == null) {

-     while (++i < n) {

-       if (!isNaN(value = number(values[i]))) {

-         delta = value - mean;

-         mean += delta / ++m;

-         sum += delta * (value - mean);

-       }

-     }

-   }

- 

-   else {

-     while (++i < n) {

-       if (!isNaN(value = number(valueof(values[i], i, values)))) {

-         delta = value - mean;

-         mean += delta / ++m;

-         sum += delta * (value - mean);

-       }

-     }

-   }

- 

-   if (m > 1) return sum / (m - 1);

- };

- 

- var deviation = function(array, f) {

-   var v = variance(array, f);

-   return v ? Math.sqrt(v) : v;

- };

- 

- var extent = function(values, valueof) {

-   var n = values.length,

-       i = -1,

-       value,

-       min,

-       max;

- 

-   if (valueof == null) {

-     while (++i < n) { // Find the first comparable value.

-       if ((value = values[i]) != null && value >= value) {

-         min = max = value;

-         while (++i < n) { // Compare the remaining values.

-           if ((value = values[i]) != null) {

-             if (min > value) min = value;

-             if (max < value) max = value;

-           }

-         }

-       }

-     }

-   }

- 

-   else {

-     while (++i < n) { // Find the first comparable value.

-       if ((value = valueof(values[i], i, values)) != null && value >= value) {

-         min = max = value;

-         while (++i < n) { // Compare the remaining values.

-           if ((value = valueof(values[i], i, values)) != null) {

-             if (min > value) min = value;

-             if (max < value) max = value;

-           }

-         }

-       }

-     }

-   }

- 

-   return [min, max];

- };

- 

- var array = Array.prototype;

- 

- var slice = array.slice;

- var map = array.map;

- 

- var constant = function(x) {

-   return function() {

-     return x;

-   };

- };

- 

- var identity = function(x) {

-   return x;

- };

- 

- var sequence = function(start, stop, step) {

-   start = +start, stop = +stop, step = (n = arguments.length) < 2 ? (stop = start, start = 0, 1) : n < 3 ? 1 : +step;

- 

-   var i = -1,

-       n = Math.max(0, Math.ceil((stop - start) / step)) | 0,

-       range = new Array(n);

- 

-   while (++i < n) {

-     range[i] = start + i * step;

-   }

- 

-   return range;

- };

- 

- var e10 = Math.sqrt(50);

- var e5 = Math.sqrt(10);

- var e2 = Math.sqrt(2);

- 

- var ticks = function(start, stop, count) {

-   var reverse,

-       i = -1,

-       n,

-       ticks,

-       step;

- 

-   stop = +stop, start = +start, count = +count;

-   if (start === stop && count > 0) return [start];

-   if (reverse = stop < start) n = start, start = stop, stop = n;

-   if ((step = tickIncrement(start, stop, count)) === 0 || !isFinite(step)) return [];

- 

-   if (step > 0) {

-     start = Math.ceil(start / step);

-     stop = Math.floor(stop / step);

-     ticks = new Array(n = Math.ceil(stop - start + 1));

-     while (++i < n) ticks[i] = (start + i) * step;

-   } else {

-     start = Math.floor(start * step);

-     stop = Math.ceil(stop * step);

-     ticks = new Array(n = Math.ceil(start - stop + 1));

-     while (++i < n) ticks[i] = (start - i) / step;

-   }

- 

-   if (reverse) ticks.reverse();

- 

-   return ticks;

- };

- 

- function tickIncrement(start, stop, count) {

-   var step = (stop - start) / Math.max(0, count),

-       power = Math.floor(Math.log(step) / Math.LN10),

-       error = step / Math.pow(10, power);

-   return power >= 0

-       ? (error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1) * Math.pow(10, power)

-       : -Math.pow(10, -power) / (error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1);

- }

- 

- function tickStep(start, stop, count) {

-   var step0 = Math.abs(stop - start) / Math.max(0, count),

-       step1 = Math.pow(10, Math.floor(Math.log(step0) / Math.LN10)),

-       error = step0 / step1;

-   if (error >= e10) step1 *= 10;

-   else if (error >= e5) step1 *= 5;

-   else if (error >= e2) step1 *= 2;

-   return stop < start ? -step1 : step1;

- }

- 

- var sturges = function(values) {

-   return Math.ceil(Math.log(values.length) / Math.LN2) + 1;

- };

- 

- var histogram = function() {

-   var value = identity,

-       domain = extent,

-       threshold = sturges;

- 

-   function histogram(data) {

-     var i,

-         n = data.length,

-         x,

-         values = new Array(n);

- 

-     for (i = 0; i < n; ++i) {

-       values[i] = value(data[i], i, data);

-     }

- 

-     var xz = domain(values),

-         x0 = xz[0],

-         x1 = xz[1],

-         tz = threshold(values, x0, x1);

- 

-     // Convert number of thresholds into uniform thresholds.

-     if (!Array.isArray(tz)) {

-       tz = tickStep(x0, x1, tz);

-       tz = sequence(Math.ceil(x0 / tz) * tz, Math.floor(x1 / tz) * tz, tz); // exclusive

-     }

- 

-     // Remove any thresholds outside the domain.

-     var m = tz.length;

-     while (tz[0] <= x0) tz.shift(), --m;

-     while (tz[m - 1] > x1) tz.pop(), --m;

- 

-     var bins = new Array(m + 1),

-         bin;

- 

-     // Initialize bins.

-     for (i = 0; i <= m; ++i) {

-       bin = bins[i] = [];

-       bin.x0 = i > 0 ? tz[i - 1] : x0;

-       bin.x1 = i < m ? tz[i] : x1;

-     }

- 

-     // Assign data to bins by value, ignoring any outside the domain.

-     for (i = 0; i < n; ++i) {

-       x = values[i];

-       if (x0 <= x && x <= x1) {

-         bins[bisectRight(tz, x, 0, m)].push(data[i]);

-       }

-     }

- 

-     return bins;

-   }

- 

-   histogram.value = function(_) {

-     return arguments.length ? (value = typeof _ === "function" ? _ : constant(_), histogram) : value;

-   };

- 

-   histogram.domain = function(_) {

-     return arguments.length ? (domain = typeof _ === "function" ? _ : constant([_[0], _[1]]), histogram) : domain;

-   };

- 

-   histogram.thresholds = function(_) {

-     return arguments.length ? (threshold = typeof _ === "function" ? _ : Array.isArray(_) ? constant(slice.call(_)) : constant(_), histogram) : threshold;

-   };

- 

-   return histogram;

- };

- 

- var threshold = function(values, p, valueof) {

-   if (valueof == null) valueof = number;

-   if (!(n = values.length)) return;

-   if ((p = +p) <= 0 || n < 2) return +valueof(values[0], 0, values);

-   if (p >= 1) return +valueof(values[n - 1], n - 1, values);

-   var n,

-       i = (n - 1) * p,

-       i0 = Math.floor(i),

-       value0 = +valueof(values[i0], i0, values),

-       value1 = +valueof(values[i0 + 1], i0 + 1, values);

-   return value0 + (value1 - value0) * (i - i0);

- };

- 

- var freedmanDiaconis = function(values, min, max) {

-   values = map.call(values, number).sort(ascending);

-   return Math.ceil((max - min) / (2 * (threshold(values, 0.75) - threshold(values, 0.25)) * Math.pow(values.length, -1 / 3)));

- };

- 

- var scott = function(values, min, max) {

-   return Math.ceil((max - min) / (3.5 * deviation(values) * Math.pow(values.length, -1 / 3)));

- };

- 

- var max = function(values, valueof) {

-   var n = values.length,

-       i = -1,

-       value,

-       max;

- 

-   if (valueof == null) {

-     while (++i < n) { // Find the first comparable value.

-       if ((value = values[i]) != null && value >= value) {

-         max = value;

-         while (++i < n) { // Compare the remaining values.

-           if ((value = values[i]) != null && value > max) {

-             max = value;

-           }

-         }

-       }

-     }

-   }

- 

-   else {

-     while (++i < n) { // Find the first comparable value.

-       if ((value = valueof(values[i], i, values)) != null && value >= value) {

-         max = value;

-         while (++i < n) { // Compare the remaining values.

-           if ((value = valueof(values[i], i, values)) != null && value > max) {

-             max = value;

-           }

-         }

-       }

-     }

-   }

- 

-   return max;

- };

- 

- var mean = function(values, valueof) {

-   var n = values.length,

-       m = n,

-       i = -1,

-       value,

-       sum = 0;

- 

-   if (valueof == null) {

-     while (++i < n) {

-       if (!isNaN(value = number(values[i]))) sum += value;

-       else --m;

-     }

-   }

- 

-   else {

-     while (++i < n) {

-       if (!isNaN(value = number(valueof(values[i], i, values)))) sum += value;

-       else --m;

-     }

-   }

- 

-   if (m) return sum / m;

- };

- 

- var median = function(values, valueof) {

-   var n = values.length,

-       i = -1,

-       value,

-       numbers = [];

- 

-   if (valueof == null) {

-     while (++i < n) {

-       if (!isNaN(value = number(values[i]))) {

-         numbers.push(value);

-       }

-     }

-   }

- 

-   else {

-     while (++i < n) {

-       if (!isNaN(value = number(valueof(values[i], i, values)))) {

-         numbers.push(value);

-       }

-     }

-   }

- 

-   return threshold(numbers.sort(ascending), 0.5);

- };

- 

- var merge = function(arrays) {

-   var n = arrays.length,

-       m,

-       i = -1,

-       j = 0,

-       merged,

-       array;

- 

-   while (++i < n) j += arrays[i].length;

-   merged = new Array(j);

- 

-   while (--n >= 0) {

-     array = arrays[n];

-     m = array.length;

-     while (--m >= 0) {

-       merged[--j] = array[m];

-     }

-   }

- 

-   return merged;

- };

- 

- var min = function(values, valueof) {

-   var n = values.length,

-       i = -1,

-       value,

-       min;

- 

-   if (valueof == null) {

-     while (++i < n) { // Find the first comparable value.

-       if ((value = values[i]) != null && value >= value) {

-         min = value;

-         while (++i < n) { // Compare the remaining values.

-           if ((value = values[i]) != null && min > value) {

-             min = value;

-           }

-         }

-       }

-     }

-   }

- 

-   else {

-     while (++i < n) { // Find the first comparable value.

-       if ((value = valueof(values[i], i, values)) != null && value >= value) {

-         min = value;

-         while (++i < n) { // Compare the remaining values.

-           if ((value = valueof(values[i], i, values)) != null && min > value) {

-             min = value;

-           }

-         }

-       }

-     }

-   }

- 

-   return min;

- };

- 

- var permute = function(array, indexes) {

-   var i = indexes.length, permutes = new Array(i);

-   while (i--) permutes[i] = array[indexes[i]];

-   return permutes;

- };

- 

- var scan = function(values, compare) {

-   if (!(n = values.length)) return;

-   var n,

-       i = 0,

-       j = 0,

-       xi,

-       xj = values[j];

- 

-   if (compare == null) compare = ascending;

- 

-   while (++i < n) {

-     if (compare(xi = values[i], xj) < 0 || compare(xj, xj) !== 0) {

-       xj = xi, j = i;

-     }

-   }

- 

-   if (compare(xj, xj) === 0) return j;

- };

- 

- var shuffle = function(array, i0, i1) {

-   var m = (i1 == null ? array.length : i1) - (i0 = i0 == null ? 0 : +i0),

-       t,

-       i;

- 

-   while (m) {

-     i = Math.random() * m-- | 0;

-     t = array[m + i0];

-     array[m + i0] = array[i + i0];

-     array[i + i0] = t;

-   }

- 

-   return array;

- };

- 

- var sum = function(values, valueof) {

-   var n = values.length,

-       i = -1,

-       value,

-       sum = 0;

- 

-   if (valueof == null) {

-     while (++i < n) {

-       if (value = +values[i]) sum += value; // Note: zero and null are equivalent.

-     }

-   }

- 

-   else {

-     while (++i < n) {

-       if (value = +valueof(values[i], i, values)) sum += value;

-     }

-   }

- 

-   return sum;

- };

- 

- var transpose = function(matrix) {

-   if (!(n = matrix.length)) return [];

-   for (var i = -1, m = min(matrix, length), transpose = new Array(m); ++i < m;) {

-     for (var j = -1, n, row = transpose[i] = new Array(n); ++j < n;) {

-       row[j] = matrix[j][i];

-     }

-   }

-   return transpose;

- };

- 

- function length(d) {

-   return d.length;

- }

- 

- var zip = function() {

-   return transpose(arguments);

- };

- 

- var slice$1 = Array.prototype.slice;

- 

- var identity$1 = function(x) {

-   return x;

- };

- 

- var top = 1;

- var right = 2;

- var bottom = 3;

- var left = 4;

- var epsilon = 1e-6;

- 

- function translateX(x) {

-   return "translate(" + (x + 0.5) + ",0)";

- }

- 

- function translateY(y) {

-   return "translate(0," + (y + 0.5) + ")";

- }

- 

- function number$1(scale) {

-   return function(d) {

-     return +scale(d);

-   };

- }

- 

- function center(scale) {

-   var offset = Math.max(0, scale.bandwidth() - 1) / 2; // Adjust for 0.5px offset.

-   if (scale.round()) offset = Math.round(offset);

-   return function(d) {

-     return +scale(d) + offset;

-   };

- }

- 

- function entering() {

-   return !this.__axis;

- }

- 

- function axis(orient, scale) {

-   var tickArguments = [],

-       tickValues = null,

-       tickFormat = null,

-       tickSizeInner = 6,

-       tickSizeOuter = 6,

-       tickPadding = 3,

-       k = orient === top || orient === left ? -1 : 1,

-       x = orient === left || orient === right ? "x" : "y",

-       transform = orient === top || orient === bottom ? translateX : translateY;

- 

-   function axis(context) {

-     var values = tickValues == null ? (scale.ticks ? scale.ticks.apply(scale, tickArguments) : scale.domain()) : tickValues,

-         format = tickFormat == null ? (scale.tickFormat ? scale.tickFormat.apply(scale, tickArguments) : identity$1) : tickFormat,

-         spacing = Math.max(tickSizeInner, 0) + tickPadding,

-         range = scale.range(),

-         range0 = +range[0] + 0.5,

-         range1 = +range[range.length - 1] + 0.5,

-         position = (scale.bandwidth ? center : number$1)(scale.copy()),

-         selection = context.selection ? context.selection() : context,

-         path = selection.selectAll(".domain").data([null]),

-         tick = selection.selectAll(".tick").data(values, scale).order(),

-         tickExit = tick.exit(),

-         tickEnter = tick.enter().append("g").attr("class", "tick"),

-         line = tick.select("line"),

-         text = tick.select("text");

- 

-     path = path.merge(path.enter().insert("path", ".tick")

-         .attr("class", "domain")

-         .attr("stroke", "#000"));

- 

-     tick = tick.merge(tickEnter);

- 

-     line = line.merge(tickEnter.append("line")

-         .attr("stroke", "#000")

-         .attr(x + "2", k * tickSizeInner));

- 

-     text = text.merge(tickEnter.append("text")

-         .attr("fill", "#000")

-         .attr(x, k * spacing)

-         .attr("dy", orient === top ? "0em" : orient === bottom ? "0.71em" : "0.32em"));

- 

-     if (context !== selection) {

-       path = path.transition(context);

-       tick = tick.transition(context);

-       line = line.transition(context);

-       text = text.transition(context);

- 

-       tickExit = tickExit.transition(context)

-           .attr("opacity", epsilon)

-           .attr("transform", function(d) { return isFinite(d = position(d)) ? transform(d) : this.getAttribute("transform"); });

- 

-       tickEnter

-           .attr("opacity", epsilon)

-           .attr("transform", function(d) { var p = this.parentNode.__axis; return transform(p && isFinite(p = p(d)) ? p : position(d)); });

-     }

- 

-     tickExit.remove();

- 

-     path

-         .attr("d", orient === left || orient == right

-             ? "M" + k * tickSizeOuter + "," + range0 + "H0.5V" + range1 + "H" + k * tickSizeOuter

-             : "M" + range0 + "," + k * tickSizeOuter + "V0.5H" + range1 + "V" + k * tickSizeOuter);

- 

-     tick

-         .attr("opacity", 1)

-         .attr("transform", function(d) { return transform(position(d)); });

- 

-     line

-         .attr(x + "2", k * tickSizeInner);

- 

-     text

-         .attr(x, k * spacing)

-         .text(format);

- 

-     selection.filter(entering)

-         .attr("fill", "none")

-         .attr("font-size", 10)

-         .attr("font-family", "sans-serif")

-         .attr("text-anchor", orient === right ? "start" : orient === left ? "end" : "middle");

- 

-     selection

-         .each(function() { this.__axis = position; });

-   }

- 

-   axis.scale = function(_) {

-     return arguments.length ? (scale = _, axis) : scale;

-   };

- 

-   axis.ticks = function() {

-     return tickArguments = slice$1.call(arguments), axis;

-   };

- 

-   axis.tickArguments = function(_) {

-     return arguments.length ? (tickArguments = _ == null ? [] : slice$1.call(_), axis) : tickArguments.slice();

-   };

- 

-   axis.tickValues = function(_) {

-     return arguments.length ? (tickValues = _ == null ? null : slice$1.call(_), axis) : tickValues && tickValues.slice();

-   };

- 

-   axis.tickFormat = function(_) {

-     return arguments.length ? (tickFormat = _, axis) : tickFormat;

-   };

- 

-   axis.tickSize = function(_) {

-     return arguments.length ? (tickSizeInner = tickSizeOuter = +_, axis) : tickSizeInner;

-   };

- 

-   axis.tickSizeInner = function(_) {

-     return arguments.length ? (tickSizeInner = +_, axis) : tickSizeInner;

-   };

- 

-   axis.tickSizeOuter = function(_) {

-     return arguments.length ? (tickSizeOuter = +_, axis) : tickSizeOuter;

-   };

- 

-   axis.tickPadding = function(_) {

-     return arguments.length ? (tickPadding = +_, axis) : tickPadding;

-   };

- 

-   return axis;

- }

- 

- function axisTop(scale) {

-   return axis(top, scale);

- }

- 

- function axisRight(scale) {

-   return axis(right, scale);

- }

- 

- function axisBottom(scale) {

-   return axis(bottom, scale);

- }

- 

- function axisLeft(scale) {

-   return axis(left, scale);

- }

- 

- var noop = {value: function() {}};

- 

- function dispatch() {

-   for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {

-     if (!(t = arguments[i] + "") || (t in _)) throw new Error("illegal type: " + t);

-     _[t] = [];

-   }

-   return new Dispatch(_);

- }

- 

- function Dispatch(_) {

-   this._ = _;

- }

- 

- function parseTypenames(typenames, types) {

-   return typenames.trim().split(/^|\s+/).map(function(t) {

-     var name = "", i = t.indexOf(".");

-     if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);

-     if (t && !types.hasOwnProperty(t)) throw new Error("unknown type: " + t);

-     return {type: t, name: name};

-   });

- }

- 

- Dispatch.prototype = dispatch.prototype = {

-   constructor: Dispatch,

-   on: function(typename, callback) {

-     var _ = this._,

-         T = parseTypenames(typename + "", _),

-         t,

-         i = -1,

-         n = T.length;

- 

-     // If no callback was specified, return the callback of the given type and name.

-     if (arguments.length < 2) {

-       while (++i < n) if ((t = (typename = T[i]).type) && (t = get(_[t], typename.name))) return t;

-       return;

-     }

- 

-     // If a type was specified, set the callback for the given type and name.

-     // Otherwise, if a null callback was specified, remove callbacks of the given name.

-     if (callback != null && typeof callback !== "function") throw new Error("invalid callback: " + callback);

-     while (++i < n) {

-       if (t = (typename = T[i]).type) _[t] = set(_[t], typename.name, callback);

-       else if (callback == null) for (t in _) _[t] = set(_[t], typename.name, null);

-     }

- 

-     return this;

-   },

-   copy: function() {

-     var copy = {}, _ = this._;

-     for (var t in _) copy[t] = _[t].slice();

-     return new Dispatch(copy);

-   },

-   call: function(type, that) {

-     if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];

-     if (!this._.hasOwnProperty(type)) throw new Error("unknown type: " + type);

-     for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);

-   },

-   apply: function(type, that, args) {

-     if (!this._.hasOwnProperty(type)) throw new Error("unknown type: " + type);

-     for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);

-   }

- };

- 

- function get(type, name) {

-   for (var i = 0, n = type.length, c; i < n; ++i) {

-     if ((c = type[i]).name === name) {

-       return c.value;

-     }

-   }

- }

- 

- function set(type, name, callback) {

-   for (var i = 0, n = type.length; i < n; ++i) {

-     if (type[i].name === name) {

-       type[i] = noop, type = type.slice(0, i).concat(type.slice(i + 1));

-       break;

-     }

-   }

-   if (callback != null) type.push({name: name, value: callback});

-   return type;

- }

- 

- var xhtml = "http://www.w3.org/1999/xhtml";

- 

- var namespaces = {

-   svg: "http://www.w3.org/2000/svg",

-   xhtml: xhtml,

-   xlink: "http://www.w3.org/1999/xlink",

-   xml: "http://www.w3.org/XML/1998/namespace",

-   xmlns: "http://www.w3.org/2000/xmlns/"

- };

- 

- var namespace = function(name) {

-   var prefix = name += "", i = prefix.indexOf(":");

-   if (i >= 0 && (prefix = name.slice(0, i)) !== "xmlns") name = name.slice(i + 1);

-   return namespaces.hasOwnProperty(prefix) ? {space: namespaces[prefix], local: name} : name;

- };

- 

- function creatorInherit(name) {

-   return function() {

-     var document = this.ownerDocument,

-         uri = this.namespaceURI;

-     return uri === xhtml && document.documentElement.namespaceURI === xhtml

-         ? document.createElement(name)

-         : document.createElementNS(uri, name);

-   };

- }

- 

- function creatorFixed(fullname) {

-   return function() {

-     return this.ownerDocument.createElementNS(fullname.space, fullname.local);

-   };

- }

- 

- var creator = function(name) {

-   var fullname = namespace(name);

-   return (fullname.local

-       ? creatorFixed

-       : creatorInherit)(fullname);

- };

- 

- var nextId = 0;

- 

- function local$1() {

-   return new Local;

- }

- 

- function Local() {

-   this._ = "@" + (++nextId).toString(36);

- }

- 

- Local.prototype = local$1.prototype = {

-   constructor: Local,

-   get: function(node) {

-     var id = this._;

-     while (!(id in node)) if (!(node = node.parentNode)) return;

-     return node[id];

-   },

-   set: function(node, value) {

-     return node[this._] = value;

-   },

-   remove: function(node) {

-     return this._ in node && delete node[this._];

-   },

-   toString: function() {

-     return this._;

-   }

- };

- 

- var matcher = function(selector) {

-   return function() {

-     return this.matches(selector);

-   };

- };

- 

- if (typeof document !== "undefined") {

-   var element = document.documentElement;

-   if (!element.matches) {

-     var vendorMatches = element.webkitMatchesSelector

-         || element.msMatchesSelector

-         || element.mozMatchesSelector

-         || element.oMatchesSelector;

-     matcher = function(selector) {

-       return function() {

-         return vendorMatches.call(this, selector);

-       };

-     };

-   }

- }

- 

- var matcher$1 = matcher;

- 

- var filterEvents = {};

- 

- exports.event = null;

- 

- if (typeof document !== "undefined") {

-   var element$1 = document.documentElement;

-   if (!("onmouseenter" in element$1)) {

-     filterEvents = {mouseenter: "mouseover", mouseleave: "mouseout"};

-   }

- }

- 

- function filterContextListener(listener, index, group) {

-   listener = contextListener(listener, index, group);

-   return function(event) {

-     var related = event.relatedTarget;

-     if (!related || (related !== this && !(related.compareDocumentPosition(this) & 8))) {

-       listener.call(this, event);

-     }

-   };

- }

- 

- function contextListener(listener, index, group) {

-   return function(event1) {

-     var event0 = exports.event; // Events can be reentrant (e.g., focus).

-     exports.event = event1;

-     try {

-       listener.call(this, this.__data__, index, group);

-     } finally {

-       exports.event = event0;

-     }

-   };

- }

- 

- function parseTypenames$1(typenames) {

-   return typenames.trim().split(/^|\s+/).map(function(t) {

-     var name = "", i = t.indexOf(".");

-     if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);

-     return {type: t, name: name};

-   });

- }

- 

- function onRemove(typename) {

-   return function() {

-     var on = this.__on;

-     if (!on) return;

-     for (var j = 0, i = -1, m = on.length, o; j < m; ++j) {

-       if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) {

-         this.removeEventListener(o.type, o.listener, o.capture);

-       } else {

-         on[++i] = o;

-       }

-     }

-     if (++i) on.length = i;

-     else delete this.__on;

-   };

- }

- 

- function onAdd(typename, value, capture) {

-   var wrap = filterEvents.hasOwnProperty(typename.type) ? filterContextListener : contextListener;

-   return function(d, i, group) {

-     var on = this.__on, o, listener = wrap(value, i, group);

-     if (on) for (var j = 0, m = on.length; j < m; ++j) {

-       if ((o = on[j]).type === typename.type && o.name === typename.name) {

-         this.removeEventListener(o.type, o.listener, o.capture);

-         this.addEventListener(o.type, o.listener = listener, o.capture = capture);

-         o.value = value;

-         return;

-       }

-     }

-     this.addEventListener(typename.type, listener, capture);

-     o = {type: typename.type, name: typename.name, value: value, listener: listener, capture: capture};

-     if (!on) this.__on = [o];

-     else on.push(o);

-   };

- }

- 

- var selection_on = function(typename, value, capture) {

-   var typenames = parseTypenames$1(typename + ""), i, n = typenames.length, t;

- 

-   if (arguments.length < 2) {

-     var on = this.node().__on;

-     if (on) for (var j = 0, m = on.length, o; j < m; ++j) {

-       for (i = 0, o = on[j]; i < n; ++i) {

-         if ((t = typenames[i]).type === o.type && t.name === o.name) {

-           return o.value;

-         }

-       }

-     }

-     return;

-   }

- 

-   on = value ? onAdd : onRemove;

-   if (capture == null) capture = false;

-   for (i = 0; i < n; ++i) this.each(on(typenames[i], value, capture));

-   return this;

- };

- 

- function customEvent(event1, listener, that, args) {

-   var event0 = exports.event;

-   event1.sourceEvent = exports.event;

-   exports.event = event1;

-   try {

-     return listener.apply(that, args);

-   } finally {

-     exports.event = event0;

-   }

- }

- 

- var sourceEvent = function() {

-   var current = exports.event, source;

-   while (source = current.sourceEvent) current = source;

-   return current;

- };

- 

- var point = function(node, event) {

-   var svg = node.ownerSVGElement || node;

- 

-   if (svg.createSVGPoint) {

-     var point = svg.createSVGPoint();

-     point.x = event.clientX, point.y = event.clientY;

-     point = point.matrixTransform(node.getScreenCTM().inverse());

-     return [point.x, point.y];

-   }

- 

-   var rect = node.getBoundingClientRect();

-   return [event.clientX - rect.left - node.clientLeft, event.clientY - rect.top - node.clientTop];

- };

- 

- var mouse = function(node) {

-   var event = sourceEvent();

-   if (event.changedTouches) event = event.changedTouches[0];

-   return point(node, event);

- };

- 

- function none() {}

- 

- var selector = function(selector) {

-   return selector == null ? none : function() {

-     return this.querySelector(selector);

-   };

- };

- 

- var selection_select = function(select) {

-   if (typeof select !== "function") select = selector(select);

- 

-   for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {

-     for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {

-       if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {

-         if ("__data__" in node) subnode.__data__ = node.__data__;

-         subgroup[i] = subnode;

-       }

-     }

-   }

- 

-   return new Selection(subgroups, this._parents);

- };

- 

- function empty$1() {

-   return [];

- }

- 

- var selectorAll = function(selector) {

-   return selector == null ? empty$1 : function() {

-     return this.querySelectorAll(selector);

-   };

- };

- 

- var selection_selectAll = function(select) {

-   if (typeof select !== "function") select = selectorAll(select);

- 

-   for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {

-     for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {

-       if (node = group[i]) {

-         subgroups.push(select.call(node, node.__data__, i, group));

-         parents.push(node);

-       }

-     }

-   }

- 

-   return new Selection(subgroups, parents);

- };

- 

- var selection_filter = function(match) {

-   if (typeof match !== "function") match = matcher$1(match);

- 

-   for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {

-     for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {

-       if ((node = group[i]) && match.call(node, node.__data__, i, group)) {

-         subgroup.push(node);

-       }

-     }

-   }

- 

-   return new Selection(subgroups, this._parents);

- };

- 

- var sparse = function(update) {

-   return new Array(update.length);

- };

- 

- var selection_enter = function() {

-   return new Selection(this._enter || this._groups.map(sparse), this._parents);

- };

- 

- function EnterNode(parent, datum) {

-   this.ownerDocument = parent.ownerDocument;

-   this.namespaceURI = parent.namespaceURI;

-   this._next = null;

-   this._parent = parent;

-   this.__data__ = datum;

- }

- 

- EnterNode.prototype = {

-   constructor: EnterNode,

-   appendChild: function(child) { return this._parent.insertBefore(child, this._next); },

-   insertBefore: function(child, next) { return this._parent.insertBefore(child, next); },

-   querySelector: function(selector) { return this._parent.querySelector(selector); },

-   querySelectorAll: function(selector) { return this._parent.querySelectorAll(selector); }

- };

- 

- var constant$1 = function(x) {

-   return function() {

-     return x;

-   };

- };

- 

- var keyPrefix = "$"; // Protect against keys like “__proto__”.

- 

- function bindIndex(parent, group, enter, update, exit, data) {

-   var i = 0,

-       node,

-       groupLength = group.length,

-       dataLength = data.length;

- 

-   // Put any non-null nodes that fit into update.

-   // Put any null nodes into enter.

-   // Put any remaining data into enter.

-   for (; i < dataLength; ++i) {

-     if (node = group[i]) {

-       node.__data__ = data[i];

-       update[i] = node;

-     } else {

-       enter[i] = new EnterNode(parent, data[i]);

-     }

-   }

- 

-   // Put any non-null nodes that don’t fit into exit.

-   for (; i < groupLength; ++i) {

-     if (node = group[i]) {

-       exit[i] = node;

-     }

-   }

- }

- 

- function bindKey(parent, group, enter, update, exit, data, key) {

-   var i,

-       node,

-       nodeByKeyValue = {},

-       groupLength = group.length,

-       dataLength = data.length,

-       keyValues = new Array(groupLength),

-       keyValue;

- 

-   // Compute the key for each node.

-   // If multiple nodes have the same key, the duplicates are added to exit.

-   for (i = 0; i < groupLength; ++i) {

-     if (node = group[i]) {

-       keyValues[i] = keyValue = keyPrefix + key.call(node, node.__data__, i, group);

-       if (keyValue in nodeByKeyValue) {

-         exit[i] = node;

-       } else {

-         nodeByKeyValue[keyValue] = node;

-       }

-     }

-   }

- 

-   // Compute the key for each datum.

-   // If there a node associated with this key, join and add it to update.

-   // If there is not (or the key is a duplicate), add it to enter.

-   for (i = 0; i < dataLength; ++i) {

-     keyValue = keyPrefix + key.call(parent, data[i], i, data);

-     if (node = nodeByKeyValue[keyValue]) {

-       update[i] = node;

-       node.__data__ = data[i];

-       nodeByKeyValue[keyValue] = null;

-     } else {

-       enter[i] = new EnterNode(parent, data[i]);

-     }

-   }

- 

-   // Add any remaining nodes that were not bound to data to exit.

-   for (i = 0; i < groupLength; ++i) {

-     if ((node = group[i]) && (nodeByKeyValue[keyValues[i]] === node)) {

-       exit[i] = node;

-     }

-   }

- }

- 

- var selection_data = function(value, key) {

-   if (!value) {

-     data = new Array(this.size()), j = -1;

-     this.each(function(d) { data[++j] = d; });

-     return data;

-   }

- 

-   var bind = key ? bindKey : bindIndex,

-       parents = this._parents,

-       groups = this._groups;

- 

-   if (typeof value !== "function") value = constant$1(value);

- 

-   for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) {

-     var parent = parents[j],

-         group = groups[j],

-         groupLength = group.length,

-         data = value.call(parent, parent && parent.__data__, j, parents),

-         dataLength = data.length,

-         enterGroup = enter[j] = new Array(dataLength),

-         updateGroup = update[j] = new Array(dataLength),

-         exitGroup = exit[j] = new Array(groupLength);

- 

-     bind(parent, group, enterGroup, updateGroup, exitGroup, data, key);

- 

-     // Now connect the enter nodes to their following update node, such that

-     // appendChild can insert the materialized enter node before this node,

-     // rather than at the end of the parent node.

-     for (var i0 = 0, i1 = 0, previous, next; i0 < dataLength; ++i0) {

-       if (previous = enterGroup[i0]) {

-         if (i0 >= i1) i1 = i0 + 1;

-         while (!(next = updateGroup[i1]) && ++i1 < dataLength);

-         previous._next = next || null;

-       }

-     }

-   }

- 

-   update = new Selection(update, parents);

-   update._enter = enter;

-   update._exit = exit;

-   return update;

- };

- 

- var selection_exit = function() {

-   return new Selection(this._exit || this._groups.map(sparse), this._parents);

- };

- 

- var selection_merge = function(selection$$1) {

- 

-   for (var groups0 = this._groups, groups1 = selection$$1._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {

-     for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {

-       if (node = group0[i] || group1[i]) {

-         merge[i] = node;

-       }

-     }

-   }

- 

-   for (; j < m0; ++j) {

-     merges[j] = groups0[j];

-   }

- 

-   return new Selection(merges, this._parents);

- };

- 

- var selection_order = function() {

- 

-   for (var groups = this._groups, j = -1, m = groups.length; ++j < m;) {

-     for (var group = groups[j], i = group.length - 1, next = group[i], node; --i >= 0;) {

-       if (node = group[i]) {

-         if (next && next !== node.nextSibling) next.parentNode.insertBefore(node, next);

-         next = node;

-       }

-     }

-   }

- 

-   return this;

- };

- 

- var selection_sort = function(compare) {

-   if (!compare) compare = ascending$1;

- 

-   function compareNode(a, b) {

-     return a && b ? compare(a.__data__, b.__data__) : !a - !b;

-   }

- 

-   for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) {

-     for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node, i = 0; i < n; ++i) {

-       if (node = group[i]) {

-         sortgroup[i] = node;

-       }

-     }

-     sortgroup.sort(compareNode);

-   }

- 

-   return new Selection(sortgroups, this._parents).order();

- };

- 

- function ascending$1(a, b) {

-   return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;

- }

- 

- var selection_call = function() {

-   var callback = arguments[0];

-   arguments[0] = this;

-   callback.apply(null, arguments);

-   return this;

- };

- 

- var selection_nodes = function() {

-   var nodes = new Array(this.size()), i = -1;

-   this.each(function() { nodes[++i] = this; });

-   return nodes;

- };

- 

- var selection_node = function() {

- 

-   for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {

-     for (var group = groups[j], i = 0, n = group.length; i < n; ++i) {

-       var node = group[i];

-       if (node) return node;

-     }

-   }

- 

-   return null;

- };

- 

- var selection_size = function() {

-   var size = 0;

-   this.each(function() { ++size; });

-   return size;

- };

- 

- var selection_empty = function() {

-   return !this.node();

- };

- 

- var selection_each = function(callback) {

- 

-   for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {

-     for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {

-       if (node = group[i]) callback.call(node, node.__data__, i, group);

-     }

-   }

- 

-   return this;

- };

- 

- function attrRemove(name) {

-   return function() {

-     this.removeAttribute(name);

-   };

- }

- 

- function attrRemoveNS(fullname) {

-   return function() {

-     this.removeAttributeNS(fullname.space, fullname.local);

-   };

- }

- 

- function attrConstant(name, value) {

-   return function() {

-     this.setAttribute(name, value);

-   };

- }

- 

- function attrConstantNS(fullname, value) {

-   return function() {

-     this.setAttributeNS(fullname.space, fullname.local, value);

-   };

- }

- 

- function attrFunction(name, value) {

-   return function() {

-     var v = value.apply(this, arguments);

-     if (v == null) this.removeAttribute(name);

-     else this.setAttribute(name, v);

-   };

- }

- 

- function attrFunctionNS(fullname, value) {

-   return function() {

-     var v = value.apply(this, arguments);

-     if (v == null) this.removeAttributeNS(fullname.space, fullname.local);

-     else this.setAttributeNS(fullname.space, fullname.local, v);

-   };

- }

- 

- var selection_attr = function(name, value) {

-   var fullname = namespace(name);

- 

-   if (arguments.length < 2) {

-     var node = this.node();

-     return fullname.local

-         ? node.getAttributeNS(fullname.space, fullname.local)

-         : node.getAttribute(fullname);

-   }

- 

-   return this.each((value == null

-       ? (fullname.local ? attrRemoveNS : attrRemove) : (typeof value === "function"

-       ? (fullname.local ? attrFunctionNS : attrFunction)

-       : (fullname.local ? attrConstantNS : attrConstant)))(fullname, value));

- };

- 

- var defaultView = function(node) {

-   return (node.ownerDocument && node.ownerDocument.defaultView) // node is a Node

-       || (node.document && node) // node is a Window

-       || node.defaultView; // node is a Document

- };

- 

- function styleRemove(name) {

-   return function() {

-     this.style.removeProperty(name);

-   };

- }

- 

- function styleConstant(name, value, priority) {

-   return function() {

-     this.style.setProperty(name, value, priority);

-   };

- }

- 

- function styleFunction(name, value, priority) {

-   return function() {

-     var v = value.apply(this, arguments);

-     if (v == null) this.style.removeProperty(name);

-     else this.style.setProperty(name, v, priority);

-   };

- }

- 

- var selection_style = function(name, value, priority) {

-   return arguments.length > 1

-       ? this.each((value == null

-             ? styleRemove : typeof value === "function"

-             ? styleFunction

-             : styleConstant)(name, value, priority == null ? "" : priority))

-       : styleValue(this.node(), name);

- };

- 

- function styleValue(node, name) {

-   return node.style.getPropertyValue(name)

-       || defaultView(node).getComputedStyle(node, null).getPropertyValue(name);

- }

- 

- function propertyRemove(name) {

-   return function() {

-     delete this[name];

-   };

- }

- 

- function propertyConstant(name, value) {

-   return function() {

-     this[name] = value;

-   };

- }

- 

- function propertyFunction(name, value) {

-   return function() {

-     var v = value.apply(this, arguments);

-     if (v == null) delete this[name];

-     else this[name] = v;

-   };

- }

- 

- var selection_property = function(name, value) {

-   return arguments.length > 1

-       ? this.each((value == null

-           ? propertyRemove : typeof value === "function"

-           ? propertyFunction

-           : propertyConstant)(name, value))

-       : this.node()[name];

- };

- 

- function classArray(string) {

-   return string.trim().split(/^|\s+/);

- }

- 

- function classList(node) {

-   return node.classList || new ClassList(node);

- }

- 

- function ClassList(node) {

-   this._node = node;

-   this._names = classArray(node.getAttribute("class") || "");

- }

- 

- ClassList.prototype = {

-   add: function(name) {

-     var i = this._names.indexOf(name);

-     if (i < 0) {

-       this._names.push(name);

-       this._node.setAttribute("class", this._names.join(" "));

-     }

-   },

-   remove: function(name) {

-     var i = this._names.indexOf(name);

-     if (i >= 0) {

-       this._names.splice(i, 1);

-       this._node.setAttribute("class", this._names.join(" "));

-     }

-   },

-   contains: function(name) {

-     return this._names.indexOf(name) >= 0;

-   }

- };

- 

- function classedAdd(node, names) {

-   var list = classList(node), i = -1, n = names.length;

-   while (++i < n) list.add(names[i]);

- }

- 

- function classedRemove(node, names) {

-   var list = classList(node), i = -1, n = names.length;

-   while (++i < n) list.remove(names[i]);

- }

- 

- function classedTrue(names) {

-   return function() {

-     classedAdd(this, names);

-   };

- }

- 

- function classedFalse(names) {

-   return function() {

-     classedRemove(this, names);

-   };

- }

- 

- function classedFunction(names, value) {

-   return function() {

-     (value.apply(this, arguments) ? classedAdd : classedRemove)(this, names);

-   };

- }

- 

- var selection_classed = function(name, value) {

-   var names = classArray(name + "");

- 

-   if (arguments.length < 2) {

-     var list = classList(this.node()), i = -1, n = names.length;

-     while (++i < n) if (!list.contains(names[i])) return false;

-     return true;

-   }

- 

-   return this.each((typeof value === "function"

-       ? classedFunction : value

-       ? classedTrue

-       : classedFalse)(names, value));

- };

- 

- function textRemove() {

-   this.textContent = "";

- }

- 

- function textConstant(value) {

-   return function() {

-     this.textContent = value;

-   };

- }

- 

- function textFunction(value) {

-   return function() {

-     var v = value.apply(this, arguments);

-     this.textContent = v == null ? "" : v;

-   };

- }

- 

- var selection_text = function(value) {

-   return arguments.length

-       ? this.each(value == null

-           ? textRemove : (typeof value === "function"

-           ? textFunction

-           : textConstant)(value))

-       : this.node().textContent;

- };

- 

- function htmlRemove() {

-   this.innerHTML = "";

- }

- 

- function htmlConstant(value) {

-   return function() {

-     this.innerHTML = value;

-   };

- }

- 

- function htmlFunction(value) {

-   return function() {

-     var v = value.apply(this, arguments);

-     this.innerHTML = v == null ? "" : v;

-   };

- }

- 

- var selection_html = function(value) {

-   return arguments.length

-       ? this.each(value == null

-           ? htmlRemove : (typeof value === "function"

-           ? htmlFunction

-           : htmlConstant)(value))

-       : this.node().innerHTML;

- };

- 

- function raise() {

-   if (this.nextSibling) this.parentNode.appendChild(this);

- }

- 

- var selection_raise = function() {

-   return this.each(raise);

- };

- 

- function lower() {

-   if (this.previousSibling) this.parentNode.insertBefore(this, this.parentNode.firstChild);

- }

- 

- var selection_lower = function() {

-   return this.each(lower);

- };

- 

- var selection_append = function(name) {

-   var create = typeof name === "function" ? name : creator(name);

-   return this.select(function() {

-     return this.appendChild(create.apply(this, arguments));

-   });

- };

- 

- function constantNull() {

-   return null;

- }

- 

- var selection_insert = function(name, before) {

-   var create = typeof name === "function" ? name : creator(name),

-       select = before == null ? constantNull : typeof before === "function" ? before : selector(before);

-   return this.select(function() {

-     return this.insertBefore(create.apply(this, arguments), select.apply(this, arguments) || null);

-   });

- };

- 

- function remove() {

-   var parent = this.parentNode;

-   if (parent) parent.removeChild(this);

- }

- 

- var selection_remove = function() {

-   return this.each(remove);

- };

- 

- var selection_datum = function(value) {

-   return arguments.length

-       ? this.property("__data__", value)

-       : this.node().__data__;

- };

- 

- function dispatchEvent(node, type, params) {

-   var window = defaultView(node),

-       event = window.CustomEvent;

- 

-   if (typeof event === "function") {

-     event = new event(type, params);

-   } else {

-     event = window.document.createEvent("Event");

-     if (params) event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail;

-     else event.initEvent(type, false, false);

-   }

- 

-   node.dispatchEvent(event);

- }

- 

- function dispatchConstant(type, params) {

-   return function() {

-     return dispatchEvent(this, type, params);

-   };

- }

- 

- function dispatchFunction(type, params) {

-   return function() {

-     return dispatchEvent(this, type, params.apply(this, arguments));

-   };

- }

- 

- var selection_dispatch = function(type, params) {

-   return this.each((typeof params === "function"

-       ? dispatchFunction

-       : dispatchConstant)(type, params));

- };

- 

- var root = [null];

- 

- function Selection(groups, parents) {

-   this._groups = groups;

-   this._parents = parents;

- }

- 

- function selection() {

-   return new Selection([[document.documentElement]], root);

- }

- 

- Selection.prototype = selection.prototype = {

-   constructor: Selection,

-   select: selection_select,

-   selectAll: selection_selectAll,

-   filter: selection_filter,

-   data: selection_data,

-   enter: selection_enter,

-   exit: selection_exit,

-   merge: selection_merge,

-   order: selection_order,

-   sort: selection_sort,

-   call: selection_call,

-   nodes: selection_nodes,

-   node: selection_node,

-   size: selection_size,

-   empty: selection_empty,

-   each: selection_each,

-   attr: selection_attr,

-   style: selection_style,

-   property: selection_property,

-   classed: selection_classed,

-   text: selection_text,

-   html: selection_html,

-   raise: selection_raise,

-   lower: selection_lower,

-   append: selection_append,

-   insert: selection_insert,

-   remove: selection_remove,

-   datum: selection_datum,

-   on: selection_on,

-   dispatch: selection_dispatch

- };

- 

- var select = function(selector) {

-   return typeof selector === "string"

-       ? new Selection([[document.querySelector(selector)]], [document.documentElement])

-       : new Selection([[selector]], root);

- };

- 

- var selectAll = function(selector) {

-   return typeof selector === "string"

-       ? new Selection([document.querySelectorAll(selector)], [document.documentElement])

-       : new Selection([selector == null ? [] : selector], root);

- };

- 

- var touch = function(node, touches, identifier) {

-   if (arguments.length < 3) identifier = touches, touches = sourceEvent().changedTouches;

- 

-   for (var i = 0, n = touches ? touches.length : 0, touch; i < n; ++i) {

-     if ((touch = touches[i]).identifier === identifier) {

-       return point(node, touch);

-     }

-   }

- 

-   return null;

- };

- 

- var touches = function(node, touches) {

-   if (touches == null) touches = sourceEvent().touches;

- 

-   for (var i = 0, n = touches ? touches.length : 0, points = new Array(n); i < n; ++i) {

-     points[i] = point(node, touches[i]);

-   }

- 

-   return points;

- };

- 

- function nopropagation() {

-   exports.event.stopImmediatePropagation();

- }

- 

- var noevent = function() {

-   exports.event.preventDefault();

-   exports.event.stopImmediatePropagation();

- };

- 

- var dragDisable = function(view) {

-   var root = view.document.documentElement,

-       selection = select(view).on("dragstart.drag", noevent, true);

-   if ("onselectstart" in root) {

-     selection.on("selectstart.drag", noevent, true);

-   } else {

-     root.__noselect = root.style.MozUserSelect;

-     root.style.MozUserSelect = "none";

-   }

- };

- 

- function yesdrag(view, noclick) {

-   var root = view.document.documentElement,

-       selection = select(view).on("dragstart.drag", null);

-   if (noclick) {

-     selection.on("click.drag", noevent, true);

-     setTimeout(function() { selection.on("click.drag", null); }, 0);

-   }

-   if ("onselectstart" in root) {

-     selection.on("selectstart.drag", null);

-   } else {

-     root.style.MozUserSelect = root.__noselect;

-     delete root.__noselect;

-   }

- }

- 

- var constant$2 = function(x) {

-   return function() {

-     return x;

-   };

- };

- 

- function DragEvent(target, type, subject, id, active, x, y, dx, dy, dispatch) {

-   this.target = target;

-   this.type = type;

-   this.subject = subject;

-   this.identifier = id;

-   this.active = active;

-   this.x = x;

-   this.y = y;

-   this.dx = dx;

-   this.dy = dy;

-   this._ = dispatch;

- }

- 

- DragEvent.prototype.on = function() {

-   var value = this._.on.apply(this._, arguments);

-   return value === this._ ? this : value;

- };

- 

- // Ignore right-click, since that should open the context menu.

- function defaultFilter$1() {

-   return !exports.event.button;

- }

- 

- function defaultContainer() {

-   return this.parentNode;

- }

- 

- function defaultSubject(d) {

-   return d == null ? {x: exports.event.x, y: exports.event.y} : d;

- }

- 

- function defaultTouchable() {

-   return "ontouchstart" in this;

- }

- 

- var drag = function() {

-   var filter = defaultFilter$1,

-       container = defaultContainer,

-       subject = defaultSubject,

-       touchable = defaultTouchable,

-       gestures = {},

-       listeners = dispatch("start", "drag", "end"),

-       active = 0,

-       mousedownx,

-       mousedowny,

-       mousemoving,

-       touchending,

-       clickDistance2 = 0;

- 

-   function drag(selection) {

-     selection

-         .on("mousedown.drag", mousedowned)

-       .filter(touchable)

-         .on("touchstart.drag", touchstarted)

-         .on("touchmove.drag", touchmoved)

-         .on("touchend.drag touchcancel.drag", touchended)

-         .style("touch-action", "none")

-         .style("-webkit-tap-highlight-color", "rgba(0,0,0,0)");

-   }

- 

-   function mousedowned() {

-     if (touchending || !filter.apply(this, arguments)) return;

-     var gesture = beforestart("mouse", container.apply(this, arguments), mouse, this, arguments);

-     if (!gesture) return;

-     select(exports.event.view).on("mousemove.drag", mousemoved, true).on("mouseup.drag", mouseupped, true);

-     dragDisable(exports.event.view);

-     nopropagation();

-     mousemoving = false;

-     mousedownx = exports.event.clientX;

-     mousedowny = exports.event.clientY;

-     gesture("start");

-   }

- 

-   function mousemoved() {

-     noevent();

-     if (!mousemoving) {

-       var dx = exports.event.clientX - mousedownx, dy = exports.event.clientY - mousedowny;

-       mousemoving = dx * dx + dy * dy > clickDistance2;

-     }

-     gestures.mouse("drag");

-   }

- 

-   function mouseupped() {

-     select(exports.event.view).on("mousemove.drag mouseup.drag", null);

-     yesdrag(exports.event.view, mousemoving);

-     noevent();

-     gestures.mouse("end");

-   }

- 

-   function touchstarted() {

-     if (!filter.apply(this, arguments)) return;

-     var touches = exports.event.changedTouches,

-         c = container.apply(this, arguments),

-         n = touches.length, i, gesture;

- 

-     for (i = 0; i < n; ++i) {

-       if (gesture = beforestart(touches[i].identifier, c, touch, this, arguments)) {

-         nopropagation();

-         gesture("start");

-       }

-     }

-   }

- 

-   function touchmoved() {

-     var touches = exports.event.changedTouches,

-         n = touches.length, i, gesture;

- 

-     for (i = 0; i < n; ++i) {

-       if (gesture = gestures[touches[i].identifier]) {

-         noevent();

-         gesture("drag");

-       }

-     }

-   }

- 

-   function touchended() {

-     var touches = exports.event.changedTouches,

-         n = touches.length, i, gesture;

- 

-     if (touchending) clearTimeout(touchending);

-     touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!

-     for (i = 0; i < n; ++i) {

-       if (gesture = gestures[touches[i].identifier]) {

-         nopropagation();

-         gesture("end");

-       }

-     }

-   }

- 

-   function beforestart(id, container, point, that, args) {

-     var p = point(container, id), s, dx, dy,

-         sublisteners = listeners.copy();

- 

-     if (!customEvent(new DragEvent(drag, "beforestart", s, id, active, p[0], p[1], 0, 0, sublisteners), function() {

-       if ((exports.event.subject = s = subject.apply(that, args)) == null) return false;

-       dx = s.x - p[0] || 0;

-       dy = s.y - p[1] || 0;

-       return true;

-     })) return;

- 

-     return function gesture(type) {

-       var p0 = p, n;

-       switch (type) {

-         case "start": gestures[id] = gesture, n = active++; break;

-         case "end": delete gestures[id], --active; // nobreak

-         case "drag": p = point(container, id), n = active; break;

-       }

-       customEvent(new DragEvent(drag, type, s, id, n, p[0] + dx, p[1] + dy, p[0] - p0[0], p[1] - p0[1], sublisteners), sublisteners.apply, sublisteners, [type, that, args]);

-     };

-   }

- 

-   drag.filter = function(_) {

-     return arguments.length ? (filter = typeof _ === "function" ? _ : constant$2(!!_), drag) : filter;

-   };

- 

-   drag.container = function(_) {

-     return arguments.length ? (container = typeof _ === "function" ? _ : constant$2(_), drag) : container;

-   };

- 

-   drag.subject = function(_) {

-     return arguments.length ? (subject = typeof _ === "function" ? _ : constant$2(_), drag) : subject;

-   };

- 

-   drag.touchable = function(_) {

-     return arguments.length ? (touchable = typeof _ === "function" ? _ : constant$2(!!_), drag) : touchable;

-   };

- 

-   drag.on = function() {

-     var value = listeners.on.apply(listeners, arguments);

-     return value === listeners ? drag : value;

-   };

- 

-   drag.clickDistance = function(_) {

-     return arguments.length ? (clickDistance2 = (_ = +_) * _, drag) : Math.sqrt(clickDistance2);

-   };

- 

-   return drag;

- };

- 

- var define = function(constructor, factory, prototype) {

-   constructor.prototype = factory.prototype = prototype;

-   prototype.constructor = constructor;

- };

- 

- function extend(parent, definition) {

-   var prototype = Object.create(parent.prototype);

-   for (var key in definition) prototype[key] = definition[key];

-   return prototype;

- }

- 

- function Color() {}

- 

- var darker = 0.7;

- var brighter = 1 / darker;

- 

- var reI = "\\s*([+-]?\\d+)\\s*";

- var reN = "\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)\\s*";

- var reP = "\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)%\\s*";

- var reHex3 = /^#([0-9a-f]{3})$/;

- var reHex6 = /^#([0-9a-f]{6})$/;

- var reRgbInteger = new RegExp("^rgb\\(" + [reI, reI, reI] + "\\)$");

- var reRgbPercent = new RegExp("^rgb\\(" + [reP, reP, reP] + "\\)$");

- var reRgbaInteger = new RegExp("^rgba\\(" + [reI, reI, reI, reN] + "\\)$");

- var reRgbaPercent = new RegExp("^rgba\\(" + [reP, reP, reP, reN] + "\\)$");

- var reHslPercent = new RegExp("^hsl\\(" + [reN, reP, reP] + "\\)$");

- var reHslaPercent = new RegExp("^hsla\\(" + [reN, reP, reP, reN] + "\\)$");

- 

- var named = {

-   aliceblue: 0xf0f8ff,

-   antiquewhite: 0xfaebd7,

-   aqua: 0x00ffff,

-   aquamarine: 0x7fffd4,

-   azure: 0xf0ffff,

-   beige: 0xf5f5dc,

-   bisque: 0xffe4c4,

-   black: 0x000000,

-   blanchedalmond: 0xffebcd,

-   blue: 0x0000ff,

-   blueviolet: 0x8a2be2,

-   brown: 0xa52a2a,

-   burlywood: 0xdeb887,

-   cadetblue: 0x5f9ea0,

-   chartreuse: 0x7fff00,

-   chocolate: 0xd2691e,

-   coral: 0xff7f50,

-   cornflowerblue: 0x6495ed,

-   cornsilk: 0xfff8dc,

-   crimson: 0xdc143c,

-   cyan: 0x00ffff,

-   darkblue: 0x00008b,

-   darkcyan: 0x008b8b,

-   darkgoldenrod: 0xb8860b,

-   darkgray: 0xa9a9a9,

-   darkgreen: 0x006400,

-   darkgrey: 0xa9a9a9,

-   darkkhaki: 0xbdb76b,

-   darkmagenta: 0x8b008b,

-   darkolivegreen: 0x556b2f,

-   darkorange: 0xff8c00,

-   darkorchid: 0x9932cc,

-   darkred: 0x8b0000,

-   darksalmon: 0xe9967a,

-   darkseagreen: 0x8fbc8f,

-   darkslateblue: 0x483d8b,

-   darkslategray: 0x2f4f4f,

-   darkslategrey: 0x2f4f4f,

-   darkturquoise: 0x00ced1,

-   darkviolet: 0x9400d3,

-   deeppink: 0xff1493,

-   deepskyblue: 0x00bfff,

-   dimgray: 0x696969,

-   dimgrey: 0x696969,

-   dodgerblue: 0x1e90ff,

-   firebrick: 0xb22222,

-   floralwhite: 0xfffaf0,

-   forestgreen: 0x228b22,

-   fuchsia: 0xff00ff,

-   gainsboro: 0xdcdcdc,

-   ghostwhite: 0xf8f8ff,

-   gold: 0xffd700,

-   goldenrod: 0xdaa520,

-   gray: 0x808080,

-   green: 0x008000,

-   greenyellow: 0xadff2f,

-   grey: 0x808080,

-   honeydew: 0xf0fff0,

-   hotpink: 0xff69b4,

-   indianred: 0xcd5c5c,

-   indigo: 0x4b0082,

-   ivory: 0xfffff0,

-   khaki: 0xf0e68c,

-   lavender: 0xe6e6fa,

-   lavenderblush: 0xfff0f5,

-   lawngreen: 0x7cfc00,

-   lemonchiffon: 0xfffacd,

-   lightblue: 0xadd8e6,

-   lightcoral: 0xf08080,

-   lightcyan: 0xe0ffff,

-   lightgoldenrodyellow: 0xfafad2,

-   lightgray: 0xd3d3d3,

-   lightgreen: 0x90ee90,

-   lightgrey: 0xd3d3d3,

-   lightpink: 0xffb6c1,

-   lightsalmon: 0xffa07a,

-   lightseagreen: 0x20b2aa,

-   lightskyblue: 0x87cefa,

-   lightslategray: 0x778899,

-   lightslategrey: 0x778899,

-   lightsteelblue: 0xb0c4de,

-   lightyellow: 0xffffe0,

-   lime: 0x00ff00,

-   limegreen: 0x32cd32,

-   linen: 0xfaf0e6,

-   magenta: 0xff00ff,

-   maroon: 0x800000,

-   mediumaquamarine: 0x66cdaa,

-   mediumblue: 0x0000cd,

-   mediumorchid: 0xba55d3,

-   mediumpurple: 0x9370db,

-   mediumseagreen: 0x3cb371,

-   mediumslateblue: 0x7b68ee,

-   mediumspringgreen: 0x00fa9a,

-   mediumturquoise: 0x48d1cc,

-   mediumvioletred: 0xc71585,

-   midnightblue: 0x191970,

-   mintcream: 0xf5fffa,

-   mistyrose: 0xffe4e1,

-   moccasin: 0xffe4b5,

-   navajowhite: 0xffdead,

-   navy: 0x000080,

-   oldlace: 0xfdf5e6,

-   olive: 0x808000,

-   olivedrab: 0x6b8e23,

-   orange: 0xffa500,

-   orangered: 0xff4500,

-   orchid: 0xda70d6,

-   palegoldenrod: 0xeee8aa,

-   palegreen: 0x98fb98,

-   paleturquoise: 0xafeeee,

-   palevioletred: 0xdb7093,

-   papayawhip: 0xffefd5,

-   peachpuff: 0xffdab9,

-   peru: 0xcd853f,

-   pink: 0xffc0cb,

-   plum: 0xdda0dd,

-   powderblue: 0xb0e0e6,

-   purple: 0x800080,

-   rebeccapurple: 0x663399,

-   red: 0xff0000,

-   rosybrown: 0xbc8f8f,

-   royalblue: 0x4169e1,

-   saddlebrown: 0x8b4513,

-   salmon: 0xfa8072,

-   sandybrown: 0xf4a460,

-   seagreen: 0x2e8b57,

-   seashell: 0xfff5ee,

-   sienna: 0xa0522d,

-   silver: 0xc0c0c0,

-   skyblue: 0x87ceeb,

-   slateblue: 0x6a5acd,

-   slategray: 0x708090,

-   slategrey: 0x708090,

-   snow: 0xfffafa,

-   springgreen: 0x00ff7f,

-   steelblue: 0x4682b4,

-   tan: 0xd2b48c,

-   teal: 0x008080,

-   thistle: 0xd8bfd8,

-   tomato: 0xff6347,

-   turquoise: 0x40e0d0,

-   violet: 0xee82ee,

-   wheat: 0xf5deb3,

-   white: 0xffffff,

-   whitesmoke: 0xf5f5f5,

-   yellow: 0xffff00,

-   yellowgreen: 0x9acd32

- };

- 

- define(Color, color, {

-   displayable: function() {

-     return this.rgb().displayable();

-   },

-   toString: function() {

-     return this.rgb() + "";

-   }

- });

- 

- function color(format) {

-   var m;

-   format = (format + "").trim().toLowerCase();

-   return (m = reHex3.exec(format)) ? (m = parseInt(m[1], 16), new Rgb((m >> 8 & 0xf) | (m >> 4 & 0x0f0), (m >> 4 & 0xf) | (m & 0xf0), ((m & 0xf) << 4) | (m & 0xf), 1)) // #f00

-       : (m = reHex6.exec(format)) ? rgbn(parseInt(m[1], 16)) // #ff0000

-       : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)

-       : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)

-       : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)

-       : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)

-       : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)

-       : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)

-       : named.hasOwnProperty(format) ? rgbn(named[format])

-       : format === "transparent" ? new Rgb(NaN, NaN, NaN, 0)

-       : null;

- }

- 

- function rgbn(n) {

-   return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);

- }

- 

- function rgba(r, g, b, a) {

-   if (a <= 0) r = g = b = NaN;

-   return new Rgb(r, g, b, a);

- }

- 

- function rgbConvert(o) {

-   if (!(o instanceof Color)) o = color(o);

-   if (!o) return new Rgb;

-   o = o.rgb();

-   return new Rgb(o.r, o.g, o.b, o.opacity);

- }

- 

- function rgb(r, g, b, opacity) {

-   return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);

- }

- 

- function Rgb(r, g, b, opacity) {

-   this.r = +r;

-   this.g = +g;

-   this.b = +b;

-   this.opacity = +opacity;

- }

- 

- define(Rgb, rgb, extend(Color, {

-   brighter: function(k) {

-     k = k == null ? brighter : Math.pow(brighter, k);

-     return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);

-   },

-   darker: function(k) {

-     k = k == null ? darker : Math.pow(darker, k);

-     return new Rgb(this.r * k, this.g * k, this.b * k, 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 a = this.opacity; a = isNaN(a) ? 1 : Math.max(0, Math.min(1, a));

-     return (a === 1 ? "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))

-         + (a === 1 ? ")" : ", " + a + ")");

-   }

- }));

- 

- function hsla(h, s, l, a) {

-   if (a <= 0) h = s = l = NaN;

-   else if (l <= 0 || l >= 1) h = s = NaN;

-   else if (s <= 0) h = NaN;

-   return new Hsl(h, s, l, a);

- }

- 

- function hslConvert(o) {

-   if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);

-   if (!(o instanceof Color)) o = color(o);

-   if (!o) return new Hsl;

-   if (o instanceof Hsl) return o;

-   o = o.rgb();

-   var r = o.r / 255,

-       g = o.g / 255,

-       b = o.b / 255,

-       min = Math.min(r, g, b),

-       max = Math.max(r, g, b),

-       h = NaN,

-       s = max - min,

-       l = (max + min) / 2;

-   if (s) {

-     if (r === max) h = (g - b) / s + (g < b) * 6;

-     else if (g === max) h = (b - r) / s + 2;

-     else h = (r - g) / s + 4;

-     s /= l < 0.5 ? max + min : 2 - max - min;

-     h *= 60;

-   } else {

-     s = l > 0 && l < 1 ? 0 : h;

-   }

-   return new Hsl(h, s, l, o.opacity);

- }

- 

- function hsl(h, s, l, opacity) {

-   return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);

- }

- 

- function Hsl(h, s, l, opacity) {

-   this.h = +h;

-   this.s = +s;

-   this.l = +l;

-   this.opacity = +opacity;

- }

- 

- define(Hsl, hsl, extend(Color, {

-   brighter: function(k) {

-     k = k == null ? brighter : Math.pow(brighter, k);

-     return new Hsl(this.h, this.s, this.l * k, this.opacity);

-   },

-   darker: function(k) {

-     k = k == null ? darker : Math.pow(darker, k);

-     return new Hsl(this.h, this.s, this.l * k, this.opacity);

-   },

-   rgb: function() {

-     var h = this.h % 360 + (this.h < 0) * 360,

-         s = isNaN(h) || isNaN(this.s) ? 0 : this.s,

-         l = this.l,

-         m2 = l + (l < 0.5 ? l : 1 - l) * s,

-         m1 = 2 * l - m2;

-     return new Rgb(

-       hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2),

-       hsl2rgb(h, m1, m2),

-       hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2),

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

-   }

- }));

- 

- /* From FvD 13.37, CSS Color Module Level 3 */

- function hsl2rgb(h, m1, m2) {

-   return (h < 60 ? m1 + (m2 - m1) * h / 60

-       : h < 180 ? m2

-       : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60

-       : m1) * 255;

- }

- 

- var deg2rad = Math.PI / 180;

- var rad2deg = 180 / Math.PI;

- 

- var Kn = 18;

- var Xn = 0.950470;

- var Yn = 1;

- var Zn = 1.088830;

- var t0 = 4 / 29;

- var t1 = 6 / 29;

- var t2 = 3 * t1 * t1;

- var t3 = t1 * t1 * t1;

- 

- function labConvert(o) {

-   if (o instanceof Lab) return new Lab(o.l, o.a, o.b, o.opacity);

-   if (o instanceof Hcl) {

-     var h = o.h * deg2rad;

-     return new Lab(o.l, Math.cos(h) * o.c, Math.sin(h) * o.c, o.opacity);

-   }

-   if (!(o instanceof Rgb)) o = rgbConvert(o);

-   var b = rgb2xyz(o.r),

-       a = rgb2xyz(o.g),

-       l = rgb2xyz(o.b),

-       x = xyz2lab((0.4124564 * b + 0.3575761 * a + 0.1804375 * l) / Xn),

-       y = xyz2lab((0.2126729 * b + 0.7151522 * a + 0.0721750 * l) / Yn),

-       z = xyz2lab((0.0193339 * b + 0.1191920 * a + 0.9503041 * l) / Zn);

-   return new Lab(116 * y - 16, 500 * (x - y), 200 * (y - z), o.opacity);

- }

- 

- function lab(l, a, b, opacity) {

-   return arguments.length === 1 ? labConvert(l) : new Lab(l, a, b, opacity == null ? 1 : opacity);

- }

- 

- function Lab(l, a, b, opacity) {

-   this.l = +l;

-   this.a = +a;

-   this.b = +b;

-   this.opacity = +opacity;

- }

- 

- define(Lab, lab, extend(Color, {

-   brighter: function(k) {

-     return new Lab(this.l + Kn * (k == null ? 1 : k), this.a, this.b, this.opacity);

-   },

-   darker: function(k) {

-     return new Lab(this.l - Kn * (k == null ? 1 : k), this.a, this.b, this.opacity);

-   },

-   rgb: function() {

-     var y = (this.l + 16) / 116,

-         x = isNaN(this.a) ? y : y + this.a / 500,

-         z = isNaN(this.b) ? y : y - this.b / 200;

-     y = Yn * lab2xyz(y);

-     x = Xn * lab2xyz(x);

-     z = Zn * lab2xyz(z);

-     return new Rgb(

-       xyz2rgb( 3.2404542 * x - 1.5371385 * y - 0.4985314 * z), // D65 -> sRGB

-       xyz2rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z),

-       xyz2rgb( 0.0556434 * x - 0.2040259 * y + 1.0572252 * z),

-       this.opacity

-     );

-   }

- }));

- 

- function xyz2lab(t) {

-   return t > t3 ? Math.pow(t, 1 / 3) : t / t2 + t0;

- }

- 

- function lab2xyz(t) {

-   return t > t1 ? t * t * t : t2 * (t - t0);

- }

- 

- function xyz2rgb(x) {

-   return 255 * (x <= 0.0031308 ? 12.92 * x : 1.055 * Math.pow(x, 1 / 2.4) - 0.055);

- }

- 

- function rgb2xyz(x) {

-   return (x /= 255) <= 0.04045 ? x / 12.92 : Math.pow((x + 0.055) / 1.055, 2.4);

- }

- 

- function hclConvert(o) {

-   if (o instanceof Hcl) return new Hcl(o.h, o.c, o.l, o.opacity);

-   if (!(o instanceof Lab)) o = labConvert(o);

-   var h = Math.atan2(o.b, o.a) * rad2deg;

-   return new Hcl(h < 0 ? h + 360 : h, Math.sqrt(o.a * o.a + o.b * o.b), o.l, o.opacity);

- }

- 

- function hcl(h, c, l, opacity) {

-   return arguments.length === 1 ? hclConvert(h) : new Hcl(h, c, l, opacity == null ? 1 : opacity);

- }

- 

- function Hcl(h, c, l, opacity) {

-   this.h = +h;

-   this.c = +c;

-   this.l = +l;

-   this.opacity = +opacity;

- }

- 

- define(Hcl, hcl, extend(Color, {

-   brighter: function(k) {

-     return new Hcl(this.h, this.c, this.l + Kn * (k == null ? 1 : k), this.opacity);

-   },

-   darker: function(k) {

-     return new Hcl(this.h, this.c, this.l - Kn * (k == null ? 1 : k), this.opacity);

-   },

-   rgb: function() {

-     return labConvert(this).rgb();

-   }

- }));

- 

- var A = -0.14861;

- var B = +1.78277;

- var C = -0.29227;

- var D = -0.90649;

- var E = +1.97294;

- var ED = E * D;

- var EB = E * B;

- var BC_DA = B * C - D * A;

- 

- function cubehelixConvert(o) {

-   if (o instanceof Cubehelix) return new Cubehelix(o.h, o.s, o.l, o.opacity);

-   if (!(o instanceof Rgb)) o = rgbConvert(o);

-   var r = o.r / 255,

-       g = o.g / 255,

-       b = o.b / 255,

-       l = (BC_DA * b + ED * r - EB * g) / (BC_DA + ED - EB),

-       bl = b - l,

-       k = (E * (g - l) - C * bl) / D,

-       s = Math.sqrt(k * k + bl * bl) / (E * l * (1 - l)), // NaN if l=0 or l=1

-       h = s ? Math.atan2(k, bl) * rad2deg - 120 : NaN;

-   return new Cubehelix(h < 0 ? h + 360 : h, s, l, o.opacity);

- }

- 

- function cubehelix(h, s, l, opacity) {

-   return arguments.length === 1 ? cubehelixConvert(h) : new Cubehelix(h, s, l, opacity == null ? 1 : opacity);

- }

- 

- function Cubehelix(h, s, l, opacity) {

-   this.h = +h;

-   this.s = +s;

-   this.l = +l;

-   this.opacity = +opacity;

- }

- 

- define(Cubehelix, cubehelix, extend(Color, {

-   brighter: function(k) {

-     k = k == null ? brighter : Math.pow(brighter, k);

-     return new Cubehelix(this.h, this.s, this.l * k, this.opacity);

-   },

-   darker: function(k) {

-     k = k == null ? darker : Math.pow(darker, k);

-     return new Cubehelix(this.h, this.s, this.l * k, this.opacity);

-   },

-   rgb: function() {

-     var h = isNaN(this.h) ? 0 : (this.h + 120) * deg2rad,

-         l = +this.l,

-         a = isNaN(this.s) ? 0 : this.s * l * (1 - l),

-         cosh = Math.cos(h),

-         sinh = Math.sin(h);

-     return new Rgb(

-       255 * (l + a * (A * cosh + B * sinh)),

-       255 * (l + a * (C * cosh + D * sinh)),

-       255 * (l + a * (E * cosh)),

-       this.opacity

-     );

-   }

- }));

- 

- function basis(t1, v0, v1, v2, v3) {

-   var t2 = t1 * t1, t3 = t2 * t1;

-   return ((1 - 3 * t1 + 3 * t2 - t3) * v0

-       + (4 - 6 * t2 + 3 * t3) * v1

-       + (1 + 3 * t1 + 3 * t2 - 3 * t3) * v2

-       + t3 * v3) / 6;

- }

- 

- var basis$1 = function(values) {

-   var n = values.length - 1;

-   return function(t) {

-     var i = t <= 0 ? (t = 0) : t >= 1 ? (t = 1, n - 1) : Math.floor(t * n),

-         v1 = values[i],

-         v2 = values[i + 1],

-         v0 = i > 0 ? values[i - 1] : 2 * v1 - v2,

-         v3 = i < n - 1 ? values[i + 2] : 2 * v2 - v1;

-     return basis((t - i / n) * n, v0, v1, v2, v3);

-   };

- };

- 

- var basisClosed = function(values) {

-   var n = values.length;

-   return function(t) {

-     var i = Math.floor(((t %= 1) < 0 ? ++t : t) * n),

-         v0 = values[(i + n - 1) % n],

-         v1 = values[i % n],

-         v2 = values[(i + 1) % n],

-         v3 = values[(i + 2) % n];

-     return basis((t - i / n) * n, v0, v1, v2, v3);

-   };

- };

- 

- var constant$3 = function(x) {

-   return function() {

-     return x;

-   };

- };

- 

- function linear(a, d) {

-   return function(t) {

-     return a + t * d;

-   };

- }

- 

- function exponential(a, b, y) {

-   return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) {

-     return Math.pow(a + t * b, y);

-   };

- }

- 

- function hue(a, b) {

-   var d = b - a;

-   return d ? linear(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant$3(isNaN(a) ? b : a);

- }

- 

- function gamma(y) {

-   return (y = +y) === 1 ? nogamma : function(a, b) {

-     return b - a ? exponential(a, b, y) : constant$3(isNaN(a) ? b : a);

-   };

- }

- 

- function nogamma(a, b) {

-   var d = b - a;

-   return d ? linear(a, d) : constant$3(isNaN(a) ? b : a);

- }

- 

- var interpolateRgb = (function rgbGamma(y) {

-   var color$$1 = gamma(y);

- 

-   function rgb$$1(start, end) {

-     var r = color$$1((start = rgb(start)).r, (end = rgb(end)).r),

-         g = color$$1(start.g, end.g),

-         b = color$$1(start.b, end.b),

-         opacity = nogamma(start.opacity, end.opacity);

-     return function(t) {

-       start.r = r(t);

-       start.g = g(t);

-       start.b = b(t);

-       start.opacity = opacity(t);

-       return start + "";

-     };

-   }

- 

-   rgb$$1.gamma = rgbGamma;

- 

-   return rgb$$1;

- })(1);

- 

- function rgbSpline(spline) {

-   return function(colors) {

-     var n = colors.length,

-         r = new Array(n),

-         g = new Array(n),

-         b = new Array(n),

-         i, color$$1;

-     for (i = 0; i < n; ++i) {

-       color$$1 = rgb(colors[i]);

-       r[i] = color$$1.r || 0;

-       g[i] = color$$1.g || 0;

-       b[i] = color$$1.b || 0;

-     }

-     r = spline(r);

-     g = spline(g);

-     b = spline(b);

-     color$$1.opacity = 1;

-     return function(t) {

-       color$$1.r = r(t);

-       color$$1.g = g(t);

-       color$$1.b = b(t);

-       return color$$1 + "";

-     };

-   };

- }

- 

- var rgbBasis = rgbSpline(basis$1);

- var rgbBasisClosed = rgbSpline(basisClosed);

- 

- var array$1 = function(a, b) {

-   var nb = b ? b.length : 0,

-       na = a ? Math.min(nb, a.length) : 0,

-       x = new Array(nb),

-       c = new Array(nb),

-       i;

- 

-   for (i = 0; i < na; ++i) x[i] = interpolateValue(a[i], b[i]);

-   for (; i < nb; ++i) c[i] = b[i];

- 

-   return function(t) {

-     for (i = 0; i < na; ++i) c[i] = x[i](t);

-     return c;

-   };

- };

- 

- var date = function(a, b) {

-   var d = new Date;

-   return a = +a, b -= a, function(t) {

-     return d.setTime(a + b * t), d;

-   };

- };

- 

- var reinterpolate = function(a, b) {

-   return a = +a, b -= a, function(t) {

-     return a + b * t;

-   };

- };

- 

- var object = function(a, b) {

-   var i = {},

-       c = {},

-       k;

- 

-   if (a === null || typeof a !== "object") a = {};

-   if (b === null || typeof b !== "object") b = {};

- 

-   for (k in b) {

-     if (k in a) {

-       i[k] = interpolateValue(a[k], b[k]);

-     } else {

-       c[k] = b[k];

-     }

-   }

- 

-   return function(t) {

-     for (k in i) c[k] = i[k](t);

-     return c;

-   };

- };

- 

- var reA = /[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g;

- var reB = new RegExp(reA.source, "g");

- 

- function zero(b) {

-   return function() {

-     return b;

-   };

- }

- 

- function one(b) {

-   return function(t) {

-     return b(t) + "";

-   };

- }

- 

- var interpolateString = function(a, b) {

-   var bi = reA.lastIndex = reB.lastIndex = 0, // scan index for next number in b

-       am, // current match in a

-       bm, // current match in b

-       bs, // string preceding current number in b, if any

-       i = -1, // index in s

-       s = [], // string constants and placeholders

-       q = []; // number interpolators

- 

-   // Coerce inputs to strings.

-   a = a + "", b = b + "";

- 

-   // Interpolate pairs of numbers in a & b.

-   while ((am = reA.exec(a))

-       && (bm = reB.exec(b))) {

-     if ((bs = bm.index) > bi) { // a string precedes the next number in b

-       bs = b.slice(bi, bs);

-       if (s[i]) s[i] += bs; // coalesce with previous string

-       else s[++i] = bs;

-     }

-     if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match

-       if (s[i]) s[i] += bm; // coalesce with previous string

-       else s[++i] = bm;

-     } else { // interpolate non-matching numbers

-       s[++i] = null;

-       q.push({i: i, x: reinterpolate(am, bm)});

-     }

-     bi = reB.lastIndex;

-   }

- 

-   // Add remains of b.

-   if (bi < b.length) {

-     bs = b.slice(bi);

-     if (s[i]) s[i] += bs; // coalesce with previous string

-     else s[++i] = bs;

-   }

- 

-   // Special optimization for only a single match.

-   // Otherwise, interpolate each of the numbers and rejoin the string.

-   return s.length < 2 ? (q[0]

-       ? one(q[0].x)

-       : zero(b))

-       : (b = q.length, function(t) {

-           for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);

-           return s.join("");

-         });

- };

- 

- var interpolateValue = function(a, b) {

-   var t = typeof b, c;

-   return b == null || t === "boolean" ? constant$3(b)

-       : (t === "number" ? reinterpolate

-       : t === "string" ? ((c = color(b)) ? (b = c, interpolateRgb) : interpolateString)

-       : b instanceof color ? interpolateRgb

-       : b instanceof Date ? date

-       : Array.isArray(b) ? array$1

-       : typeof b.valueOf !== "function" && typeof b.toString !== "function" || isNaN(b) ? object

-       : reinterpolate)(a, b);

- };

- 

- var interpolateRound = function(a, b) {

-   return a = +a, b -= a, function(t) {

-     return Math.round(a + b * t);

-   };

- };

- 

- var degrees = 180 / Math.PI;

- 

- var identity$2 = {

-   translateX: 0,

-   translateY: 0,

-   rotate: 0,

-   skewX: 0,

-   scaleX: 1,

-   scaleY: 1

- };

- 

- var decompose = function(a, b, c, d, e, f) {

-   var scaleX, scaleY, skewX;

-   if (scaleX = Math.sqrt(a * a + b * b)) a /= scaleX, b /= scaleX;

-   if (skewX = a * c + b * d) c -= a * skewX, d -= b * skewX;

-   if (scaleY = Math.sqrt(c * c + d * d)) c /= scaleY, d /= scaleY, skewX /= scaleY;

-   if (a * d < b * c) a = -a, b = -b, skewX = -skewX, scaleX = -scaleX;

-   return {

-     translateX: e,

-     translateY: f,

-     rotate: Math.atan2(b, a) * degrees,

-     skewX: Math.atan(skewX) * degrees,

-     scaleX: scaleX,

-     scaleY: scaleY

-   };

- };

- 

- var cssNode;

- var cssRoot;

- var cssView;

- var svgNode;

- 

- function parseCss(value) {

-   if (value === "none") return identity$2;

-   if (!cssNode) cssNode = document.createElement("DIV"), cssRoot = document.documentElement, cssView = document.defaultView;

-   cssNode.style.transform = value;

-   value = cssView.getComputedStyle(cssRoot.appendChild(cssNode), null).getPropertyValue("transform");

-   cssRoot.removeChild(cssNode);

-   value = value.slice(7, -1).split(",");

-   return decompose(+value[0], +value[1], +value[2], +value[3], +value[4], +value[5]);

- }

- 

- function parseSvg(value) {

-   if (value == null) return identity$2;

-   if (!svgNode) svgNode = document.createElementNS("http://www.w3.org/2000/svg", "g");

-   svgNode.setAttribute("transform", value);

-   if (!(value = svgNode.transform.baseVal.consolidate())) return identity$2;

-   value = value.matrix;

-   return decompose(value.a, value.b, value.c, value.d, value.e, value.f);

- }

- 

- function interpolateTransform(parse, pxComma, pxParen, degParen) {

- 

-   function pop(s) {

-     return s.length ? s.pop() + " " : "";

-   }

- 

-   function translate(xa, ya, xb, yb, s, q) {

-     if (xa !== xb || ya !== yb) {

-       var i = s.push("translate(", null, pxComma, null, pxParen);

-       q.push({i: i - 4, x: reinterpolate(xa, xb)}, {i: i - 2, x: reinterpolate(ya, yb)});

-     } else if (xb || yb) {

-       s.push("translate(" + xb + pxComma + yb + pxParen);

-     }

-   }

- 

-   function rotate(a, b, s, q) {

-     if (a !== b) {

-       if (a - b > 180) b += 360; else if (b - a > 180) a += 360; // shortest path

-       q.push({i: s.push(pop(s) + "rotate(", null, degParen) - 2, x: reinterpolate(a, b)});

-     } else if (b) {

-       s.push(pop(s) + "rotate(" + b + degParen);

-     }

-   }

- 

-   function skewX(a, b, s, q) {

-     if (a !== b) {

-       q.push({i: s.push(pop(s) + "skewX(", null, degParen) - 2, x: reinterpolate(a, b)});

-     } else if (b) {

-       s.push(pop(s) + "skewX(" + b + degParen);

-     }

-   }

- 

-   function scale(xa, ya, xb, yb, s, q) {

-     if (xa !== xb || ya !== yb) {

-       var i = s.push(pop(s) + "scale(", null, ",", null, ")");

-       q.push({i: i - 4, x: reinterpolate(xa, xb)}, {i: i - 2, x: reinterpolate(ya, yb)});

-     } else if (xb !== 1 || yb !== 1) {

-       s.push(pop(s) + "scale(" + xb + "," + yb + ")");

-     }

-   }

- 

-   return function(a, b) {

-     var s = [], // string constants and placeholders

-         q = []; // number interpolators

-     a = parse(a), b = parse(b);

-     translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q);

-     rotate(a.rotate, b.rotate, s, q);

-     skewX(a.skewX, b.skewX, s, q);

-     scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q);

-     a = b = null; // gc

-     return function(t) {

-       var i = -1, n = q.length, o;

-       while (++i < n) s[(o = q[i]).i] = o.x(t);

-       return s.join("");

-     };

-   };

- }

- 

- var interpolateTransformCss = interpolateTransform(parseCss, "px, ", "px)", "deg)");

- var interpolateTransformSvg = interpolateTransform(parseSvg, ", ", ")", ")");

- 

- var rho = Math.SQRT2;

- var rho2 = 2;

- var rho4 = 4;

- var epsilon2 = 1e-12;

- 

- function cosh(x) {

-   return ((x = Math.exp(x)) + 1 / x) / 2;

- }

- 

- function sinh(x) {

-   return ((x = Math.exp(x)) - 1 / x) / 2;

- }

- 

- function tanh(x) {

-   return ((x = Math.exp(2 * x)) - 1) / (x + 1);

- }

- 

- // p0 = [ux0, uy0, w0]

- // p1 = [ux1, uy1, w1]

- var interpolateZoom = function(p0, p1) {

-   var ux0 = p0[0], uy0 = p0[1], w0 = p0[2],

-       ux1 = p1[0], uy1 = p1[1], w1 = p1[2],

-       dx = ux1 - ux0,

-       dy = uy1 - uy0,

-       d2 = dx * dx + dy * dy,

-       i,

-       S;

- 

-   // Special case for u0 ≅ u1.

-   if (d2 < epsilon2) {

-     S = Math.log(w1 / w0) / rho;

-     i = function(t) {

-       return [

-         ux0 + t * dx,

-         uy0 + t * dy,

-         w0 * Math.exp(rho * t * S)

-       ];

-     };

-   }

- 

-   // General case.

-   else {

-     var d1 = Math.sqrt(d2),

-         b0 = (w1 * w1 - w0 * w0 + rho4 * d2) / (2 * w0 * rho2 * d1),

-         b1 = (w1 * w1 - w0 * w0 - rho4 * d2) / (2 * w1 * rho2 * d1),

-         r0 = Math.log(Math.sqrt(b0 * b0 + 1) - b0),

-         r1 = Math.log(Math.sqrt(b1 * b1 + 1) - b1);

-     S = (r1 - r0) / rho;

-     i = function(t) {

-       var s = t * S,

-           coshr0 = cosh(r0),

-           u = w0 / (rho2 * d1) * (coshr0 * tanh(rho * s + r0) - sinh(r0));

-       return [

-         ux0 + u * dx,

-         uy0 + u * dy,

-         w0 * coshr0 / cosh(rho * s + r0)

-       ];

-     };

-   }

- 

-   i.duration = S * 1000;

- 

-   return i;

- };

- 

- function hsl$1(hue$$1) {

-   return function(start, end) {

-     var h = hue$$1((start = hsl(start)).h, (end = hsl(end)).h),

-         s = nogamma(start.s, end.s),

-         l = nogamma(start.l, end.l),

-         opacity = nogamma(start.opacity, end.opacity);

-     return function(t) {

-       start.h = h(t);

-       start.s = s(t);

-       start.l = l(t);

-       start.opacity = opacity(t);

-       return start + "";

-     };

-   }

- }

- 

- var hsl$2 = hsl$1(hue);

- var hslLong = hsl$1(nogamma);

- 

- function lab$1(start, end) {

-   var l = nogamma((start = lab(start)).l, (end = lab(end)).l),

-       a = nogamma(start.a, end.a),

-       b = nogamma(start.b, end.b),

-       opacity = nogamma(start.opacity, end.opacity);

-   return function(t) {

-     start.l = l(t);

-     start.a = a(t);

-     start.b = b(t);

-     start.opacity = opacity(t);

-     return start + "";

-   };

- }

- 

- function hcl$1(hue$$1) {

-   return function(start, end) {

-     var h = hue$$1((start = hcl(start)).h, (end = hcl(end)).h),

-         c = nogamma(start.c, end.c),

-         l = nogamma(start.l, end.l),

-         opacity = nogamma(start.opacity, end.opacity);

-     return function(t) {

-       start.h = h(t);

-       start.c = c(t);

-       start.l = l(t);

-       start.opacity = opacity(t);

-       return start + "";

-     };

-   }

- }

- 

- var hcl$2 = hcl$1(hue);

- var hclLong = hcl$1(nogamma);

- 

- function cubehelix$1(hue$$1) {

-   return (function cubehelixGamma(y) {

-     y = +y;

- 

-     function cubehelix$$1(start, end) {

-       var h = hue$$1((start = cubehelix(start)).h, (end = cubehelix(end)).h),

-           s = nogamma(start.s, end.s),

-           l = nogamma(start.l, end.l),

-           opacity = nogamma(start.opacity, end.opacity);

-       return function(t) {

-         start.h = h(t);

-         start.s = s(t);

-         start.l = l(Math.pow(t, y));

-         start.opacity = opacity(t);

-         return start + "";

-       };

-     }

- 

-     cubehelix$$1.gamma = cubehelixGamma;

- 

-     return cubehelix$$1;

-   })(1);

- }

- 

- var cubehelix$2 = cubehelix$1(hue);

- var cubehelixLong = cubehelix$1(nogamma);

- 

- var quantize = function(interpolator, n) {

-   var samples = new Array(n);

-   for (var i = 0; i < n; ++i) samples[i] = interpolator(i / (n - 1));

-   return samples;

- };

- 

- var frame = 0;

- var timeout = 0;

- var interval = 0;

- var pokeDelay = 1000;

- var taskHead;

- var taskTail;

- var clockLast = 0;

- var clockNow = 0;

- var clockSkew = 0;

- var clock = typeof performance === "object" && performance.now ? performance : Date;

- var setFrame = typeof window === "object" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function(f) { setTimeout(f, 17); };

- 

- function now() {

-   return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);

- }

- 

- function clearNow() {

-   clockNow = 0;

- }

- 

- function Timer() {

-   this._call =

-   this._time =

-   this._next = null;

- }

- 

- Timer.prototype = timer.prototype = {

-   constructor: Timer,

-   restart: function(callback, delay, time) {

-     if (typeof callback !== "function") throw new TypeError("callback is not a function");

-     time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);

-     if (!this._next && taskTail !== this) {

-       if (taskTail) taskTail._next = this;

-       else taskHead = this;

-       taskTail = this;

-     }

-     this._call = callback;

-     this._time = time;

-     sleep();

-   },

-   stop: function() {

-     if (this._call) {

-       this._call = null;

-       this._time = Infinity;

-       sleep();

-     }

-   }

- };

- 

- function timer(callback, delay, time) {

-   var t = new Timer;

-   t.restart(callback, delay, time);

-   return t;

- }

- 

- function timerFlush() {

-   now(); // Get the current time, if not already set.

-   ++frame; // Pretend we’ve set an alarm, if we haven’t already.

-   var t = taskHead, e;

-   while (t) {

-     if ((e = clockNow - t._time) >= 0) t._call.call(null, e);

-     t = t._next;

-   }

-   --frame;

- }

- 

- function wake() {

-   clockNow = (clockLast = clock.now()) + clockSkew;

-   frame = timeout = 0;

-   try {

-     timerFlush();

-   } finally {

-     frame = 0;

-     nap();

-     clockNow = 0;

-   }

- }

- 

- function poke() {

-   var now = clock.now(), delay = now - clockLast;

-   if (delay > pokeDelay) clockSkew -= delay, clockLast = now;

- }

- 

- function nap() {

-   var t0, t1 = taskHead, t2, time = Infinity;

-   while (t1) {

-     if (t1._call) {

-       if (time > t1._time) time = t1._time;

-       t0 = t1, t1 = t1._next;

-     } else {

-       t2 = t1._next, t1._next = null;

-       t1 = t0 ? t0._next = t2 : taskHead = t2;

-     }

-   }

-   taskTail = t0;

-   sleep(time);

- }

- 

- function sleep(time) {

-   if (frame) return; // Soonest alarm already set, or will be.

-   if (timeout) timeout = clearTimeout(timeout);

-   var delay = time - clockNow; // Strictly less than if we recomputed clockNow.

-   if (delay > 24) {

-     if (time < Infinity) timeout = setTimeout(wake, time - clock.now() - clockSkew);

-     if (interval) interval = clearInterval(interval);

-   } else {

-     if (!interval) clockLast = clock.now(), interval = setInterval(poke, pokeDelay);

-     frame = 1, setFrame(wake);

-   }

- }

- 

- var timeout$1 = function(callback, delay, time) {

-   var t = new Timer;

-   delay = delay == null ? 0 : +delay;

-   t.restart(function(elapsed) {

-     t.stop();

-     callback(elapsed + delay);

-   }, delay, time);

-   return t;

- };

- 

- var interval$1 = function(callback, delay, time) {

-   var t = new Timer, total = delay;

-   if (delay == null) return t.restart(callback, delay, time), t;

-   delay = +delay, time = time == null ? now() : +time;

-   t.restart(function tick(elapsed) {

-     elapsed += total;

-     t.restart(tick, total += delay, time);

-     callback(elapsed);

-   }, delay, time);

-   return t;

- };

- 

- var emptyOn = dispatch("start", "end", "interrupt");

- var emptyTween = [];

- 

- var CREATED = 0;

- var SCHEDULED = 1;

- var STARTING = 2;

- var STARTED = 3;

- var RUNNING = 4;

- var ENDING = 5;

- var ENDED = 6;

- 

- var schedule = function(node, name, id, index, group, timing) {

-   var schedules = node.__transition;

-   if (!schedules) node.__transition = {};

-   else if (id in schedules) return;

-   create(node, id, {

-     name: name,

-     index: index, // For context during callback.

-     group: group, // For context during callback.

-     on: emptyOn,

-     tween: emptyTween,

-     time: timing.time,

-     delay: timing.delay,

-     duration: timing.duration,

-     ease: timing.ease,

-     timer: null,

-     state: CREATED

-   });

- };

- 

- function init(node, id) {

-   var schedule = node.__transition;

-   if (!schedule || !(schedule = schedule[id]) || schedule.state > CREATED) throw new Error("too late");

-   return schedule;

- }

- 

- function set$1(node, id) {

-   var schedule = node.__transition;

-   if (!schedule || !(schedule = schedule[id]) || schedule.state > STARTING) throw new Error("too late");

-   return schedule;

- }

- 

- function get$1(node, id) {

-   var schedule = node.__transition;

-   if (!schedule || !(schedule = schedule[id])) throw new Error("too late");

-   return schedule;

- }

- 

- function create(node, id, self) {

-   var schedules = node.__transition,

-       tween;

- 

-   // Initialize the self timer when the transition is created.

-   // Note the actual delay is not known until the first callback!

-   schedules[id] = self;

-   self.timer = timer(schedule, 0, self.time);

- 

-   function schedule(elapsed) {

-     self.state = SCHEDULED;

-     self.timer.restart(start, self.delay, self.time);

- 

-     // If the elapsed delay is less than our first sleep, start immediately.

-     if (self.delay <= elapsed) start(elapsed - self.delay);

-   }

- 

-   function start(elapsed) {

-     var i, j, n, o;

- 

-     // If the state is not SCHEDULED, then we previously errored on start.

-     if (self.state !== SCHEDULED) return stop();

- 

-     for (i in schedules) {

-       o = schedules[i];

-       if (o.name !== self.name) continue;

- 

-       // While this element already has a starting transition during this frame,

-       // defer starting an interrupting transition until that transition has a

-       // chance to tick (and possibly end); see d3/d3-transition#54!

-       if (o.state === STARTED) return timeout$1(start);

- 

-       // Interrupt the active transition, if any.

-       // Dispatch the interrupt event.

-       if (o.state === RUNNING) {

-         o.state = ENDED;

-         o.timer.stop();

-         o.on.call("interrupt", node, node.__data__, o.index, o.group);

-         delete schedules[i];

-       }

- 

-       // Cancel any pre-empted transitions. No interrupt event is dispatched

-       // because the cancelled transitions never started. Note that this also

-       // removes this transition from the pending list!

-       else if (+i < id) {

-         o.state = ENDED;

-         o.timer.stop();

-         delete schedules[i];

-       }

-     }

- 

-     // Defer the first tick to end of the current frame; see d3/d3#1576.

-     // Note the transition may be canceled after start and before the first tick!

-     // Note this must be scheduled before the start event; see d3/d3-transition#16!

-     // Assuming this is successful, subsequent callbacks go straight to tick.

-     timeout$1(function() {

-       if (self.state === STARTED) {

-         self.state = RUNNING;

-         self.timer.restart(tick, self.delay, self.time);

-         tick(elapsed);

-       }

-     });

- 

-     // Dispatch the start event.

-     // Note this must be done before the tween are initialized.

-     self.state = STARTING;

-     self.on.call("start", node, node.__data__, self.index, self.group);

-     if (self.state !== STARTING) return; // interrupted

-     self.state = STARTED;

- 

-     // Initialize the tween, deleting null tween.

-     tween = new Array(n = self.tween.length);

-     for (i = 0, j = -1; i < n; ++i) {

-       if (o = self.tween[i].value.call(node, node.__data__, self.index, self.group)) {

-         tween[++j] = o;

-       }

-     }

-     tween.length = j + 1;

-   }

- 

-   function tick(elapsed) {

-     var t = elapsed < self.duration ? self.ease.call(null, elapsed / self.duration) : (self.timer.restart(stop), self.state = ENDING, 1),

-         i = -1,

-         n = tween.length;

- 

-     while (++i < n) {

-       tween[i].call(null, t);

-     }

- 

-     // Dispatch the end event.

-     if (self.state === ENDING) {

-       self.on.call("end", node, node.__data__, self.index, self.group);

-       stop();

-     }

-   }

- 

-   function stop() {

-     self.state = ENDED;

-     self.timer.stop();

-     delete schedules[id];

-     for (var i in schedules) return; // eslint-disable-line no-unused-vars

-     delete node.__transition;

-   }

- }

- 

- var interrupt = function(node, name) {

-   var schedules = node.__transition,

-       schedule$$1,

-       active,

-       empty = true,

-       i;

- 

-   if (!schedules) return;

- 

-   name = name == null ? null : name + "";

- 

-   for (i in schedules) {

-     if ((schedule$$1 = schedules[i]).name !== name) { empty = false; continue; }

-     active = schedule$$1.state > STARTING && schedule$$1.state < ENDING;

-     schedule$$1.state = ENDED;

-     schedule$$1.timer.stop();

-     if (active) schedule$$1.on.call("interrupt", node, node.__data__, schedule$$1.index, schedule$$1.group);

-     delete schedules[i];

-   }

- 

-   if (empty) delete node.__transition;

- };

- 

- var selection_interrupt = function(name) {

-   return this.each(function() {

-     interrupt(this, name);

-   });

- };

- 

- function tweenRemove(id, name) {

-   var tween0, tween1;

-   return function() {

-     var schedule$$1 = set$1(this, id),

-         tween = schedule$$1.tween;

- 

-     // If this node shared tween with the previous node,

-     // just assign the updated shared tween and we’re done!

-     // Otherwise, copy-on-write.

-     if (tween !== tween0) {

-       tween1 = tween0 = tween;

-       for (var i = 0, n = tween1.length; i < n; ++i) {

-         if (tween1[i].name === name) {

-           tween1 = tween1.slice();

-           tween1.splice(i, 1);

-           break;

-         }

-       }

-     }

- 

-     schedule$$1.tween = tween1;

-   };

- }

- 

- function tweenFunction(id, name, value) {

-   var tween0, tween1;

-   if (typeof value !== "function") throw new Error;

-   return function() {

-     var schedule$$1 = set$1(this, id),

-         tween = schedule$$1.tween;

- 

-     // If this node shared tween with the previous node,

-     // just assign the updated shared tween and we’re done!

-     // Otherwise, copy-on-write.

-     if (tween !== tween0) {

-       tween1 = (tween0 = tween).slice();

-       for (var t = {name: name, value: value}, i = 0, n = tween1.length; i < n; ++i) {

-         if (tween1[i].name === name) {

-           tween1[i] = t;

-           break;

-         }

-       }

-       if (i === n) tween1.push(t);

-     }

- 

-     schedule$$1.tween = tween1;

-   };

- }

- 

- var transition_tween = function(name, value) {

-   var id = this._id;

- 

-   name += "";

- 

-   if (arguments.length < 2) {

-     var tween = get$1(this.node(), id).tween;

-     for (var i = 0, n = tween.length, t; i < n; ++i) {

-       if ((t = tween[i]).name === name) {

-         return t.value;

-       }

-     }

-     return null;

-   }

- 

-   return this.each((value == null ? tweenRemove : tweenFunction)(id, name, value));

- };

- 

- function tweenValue(transition, name, value) {

-   var id = transition._id;

- 

-   transition.each(function() {

-     var schedule$$1 = set$1(this, id);

-     (schedule$$1.value || (schedule$$1.value = {}))[name] = value.apply(this, arguments);

-   });

- 

-   return function(node) {

-     return get$1(node, id).value[name];

-   };

- }

- 

- var interpolate = function(a, b) {

-   var c;

-   return (typeof b === "number" ? reinterpolate

-       : b instanceof color ? interpolateRgb

-       : (c = color(b)) ? (b = c, interpolateRgb)

-       : interpolateString)(a, b);

- };

- 

- function attrRemove$1(name) {

-   return function() {

-     this.removeAttribute(name);

-   };

- }

- 

- function attrRemoveNS$1(fullname) {

-   return function() {

-     this.removeAttributeNS(fullname.space, fullname.local);

-   };

- }

- 

- function attrConstant$1(name, interpolate$$1, value1) {

-   var value00,

-       interpolate0;

-   return function() {

-     var value0 = this.getAttribute(name);

-     return value0 === value1 ? null

-         : value0 === value00 ? interpolate0

-         : interpolate0 = interpolate$$1(value00 = value0, value1);

-   };

- }

- 

- function attrConstantNS$1(fullname, interpolate$$1, value1) {

-   var value00,

-       interpolate0;

-   return function() {

-     var value0 = this.getAttributeNS(fullname.space, fullname.local);

-     return value0 === value1 ? null

-         : value0 === value00 ? interpolate0

-         : interpolate0 = interpolate$$1(value00 = value0, value1);

-   };

- }

- 

- function attrFunction$1(name, interpolate$$1, value) {

-   var value00,

-       value10,

-       interpolate0;

-   return function() {

-     var value0, value1 = value(this);

-     if (value1 == null) return void this.removeAttribute(name);

-     value0 = this.getAttribute(name);

-     return value0 === value1 ? null

-         : value0 === value00 && value1 === value10 ? interpolate0

-         : interpolate0 = interpolate$$1(value00 = value0, value10 = value1);

-   };

- }

- 

- function attrFunctionNS$1(fullname, interpolate$$1, value) {

-   var value00,

-       value10,

-       interpolate0;

-   return function() {

-     var value0, value1 = value(this);

-     if (value1 == null) return void this.removeAttributeNS(fullname.space, fullname.local);

-     value0 = this.getAttributeNS(fullname.space, fullname.local);

-     return value0 === value1 ? null

-         : value0 === value00 && value1 === value10 ? interpolate0

-         : interpolate0 = interpolate$$1(value00 = value0, value10 = value1);

-   };

- }

- 

- var transition_attr = function(name, value) {

-   var fullname = namespace(name), i = fullname === "transform" ? interpolateTransformSvg : interpolate;

-   return this.attrTween(name, typeof value === "function"

-       ? (fullname.local ? attrFunctionNS$1 : attrFunction$1)(fullname, i, tweenValue(this, "attr." + name, value))

-       : value == null ? (fullname.local ? attrRemoveNS$1 : attrRemove$1)(fullname)

-       : (fullname.local ? attrConstantNS$1 : attrConstant$1)(fullname, i, value + ""));

- };

- 

- function attrTweenNS(fullname, value) {

-   function tween() {

-     var node = this, i = value.apply(node, arguments);

-     return i && function(t) {

-       node.setAttributeNS(fullname.space, fullname.local, i(t));

-     };

-   }

-   tween._value = value;

-   return tween;

- }

- 

- function attrTween(name, value) {

-   function tween() {

-     var node = this, i = value.apply(node, arguments);

-     return i && function(t) {

-       node.setAttribute(name, i(t));

-     };

-   }

-   tween._value = value;

-   return tween;

- }

- 

- var transition_attrTween = function(name, value) {

-   var key = "attr." + name;

-   if (arguments.length < 2) return (key = this.tween(key)) && key._value;

-   if (value == null) return this.tween(key, null);

-   if (typeof value !== "function") throw new Error;

-   var fullname = namespace(name);

-   return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value));

- };

- 

- function delayFunction(id, value) {

-   return function() {

-     init(this, id).delay = +value.apply(this, arguments);

-   };

- }

- 

- function delayConstant(id, value) {

-   return value = +value, function() {

-     init(this, id).delay = value;

-   };

- }

- 

- var transition_delay = function(value) {

-   var id = this._id;

- 

-   return arguments.length

-       ? this.each((typeof value === "function"

-           ? delayFunction

-           : delayConstant)(id, value))

-       : get$1(this.node(), id).delay;

- };

- 

- function durationFunction(id, value) {

-   return function() {

-     set$1(this, id).duration = +value.apply(this, arguments);

-   };

- }

- 

- function durationConstant(id, value) {

-   return value = +value, function() {

-     set$1(this, id).duration = value;

-   };

- }

- 

- var transition_duration = function(value) {

-   var id = this._id;

- 

-   return arguments.length

-       ? this.each((typeof value === "function"

-           ? durationFunction

-           : durationConstant)(id, value))

-       : get$1(this.node(), id).duration;

- };

- 

- function easeConstant(id, value) {

-   if (typeof value !== "function") throw new Error;

-   return function() {

-     set$1(this, id).ease = value;

-   };

- }

- 

- var transition_ease = function(value) {

-   var id = this._id;

- 

-   return arguments.length

-       ? this.each(easeConstant(id, value))

-       : get$1(this.node(), id).ease;

- };

- 

- var transition_filter = function(match) {

-   if (typeof match !== "function") match = matcher$1(match);

- 

-   for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {

-     for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {

-       if ((node = group[i]) && match.call(node, node.__data__, i, group)) {

-         subgroup.push(node);

-       }

-     }

-   }

- 

-   return new Transition(subgroups, this._parents, this._name, this._id);

- };

- 

- var transition_merge = function(transition$$1) {

-   if (transition$$1._id !== this._id) throw new Error;

- 

-   for (var groups0 = this._groups, groups1 = transition$$1._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {

-     for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {

-       if (node = group0[i] || group1[i]) {

-         merge[i] = node;

-       }

-     }

-   }

- 

-   for (; j < m0; ++j) {

-     merges[j] = groups0[j];

-   }

- 

-   return new Transition(merges, this._parents, this._name, this._id);

- };

- 

- function start(name) {

-   return (name + "").trim().split(/^|\s+/).every(function(t) {

-     var i = t.indexOf(".");

-     if (i >= 0) t = t.slice(0, i);

-     return !t || t === "start";

-   });

- }

- 

- function onFunction(id, name, listener) {

-   var on0, on1, sit = start(name) ? init : set$1;

-   return function() {

-     var schedule$$1 = sit(this, id),

-         on = schedule$$1.on;

- 

-     // If this node shared a dispatch with the previous node,

-     // just assign the updated shared dispatch and we’re done!

-     // Otherwise, copy-on-write.

-     if (on !== on0) (on1 = (on0 = on).copy()).on(name, listener);

- 

-     schedule$$1.on = on1;

-   };

- }

- 

- var transition_on = function(name, listener) {

-   var id = this._id;

- 

-   return arguments.length < 2

-       ? get$1(this.node(), id).on.on(name)

-       : this.each(onFunction(id, name, listener));

- };

- 

- function removeFunction(id) {

-   return function() {

-     var parent = this.parentNode;

-     for (var i in this.__transition) if (+i !== id) return;

-     if (parent) parent.removeChild(this);

-   };

- }

- 

- var transition_remove = function() {

-   return this.on("end.remove", removeFunction(this._id));

- };

- 

- var transition_select = function(select) {

-   var name = this._name,

-       id = this._id;

- 

-   if (typeof select !== "function") select = selector(select);

- 

-   for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {

-     for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {

-       if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {

-         if ("__data__" in node) subnode.__data__ = node.__data__;

-         subgroup[i] = subnode;

-         schedule(subgroup[i], name, id, i, subgroup, get$1(node, id));

-       }

-     }

-   }

- 

-   return new Transition(subgroups, this._parents, name, id);

- };

- 

- var transition_selectAll = function(select) {

-   var name = this._name,

-       id = this._id;

- 

-   if (typeof select !== "function") select = selectorAll(select);

- 

-   for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {

-     for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {

-       if (node = group[i]) {

-         for (var children = select.call(node, node.__data__, i, group), child, inherit = get$1(node, id), k = 0, l = children.length; k < l; ++k) {

-           if (child = children[k]) {

-             schedule(child, name, id, k, children, inherit);

-           }

-         }

-         subgroups.push(children);

-         parents.push(node);

-       }

-     }

-   }

- 

-   return new Transition(subgroups, parents, name, id);

- };

- 

- var Selection$1 = selection.prototype.constructor;

- 

- var transition_selection = function() {

-   return new Selection$1(this._groups, this._parents);

- };

- 

- function styleRemove$1(name, interpolate$$1) {

-   var value00,

-       value10,

-       interpolate0;

-   return function() {

-     var value0 = styleValue(this, name),

-         value1 = (this.style.removeProperty(name), styleValue(this, name));

-     return value0 === value1 ? null

-         : value0 === value00 && value1 === value10 ? interpolate0

-         : interpolate0 = interpolate$$1(value00 = value0, value10 = value1);

-   };

- }

- 

- function styleRemoveEnd(name) {

-   return function() {

-     this.style.removeProperty(name);

-   };

- }

- 

- function styleConstant$1(name, interpolate$$1, value1) {

-   var value00,

-       interpolate0;

-   return function() {

-     var value0 = styleValue(this, name);

-     return value0 === value1 ? null

-         : value0 === value00 ? interpolate0

-         : interpolate0 = interpolate$$1(value00 = value0, value1);

-   };

- }

- 

- function styleFunction$1(name, interpolate$$1, value) {

-   var value00,

-       value10,

-       interpolate0;

-   return function() {

-     var value0 = styleValue(this, name),

-         value1 = value(this);

-     if (value1 == null) value1 = (this.style.removeProperty(name), styleValue(this, name));

-     return value0 === value1 ? null

-         : value0 === value00 && value1 === value10 ? interpolate0

-         : interpolate0 = interpolate$$1(value00 = value0, value10 = value1);

-   };

- }

- 

- var transition_style = function(name, value, priority) {

-   var i = (name += "") === "transform" ? interpolateTransformCss : interpolate;

-   return value == null ? this

-           .styleTween(name, styleRemove$1(name, i))

-           .on("end.style." + name, styleRemoveEnd(name))

-       : this.styleTween(name, typeof value === "function"

-           ? styleFunction$1(name, i, tweenValue(this, "style." + name, value))

-           : styleConstant$1(name, i, value + ""), priority);

- };

- 

- function styleTween(name, value, priority) {

-   function tween() {

-     var node = this, i = value.apply(node, arguments);

-     return i && function(t) {

-       node.style.setProperty(name, i(t), priority);

-     };

-   }

-   tween._value = value;

-   return tween;

- }

- 

- var transition_styleTween = function(name, value, priority) {

-   var key = "style." + (name += "");

-   if (arguments.length < 2) return (key = this.tween(key)) && key._value;

-   if (value == null) return this.tween(key, null);

-   if (typeof value !== "function") throw new Error;

-   return this.tween(key, styleTween(name, value, priority == null ? "" : priority));

- };

- 

- function textConstant$1(value) {

-   return function() {

-     this.textContent = value;

-   };

- }

- 

- function textFunction$1(value) {

-   return function() {

-     var value1 = value(this);

-     this.textContent = value1 == null ? "" : value1;

-   };

- }

- 

- var transition_text = function(value) {

-   return this.tween("text", typeof value === "function"

-       ? textFunction$1(tweenValue(this, "text", value))

-       : textConstant$1(value == null ? "" : value + ""));

- };

- 

- var transition_transition = function() {

-   var name = this._name,

-       id0 = this._id,

-       id1 = newId();

- 

-   for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {

-     for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {

-       if (node = group[i]) {

-         var inherit = get$1(node, id0);

-         schedule(node, name, id1, i, group, {

-           time: inherit.time + inherit.delay + inherit.duration,

-           delay: 0,

-           duration: inherit.duration,

-           ease: inherit.ease

-         });

-       }

-     }

-   }

- 

-   return new Transition(groups, this._parents, name, id1);

- };

- 

- var id = 0;

- 

- function Transition(groups, parents, name, id) {

-   this._groups = groups;

-   this._parents = parents;

-   this._name = name;

-   this._id = id;

- }

- 

- function transition(name) {

-   return selection().transition(name);

- }

- 

- function newId() {

-   return ++id;

- }

- 

- var selection_prototype = selection.prototype;

- 

- Transition.prototype = transition.prototype = {

-   constructor: Transition,

-   select: transition_select,

-   selectAll: transition_selectAll,

-   filter: transition_filter,

-   merge: transition_merge,

-   selection: transition_selection,

-   transition: transition_transition,

-   call: selection_prototype.call,

-   nodes: selection_prototype.nodes,

-   node: selection_prototype.node,

-   size: selection_prototype.size,

-   empty: selection_prototype.empty,

-   each: selection_prototype.each,

-   on: transition_on,

-   attr: transition_attr,

-   attrTween: transition_attrTween,

-   style: transition_style,

-   styleTween: transition_styleTween,

-   text: transition_text,

-   remove: transition_remove,

-   tween: transition_tween,

-   delay: transition_delay,

-   duration: transition_duration,

-   ease: transition_ease

- };

- 

- function linear$1(t) {

-   return +t;

- }

- 

- function quadIn(t) {

-   return t * t;

- }

- 

- function quadOut(t) {

-   return t * (2 - t);

- }

- 

- function quadInOut(t) {

-   return ((t *= 2) <= 1 ? t * t : --t * (2 - t) + 1) / 2;

- }

- 

- function cubicIn(t) {

-   return t * t * t;

- }

- 

- function cubicOut(t) {

-   return --t * t * t + 1;

- }

- 

- function cubicInOut(t) {

-   return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;

- }

- 

- var exponent = 3;

- 

- var polyIn = (function custom(e) {

-   e = +e;

- 

-   function polyIn(t) {

-     return Math.pow(t, e);

-   }

- 

-   polyIn.exponent = custom;

- 

-   return polyIn;

- })(exponent);

- 

- var polyOut = (function custom(e) {

-   e = +e;

- 

-   function polyOut(t) {

-     return 1 - Math.pow(1 - t, e);

-   }

- 

-   polyOut.exponent = custom;

- 

-   return polyOut;

- })(exponent);

- 

- var polyInOut = (function custom(e) {

-   e = +e;

- 

-   function polyInOut(t) {

-     return ((t *= 2) <= 1 ? Math.pow(t, e) : 2 - Math.pow(2 - t, e)) / 2;

-   }

- 

-   polyInOut.exponent = custom;

- 

-   return polyInOut;

- })(exponent);

- 

- var pi = Math.PI;

- var halfPi = pi / 2;

- 

- function sinIn(t) {

-   return 1 - Math.cos(t * halfPi);

- }

- 

- function sinOut(t) {

-   return Math.sin(t * halfPi);

- }

- 

- function sinInOut(t) {

-   return (1 - Math.cos(pi * t)) / 2;

- }

- 

- function expIn(t) {

-   return Math.pow(2, 10 * t - 10);

- }

- 

- function expOut(t) {

-   return 1 - Math.pow(2, -10 * t);

- }

- 

- function expInOut(t) {

-   return ((t *= 2) <= 1 ? Math.pow(2, 10 * t - 10) : 2 - Math.pow(2, 10 - 10 * t)) / 2;

- }

- 

- function circleIn(t) {

-   return 1 - Math.sqrt(1 - t * t);

- }

- 

- function circleOut(t) {

-   return Math.sqrt(1 - --t * t);

- }

- 

- function circleInOut(t) {

-   return ((t *= 2) <= 1 ? 1 - Math.sqrt(1 - t * t) : Math.sqrt(1 - (t -= 2) * t) + 1) / 2;

- }

- 

- var b1 = 4 / 11;

- var b2 = 6 / 11;

- var b3 = 8 / 11;

- var b4 = 3 / 4;

- var b5 = 9 / 11;

- var b6 = 10 / 11;

- var b7 = 15 / 16;

- var b8 = 21 / 22;

- var b9 = 63 / 64;

- var b0 = 1 / b1 / b1;

- 

- function bounceIn(t) {

-   return 1 - bounceOut(1 - t);

- }

- 

- function bounceOut(t) {

-   return (t = +t) < b1 ? b0 * t * t : t < b3 ? b0 * (t -= b2) * t + b4 : t < b6 ? b0 * (t -= b5) * t + b7 : b0 * (t -= b8) * t + b9;

- }

- 

- function bounceInOut(t) {

-   return ((t *= 2) <= 1 ? 1 - bounceOut(1 - t) : bounceOut(t - 1) + 1) / 2;

- }

- 

- var overshoot = 1.70158;

- 

- var backIn = (function custom(s) {

-   s = +s;

- 

-   function backIn(t) {

-     return t * t * ((s + 1) * t - s);

-   }

- 

-   backIn.overshoot = custom;

- 

-   return backIn;

- })(overshoot);

- 

- var backOut = (function custom(s) {

-   s = +s;

- 

-   function backOut(t) {

-     return --t * t * ((s + 1) * t + s) + 1;

-   }

- 

-   backOut.overshoot = custom;

- 

-   return backOut;

- })(overshoot);

- 

- var backInOut = (function custom(s) {

-   s = +s;

- 

-   function backInOut(t) {

-     return ((t *= 2) < 1 ? t * t * ((s + 1) * t - s) : (t -= 2) * t * ((s + 1) * t + s) + 2) / 2;

-   }

- 

-   backInOut.overshoot = custom;

- 

-   return backInOut;

- })(overshoot);

- 

- var tau = 2 * Math.PI;

- var amplitude = 1;

- var period = 0.3;

- 

- var elasticIn = (function custom(a, p) {

-   var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);

- 

-   function elasticIn(t) {

-     return a * Math.pow(2, 10 * --t) * Math.sin((s - t) / p);

-   }

- 

-   elasticIn.amplitude = function(a) { return custom(a, p * tau); };

-   elasticIn.period = function(p) { return custom(a, p); };

- 

-   return elasticIn;

- })(amplitude, period);

- 

- var elasticOut = (function custom(a, p) {

-   var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);

- 

-   function elasticOut(t) {

-     return 1 - a * Math.pow(2, -10 * (t = +t)) * Math.sin((t + s) / p);

-   }

- 

-   elasticOut.amplitude = function(a) { return custom(a, p * tau); };

-   elasticOut.period = function(p) { return custom(a, p); };

- 

-   return elasticOut;

- })(amplitude, period);

- 

- var elasticInOut = (function custom(a, p) {

-   var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);

- 

-   function elasticInOut(t) {

-     return ((t = t * 2 - 1) < 0

-         ? a * Math.pow(2, 10 * t) * Math.sin((s - t) / p)

-         : 2 - a * Math.pow(2, -10 * t) * Math.sin((s + t) / p)) / 2;

-   }

- 

-   elasticInOut.amplitude = function(a) { return custom(a, p * tau); };

-   elasticInOut.period = function(p) { return custom(a, p); };

- 

-   return elasticInOut;

- })(amplitude, period);

- 

- var defaultTiming = {

-   time: null, // Set on use.

-   delay: 0,

-   duration: 250,

-   ease: cubicInOut

- };

- 

- function inherit(node, id) {

-   var timing;

-   while (!(timing = node.__transition) || !(timing = timing[id])) {

-     if (!(node = node.parentNode)) {

-       return defaultTiming.time = now(), defaultTiming;

-     }

-   }

-   return timing;

- }

- 

- var selection_transition = function(name) {

-   var id,

-       timing;

- 

-   if (name instanceof Transition) {

-     id = name._id, name = name._name;

-   } else {

-     id = newId(), (timing = defaultTiming).time = now(), name = name == null ? null : name + "";

-   }

- 

-   for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {

-     for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {

-       if (node = group[i]) {

-         schedule(node, name, id, i, group, timing || inherit(node, id));

-       }

-     }

-   }

- 

-   return new Transition(groups, this._parents, name, id);

- };

- 

- selection.prototype.interrupt = selection_interrupt;

- selection.prototype.transition = selection_transition;

- 

- var root$1 = [null];

- 

- var active = function(node, name) {

-   var schedules = node.__transition,

-       schedule$$1,

-       i;

- 

-   if (schedules) {

-     name = name == null ? null : name + "";

-     for (i in schedules) {

-       if ((schedule$$1 = schedules[i]).state > SCHEDULED && schedule$$1.name === name) {

-         return new Transition([[node]], root$1, name, +i);

-       }

-     }

-   }

- 

-   return null;

- };

- 

- var constant$4 = function(x) {

-   return function() {

-     return x;

-   };

- };

- 

- var BrushEvent = function(target, type, selection) {

-   this.target = target;

-   this.type = type;

-   this.selection = selection;

- };

- 

- function nopropagation$1() {

-   exports.event.stopImmediatePropagation();

- }

- 

- var noevent$1 = function() {

-   exports.event.preventDefault();

-   exports.event.stopImmediatePropagation();

- };

- 

- var MODE_DRAG = {name: "drag"};

- var MODE_SPACE = {name: "space"};

- var MODE_HANDLE = {name: "handle"};

- var MODE_CENTER = {name: "center"};

- 

- var X = {

-   name: "x",

-   handles: ["e", "w"].map(type),

-   input: function(x, e) { return x && [[x[0], e[0][1]], [x[1], e[1][1]]]; },

-   output: function(xy) { return xy && [xy[0][0], xy[1][0]]; }

- };

- 

- var Y = {

-   name: "y",

-   handles: ["n", "s"].map(type),

-   input: function(y, e) { return y && [[e[0][0], y[0]], [e[1][0], y[1]]]; },

-   output: function(xy) { return xy && [xy[0][1], xy[1][1]]; }

- };

- 

- var XY = {

-   name: "xy",

-   handles: ["n", "e", "s", "w", "nw", "ne", "se", "sw"].map(type),

-   input: function(xy) { return xy; },

-   output: function(xy) { return xy; }

- };

- 

- var cursors = {

-   overlay: "crosshair",

-   selection: "move",

-   n: "ns-resize",

-   e: "ew-resize",

-   s: "ns-resize",

-   w: "ew-resize",

-   nw: "nwse-resize",

-   ne: "nesw-resize",

-   se: "nwse-resize",

-   sw: "nesw-resize"

- };

- 

- var flipX = {

-   e: "w",

-   w: "e",

-   nw: "ne",

-   ne: "nw",

-   se: "sw",

-   sw: "se"

- };

- 

- var flipY = {

-   n: "s",

-   s: "n",

-   nw: "sw",

-   ne: "se",

-   se: "ne",

-   sw: "nw"

- };

- 

- var signsX = {

-   overlay: +1,

-   selection: +1,

-   n: null,

-   e: +1,

-   s: null,

-   w: -1,

-   nw: -1,

-   ne: +1,

-   se: +1,

-   sw: -1

- };

- 

- var signsY = {

-   overlay: +1,

-   selection: +1,

-   n: -1,

-   e: null,

-   s: +1,

-   w: null,

-   nw: -1,

-   ne: -1,

-   se: +1,

-   sw: +1

- };

- 

- function type(t) {

-   return {type: t};

- }

- 

- // Ignore right-click, since that should open the context menu.

- function defaultFilter() {

-   return !exports.event.button;

- }

- 

- function defaultExtent() {

-   var svg = this.ownerSVGElement || this;

-   return [[0, 0], [svg.width.baseVal.value, svg.height.baseVal.value]];

- }

- 

- // Like d3.local, but with the name “__brush” rather than auto-generated.

- function local(node) {

-   while (!node.__brush) if (!(node = node.parentNode)) return;

-   return node.__brush;

- }

- 

- function empty(extent) {

-   return extent[0][0] === extent[1][0]

-       || extent[0][1] === extent[1][1];

- }

- 

- function brushSelection(node) {

-   var state = node.__brush;

-   return state ? state.dim.output(state.selection) : null;

- }

- 

- function brushX() {

-   return brush$1(X);

- }

- 

- function brushY() {

-   return brush$1(Y);

- }

- 

- var brush = function() {

-   return brush$1(XY);

- };

- 

- function brush$1(dim) {

-   var extent = defaultExtent,

-       filter = defaultFilter,

-       listeners = dispatch(brush, "start", "brush", "end"),

-       handleSize = 6,

-       touchending;

- 

-   function brush(group) {

-     var overlay = group

-         .property("__brush", initialize)

-       .selectAll(".overlay")

-       .data([type("overlay")]);

- 

-     overlay.enter().append("rect")

-         .attr("class", "overlay")

-         .attr("pointer-events", "all")

-         .attr("cursor", cursors.overlay)

-       .merge(overlay)

-         .each(function() {

-           var extent = local(this).extent;

-           select(this)

-               .attr("x", extent[0][0])

-               .attr("y", extent[0][1])

-               .attr("width", extent[1][0] - extent[0][0])

-               .attr("height", extent[1][1] - extent[0][1]);

-         });

- 

-     group.selectAll(".selection")

-       .data([type("selection")])

-       .enter().append("rect")

-         .attr("class", "selection")

-         .attr("cursor", cursors.selection)

-         .attr("fill", "#777")

-         .attr("fill-opacity", 0.3)

-         .attr("stroke", "#fff")

-         .attr("shape-rendering", "crispEdges");

- 

-     var handle = group.selectAll(".handle")

-       .data(dim.handles, function(d) { return d.type; });

- 

-     handle.exit().remove();

- 

-     handle.enter().append("rect")

-         .attr("class", function(d) { return "handle handle--" + d.type; })

-         .attr("cursor", function(d) { return cursors[d.type]; });

- 

-     group

-         .each(redraw)

-         .attr("fill", "none")

-         .attr("pointer-events", "all")

-         .style("-webkit-tap-highlight-color", "rgba(0,0,0,0)")

-         .on("mousedown.brush touchstart.brush", started);

-   }

- 

-   brush.move = function(group, selection) {

-     if (group.selection) {

-       group

-           .on("start.brush", function() { emitter(this, arguments).beforestart().start(); })

-           .on("interrupt.brush end.brush", function() { emitter(this, arguments).end(); })

-           .tween("brush", function() {

-             var that = this,

-                 state = that.__brush,

-                 emit = emitter(that, arguments),

-                 selection0 = state.selection,

-                 selection1 = dim.input(typeof selection === "function" ? selection.apply(this, arguments) : selection, state.extent),

-                 i = interpolateValue(selection0, selection1);

- 

-             function tween(t) {

-               state.selection = t === 1 && empty(selection1) ? null : i(t);

-               redraw.call(that);

-               emit.brush();

-             }

- 

-             return selection0 && selection1 ? tween : tween(1);

-           });

-     } else {

-       group

-           .each(function() {

-             var that = this,

-                 args = arguments,

-                 state = that.__brush,

-                 selection1 = dim.input(typeof selection === "function" ? selection.apply(that, args) : selection, state.extent),

-                 emit = emitter(that, args).beforestart();

- 

-             interrupt(that);

-             state.selection = selection1 == null || empty(selection1) ? null : selection1;

-             redraw.call(that);

-             emit.start().brush().end();

-           });

-     }

-   };

- 

-   function redraw() {

-     var group = select(this),

-         selection = local(this).selection;

- 

-     if (selection) {

-       group.selectAll(".selection")

-           .style("display", null)

-           .attr("x", selection[0][0])

-           .attr("y", selection[0][1])

-           .attr("width", selection[1][0] - selection[0][0])

-           .attr("height", selection[1][1] - selection[0][1]);

- 

-       group.selectAll(".handle")

-           .style("display", null)

-           .attr("x", function(d) { return d.type[d.type.length - 1] === "e" ? selection[1][0] - handleSize / 2 : selection[0][0] - handleSize / 2; })

-           .attr("y", function(d) { return d.type[0] === "s" ? selection[1][1] - handleSize / 2 : selection[0][1] - handleSize / 2; })

-           .attr("width", function(d) { return d.type === "n" || d.type === "s" ? selection[1][0] - selection[0][0] + handleSize : handleSize; })

-           .attr("height", function(d) { return d.type === "e" || d.type === "w" ? selection[1][1] - selection[0][1] + handleSize : handleSize; });

-     }

- 

-     else {

-       group.selectAll(".selection,.handle")

-           .style("display", "none")

-           .attr("x", null)

-           .attr("y", null)

-           .attr("width", null)

-           .attr("height", null);

-     }

-   }

- 

-   function emitter(that, args) {

-     return that.__brush.emitter || new Emitter(that, args);

-   }

- 

-   function Emitter(that, args) {

-     this.that = that;

-     this.args = args;

-     this.state = that.__brush;

-     this.active = 0;

-   }

- 

-   Emitter.prototype = {

-     beforestart: function() {

-       if (++this.active === 1) this.state.emitter = this, this.starting = true;

-       return this;

-     },

-     start: function() {

-       if (this.starting) this.starting = false, this.emit("start");

-       return this;

-     },

-     brush: function() {

-       this.emit("brush");

-       return this;

-     },

-     end: function() {

-       if (--this.active === 0) delete this.state.emitter, this.emit("end");

-       return this;

-     },

-     emit: function(type) {

-       customEvent(new BrushEvent(brush, type, dim.output(this.state.selection)), listeners.apply, listeners, [type, this.that, this.args]);

-     }

-   };

- 

-   function started() {

-     if (exports.event.touches) { if (exports.event.changedTouches.length < exports.event.touches.length) return noevent$1(); }

-     else if (touchending) return;

-     if (!filter.apply(this, arguments)) return;

- 

-     var that = this,

-         type = exports.event.target.__data__.type,

-         mode = (exports.event.metaKey ? type = "overlay" : type) === "selection" ? MODE_DRAG : (exports.event.altKey ? MODE_CENTER : MODE_HANDLE),

-         signX = dim === Y ? null : signsX[type],

-         signY = dim === X ? null : signsY[type],

-         state = local(that),

-         extent = state.extent,

-         selection = state.selection,

-         W = extent[0][0], w0, w1,

-         N = extent[0][1], n0, n1,

-         E = extent[1][0], e0, e1,

-         S = extent[1][1], s0, s1,

-         dx,

-         dy,

-         moving,

-         shifting = signX && signY && exports.event.shiftKey,

-         lockX,

-         lockY,

-         point0 = mouse(that),

-         point = point0,

-         emit = emitter(that, arguments).beforestart();

- 

-     if (type === "overlay") {

-       state.selection = selection = [

-         [w0 = dim === Y ? W : point0[0], n0 = dim === X ? N : point0[1]],

-         [e0 = dim === Y ? E : w0, s0 = dim === X ? S : n0]

-       ];

-     } else {

-       w0 = selection[0][0];

-       n0 = selection[0][1];

-       e0 = selection[1][0];

-       s0 = selection[1][1];

-     }

- 

-     w1 = w0;

-     n1 = n0;

-     e1 = e0;

-     s1 = s0;

- 

-     var group = select(that)

-         .attr("pointer-events", "none");

- 

-     var overlay = group.selectAll(".overlay")

-         .attr("cursor", cursors[type]);

- 

-     if (exports.event.touches) {

-       group

-           .on("touchmove.brush", moved, true)

-           .on("touchend.brush touchcancel.brush", ended, true);

-     } else {

-       var view = select(exports.event.view)

-           .on("keydown.brush", keydowned, true)

-           .on("keyup.brush", keyupped, true)

-           .on("mousemove.brush", moved, true)

-           .on("mouseup.brush", ended, true);

- 

-       dragDisable(exports.event.view);

-     }

- 

-     nopropagation$1();

-     interrupt(that);

-     redraw.call(that);

-     emit.start();

- 

-     function moved() {

-       var point1 = mouse(that);

-       if (shifting && !lockX && !lockY) {

-         if (Math.abs(point1[0] - point[0]) > Math.abs(point1[1] - point[1])) lockY = true;

-         else lockX = true;

-       }

-       point = point1;

-       moving = true;

-       noevent$1();

-       move();

-     }

- 

-     function move() {

-       var t;

- 

-       dx = point[0] - point0[0];

-       dy = point[1] - point0[1];

- 

-       switch (mode) {

-         case MODE_SPACE:

-         case MODE_DRAG: {

-           if (signX) dx = Math.max(W - w0, Math.min(E - e0, dx)), w1 = w0 + dx, e1 = e0 + dx;

-           if (signY) dy = Math.max(N - n0, Math.min(S - s0, dy)), n1 = n0 + dy, s1 = s0 + dy;

-           break;

-         }

-         case MODE_HANDLE: {

-           if (signX < 0) dx = Math.max(W - w0, Math.min(E - w0, dx)), w1 = w0 + dx, e1 = e0;

-           else if (signX > 0) dx = Math.max(W - e0, Math.min(E - e0, dx)), w1 = w0, e1 = e0 + dx;

-           if (signY < 0) dy = Math.max(N - n0, Math.min(S - n0, dy)), n1 = n0 + dy, s1 = s0;

-           else if (signY > 0) dy = Math.max(N - s0, Math.min(S - s0, dy)), n1 = n0, s1 = s0 + dy;

-           break;

-         }

-         case MODE_CENTER: {

-           if (signX) w1 = Math.max(W, Math.min(E, w0 - dx * signX)), e1 = Math.max(W, Math.min(E, e0 + dx * signX));

-           if (signY) n1 = Math.max(N, Math.min(S, n0 - dy * signY)), s1 = Math.max(N, Math.min(S, s0 + dy * signY));

-           break;

-         }

-       }

- 

-       if (e1 < w1) {

-         signX *= -1;

-         t = w0, w0 = e0, e0 = t;

-         t = w1, w1 = e1, e1 = t;

-         if (type in flipX) overlay.attr("cursor", cursors[type = flipX[type]]);

-       }

- 

-       if (s1 < n1) {

-         signY *= -1;

-         t = n0, n0 = s0, s0 = t;

-         t = n1, n1 = s1, s1 = t;

-         if (type in flipY) overlay.attr("cursor", cursors[type = flipY[type]]);

-       }

- 

-       if (state.selection) selection = state.selection; // May be set by brush.move!

-       if (lockX) w1 = selection[0][0], e1 = selection[1][0];

-       if (lockY) n1 = selection[0][1], s1 = selection[1][1];

- 

-       if (selection[0][0] !== w1

-           || selection[0][1] !== n1

-           || selection[1][0] !== e1

-           || selection[1][1] !== s1) {

-         state.selection = [[w1, n1], [e1, s1]];

-         redraw.call(that);

-         emit.brush();

-       }

-     }

- 

-     function ended() {

-       nopropagation$1();

-       if (exports.event.touches) {

-         if (exports.event.touches.length) return;

-         if (touchending) clearTimeout(touchending);

-         touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!

-         group.on("touchmove.brush touchend.brush touchcancel.brush", null);

-       } else {

-         yesdrag(exports.event.view, moving);

-         view.on("keydown.brush keyup.brush mousemove.brush mouseup.brush", null);

-       }

-       group.attr("pointer-events", "all");

-       overlay.attr("cursor", cursors.overlay);

-       if (state.selection) selection = state.selection; // May be set by brush.move (on start)!

-       if (empty(selection)) state.selection = null, redraw.call(that);

-       emit.end();

-     }

- 

-     function keydowned() {

-       switch (exports.event.keyCode) {

-         case 16: { // SHIFT

-           shifting = signX && signY;

-           break;

-         }

-         case 18: { // ALT

-           if (mode === MODE_HANDLE) {

-             if (signX) e0 = e1 - dx * signX, w0 = w1 + dx * signX;

-             if (signY) s0 = s1 - dy * signY, n0 = n1 + dy * signY;

-             mode = MODE_CENTER;

-             move();

-           }

-           break;

-         }

-         case 32: { // SPACE; takes priority over ALT

-           if (mode === MODE_HANDLE || mode === MODE_CENTER) {

-             if (signX < 0) e0 = e1 - dx; else if (signX > 0) w0 = w1 - dx;

-             if (signY < 0) s0 = s1 - dy; else if (signY > 0) n0 = n1 - dy;

-             mode = MODE_SPACE;

-             overlay.attr("cursor", cursors.selection);

-             move();

-           }

-           break;

-         }

-         default: return;

-       }

-       noevent$1();

-     }

- 

-     function keyupped() {

-       switch (exports.event.keyCode) {

-         case 16: { // SHIFT

-           if (shifting) {

-             lockX = lockY = shifting = false;

-             move();

-           }

-           break;

-         }

-         case 18: { // ALT

-           if (mode === MODE_CENTER) {

-             if (signX < 0) e0 = e1; else if (signX > 0) w0 = w1;

-             if (signY < 0) s0 = s1; else if (signY > 0) n0 = n1;

-             mode = MODE_HANDLE;

-             move();

-           }

-           break;

-         }

-         case 32: { // SPACE

-           if (mode === MODE_SPACE) {

-             if (exports.event.altKey) {

-               if (signX) e0 = e1 - dx * signX, w0 = w1 + dx * signX;

-               if (signY) s0 = s1 - dy * signY, n0 = n1 + dy * signY;

-               mode = MODE_CENTER;

-             } else {

-               if (signX < 0) e0 = e1; else if (signX > 0) w0 = w1;

-               if (signY < 0) s0 = s1; else if (signY > 0) n0 = n1;

-               mode = MODE_HANDLE;

-             }

-             overlay.attr("cursor", cursors[type]);

-             move();

-           }

-           break;

-         }

-         default: return;

-       }

-       noevent$1();

-     }

-   }

- 

-   function initialize() {

-     var state = this.__brush || {selection: null};

-     state.extent = extent.apply(this, arguments);

-     state.dim = dim;

-     return state;

-   }

- 

-   brush.extent = function(_) {

-     return arguments.length ? (extent = typeof _ === "function" ? _ : constant$4([[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]]), brush) : extent;

-   };

- 

-   brush.filter = function(_) {

-     return arguments.length ? (filter = typeof _ === "function" ? _ : constant$4(!!_), brush) : filter;

-   };

- 

-   brush.handleSize = function(_) {

-     return arguments.length ? (handleSize = +_, brush) : handleSize;

-   };

- 

-   brush.on = function() {

-     var value = listeners.on.apply(listeners, arguments);

-     return value === listeners ? brush : value;

-   };

- 

-   return brush;

- }

- 

- var cos = Math.cos;

- var sin = Math.sin;

- var pi$1 = Math.PI;

- var halfPi$1 = pi$1 / 2;

- var tau$1 = pi$1 * 2;

- var max$1 = Math.max;

- 

- function compareValue(compare) {

-   return function(a, b) {

-     return compare(

-       a.source.value + a.target.value,

-       b.source.value + b.target.value

-     );

-   };

- }

- 

- var chord = function() {

-   var padAngle = 0,

-       sortGroups = null,

-       sortSubgroups = null,

-       sortChords = null;

- 

-   function chord(matrix) {

-     var n = matrix.length,

-         groupSums = [],

-         groupIndex = sequence(n),

-         subgroupIndex = [],

-         chords = [],

-         groups = chords.groups = new Array(n),

-         subgroups = new Array(n * n),

-         k,

-         x,

-         x0,

-         dx,

-         i,

-         j;

- 

-     // Compute the sum.

-     k = 0, i = -1; while (++i < n) {

-       x = 0, j = -1; while (++j < n) {

-         x += matrix[i][j];

-       }

-       groupSums.push(x);

-       subgroupIndex.push(sequence(n));

-       k += x;

-     }

- 

-     // Sort groups…

-     if (sortGroups) groupIndex.sort(function(a, b) {

-       return sortGroups(groupSums[a], groupSums[b]);

-     });

- 

-     // Sort subgroups…

-     if (sortSubgroups) subgroupIndex.forEach(function(d, i) {

-       d.sort(function(a, b) {

-         return sortSubgroups(matrix[i][a], matrix[i][b]);

-       });

-     });

- 

-     // Convert the sum to scaling factor for [0, 2pi].

-     // TODO Allow start and end angle to be specified?

-     // TODO Allow padding to be specified as percentage?

-     k = max$1(0, tau$1 - padAngle * n) / k;

-     dx = k ? padAngle : tau$1 / n;

- 

-     // Compute the start and end angle for each group and subgroup.

-     // Note: Opera has a bug reordering object literal properties!

-     x = 0, i = -1; while (++i < n) {

-       x0 = x, j = -1; while (++j < n) {

-         var di = groupIndex[i],

-             dj = subgroupIndex[di][j],

-             v = matrix[di][dj],

-             a0 = x,

-             a1 = x += v * k;

-         subgroups[dj * n + di] = {

-           index: di,

-           subindex: dj,

-           startAngle: a0,

-           endAngle: a1,

-           value: v

-         };

-       }

-       groups[di] = {

-         index: di,

-         startAngle: x0,

-         endAngle: x,

-         value: groupSums[di]

-       };

-       x += dx;

-     }

- 

-     // Generate chords for each (non-empty) subgroup-subgroup link.

-     i = -1; while (++i < n) {

-       j = i - 1; while (++j < n) {

-         var source = subgroups[j * n + i],

-             target = subgroups[i * n + j];

-         if (source.value || target.value) {

-           chords.push(source.value < target.value

-               ? {source: target, target: source}

-               : {source: source, target: target});

-         }

-       }

-     }

- 

-     return sortChords ? chords.sort(sortChords) : chords;

-   }

- 

-   chord.padAngle = function(_) {

-     return arguments.length ? (padAngle = max$1(0, _), chord) : padAngle;

-   };

- 

-   chord.sortGroups = function(_) {

-     return arguments.length ? (sortGroups = _, chord) : sortGroups;

-   };

- 

-   chord.sortSubgroups = function(_) {

-     return arguments.length ? (sortSubgroups = _, chord) : sortSubgroups;

-   };

- 

-   chord.sortChords = function(_) {

-     return arguments.length ? (_ == null ? sortChords = null : (sortChords = compareValue(_))._ = _, chord) : sortChords && sortChords._;

-   };

- 

-   return chord;

- };

- 

- var slice$2 = Array.prototype.slice;

- 

- var constant$5 = function(x) {

-   return function() {

-     return x;

-   };

- };

- 

- var pi$2 = Math.PI;

- var tau$2 = 2 * pi$2;

- var epsilon$1 = 1e-6;

- var tauEpsilon = tau$2 - epsilon$1;

- 

- function Path() {

-   this._x0 = this._y0 = // start of current subpath

-   this._x1 = this._y1 = null; // end of current subpath

-   this._ = "";

- }

- 

- function path() {

-   return new Path;

- }

- 

- Path.prototype = path.prototype = {

-   constructor: Path,

-   moveTo: function(x, y) {

-     this._ += "M" + (this._x0 = this._x1 = +x) + "," + (this._y0 = this._y1 = +y);

-   },

-   closePath: function() {

-     if (this._x1 !== null) {

-       this._x1 = this._x0, this._y1 = this._y0;

-       this._ += "Z";

-     }

-   },

-   lineTo: function(x, y) {

-     this._ += "L" + (this._x1 = +x) + "," + (this._y1 = +y);

-   },

-   quadraticCurveTo: function(x1, y1, x, y) {

-     this._ += "Q" + (+x1) + "," + (+y1) + "," + (this._x1 = +x) + "," + (this._y1 = +y);

-   },

-   bezierCurveTo: function(x1, y1, x2, y2, x, y) {

-     this._ += "C" + (+x1) + "," + (+y1) + "," + (+x2) + "," + (+y2) + "," + (this._x1 = +x) + "," + (this._y1 = +y);

-   },

-   arcTo: function(x1, y1, x2, y2, r) {

-     x1 = +x1, y1 = +y1, x2 = +x2, y2 = +y2, r = +r;

-     var x0 = this._x1,

-         y0 = this._y1,

-         x21 = x2 - x1,

-         y21 = y2 - y1,

-         x01 = x0 - x1,

-         y01 = y0 - y1,

-         l01_2 = x01 * x01 + y01 * y01;

- 

-     // Is the radius negative? Error.

-     if (r < 0) throw new Error("negative radius: " + r);

- 

-     // Is this path empty? Move to (x1,y1).

-     if (this._x1 === null) {

-       this._ += "M" + (this._x1 = x1) + "," + (this._y1 = y1);

-     }

- 

-     // Or, is (x1,y1) coincident with (x0,y0)? Do nothing.

-     else if (!(l01_2 > epsilon$1)) {}

- 

-     // Or, are (x0,y0), (x1,y1) and (x2,y2) collinear?

-     // Equivalently, is (x1,y1) coincident with (x2,y2)?

-     // Or, is the radius zero? Line to (x1,y1).

-     else if (!(Math.abs(y01 * x21 - y21 * x01) > epsilon$1) || !r) {

-       this._ += "L" + (this._x1 = x1) + "," + (this._y1 = y1);

-     }

- 

-     // Otherwise, draw an arc!

-     else {

-       var x20 = x2 - x0,

-           y20 = y2 - y0,

-           l21_2 = x21 * x21 + y21 * y21,

-           l20_2 = x20 * x20 + y20 * y20,

-           l21 = Math.sqrt(l21_2),

-           l01 = Math.sqrt(l01_2),

-           l = r * Math.tan((pi$2 - Math.acos((l21_2 + l01_2 - l20_2) / (2 * l21 * l01))) / 2),

-           t01 = l / l01,

-           t21 = l / l21;

- 

-       // If the start tangent is not coincident with (x0,y0), line to.

-       if (Math.abs(t01 - 1) > epsilon$1) {

-         this._ += "L" + (x1 + t01 * x01) + "," + (y1 + t01 * y01);

-       }

- 

-       this._ += "A" + r + "," + r + ",0,0," + (+(y01 * x20 > x01 * y20)) + "," + (this._x1 = x1 + t21 * x21) + "," + (this._y1 = y1 + t21 * y21);

-     }

-   },

-   arc: function(x, y, r, a0, a1, ccw) {

-     x = +x, y = +y, r = +r;

-     var dx = r * Math.cos(a0),

-         dy = r * Math.sin(a0),

-         x0 = x + dx,

-         y0 = y + dy,

-         cw = 1 ^ ccw,

-         da = ccw ? a0 - a1 : a1 - a0;

- 

-     // Is the radius negative? Error.

-     if (r < 0) throw new Error("negative radius: " + r);

- 

-     // Is this path empty? Move to (x0,y0).

-     if (this._x1 === null) {

-       this._ += "M" + x0 + "," + y0;

-     }

- 

-     // Or, is (x0,y0) not coincident with the previous point? Line to (x0,y0).

-     else if (Math.abs(this._x1 - x0) > epsilon$1 || Math.abs(this._y1 - y0) > epsilon$1) {

-       this._ += "L" + x0 + "," + y0;

-     }

- 

-     // Is this arc empty? We’re done.

-     if (!r) return;

- 

-     // Does the angle go the wrong way? Flip the direction.

-     if (da < 0) da = da % tau$2 + tau$2;

- 

-     // Is this a complete circle? Draw two arcs to complete the circle.

-     if (da > tauEpsilon) {

-       this._ += "A" + r + "," + r + ",0,1," + cw + "," + (x - dx) + "," + (y - dy) + "A" + r + "," + r + ",0,1," + cw + "," + (this._x1 = x0) + "," + (this._y1 = y0);

-     }

- 

-     // Is this arc non-empty? Draw an arc!

-     else if (da > epsilon$1) {

-       this._ += "A" + r + "," + r + ",0," + (+(da >= pi$2)) + "," + cw + "," + (this._x1 = x + r * Math.cos(a1)) + "," + (this._y1 = y + r * Math.sin(a1));

-     }

-   },

-   rect: function(x, y, w, h) {

-     this._ += "M" + (this._x0 = this._x1 = +x) + "," + (this._y0 = this._y1 = +y) + "h" + (+w) + "v" + (+h) + "h" + (-w) + "Z";

-   },

-   toString: function() {

-     return this._;

-   }

- };

- 

- function defaultSource(d) {

-   return d.source;

- }

- 

- function defaultTarget(d) {

-   return d.target;

- }

- 

- function defaultRadius(d) {

-   return d.radius;

- }

- 

- function defaultStartAngle(d) {

-   return d.startAngle;

- }

- 

- function defaultEndAngle(d) {

-   return d.endAngle;

- }

- 

- var ribbon = function() {

-   var source = defaultSource,

-       target = defaultTarget,

-       radius = defaultRadius,

-       startAngle = defaultStartAngle,

-       endAngle = defaultEndAngle,

-       context = null;

- 

-   function ribbon() {

-     var buffer,

-         argv = slice$2.call(arguments),

-         s = source.apply(this, argv),

-         t = target.apply(this, argv),

-         sr = +radius.apply(this, (argv[0] = s, argv)),

-         sa0 = startAngle.apply(this, argv) - halfPi$1,

-         sa1 = endAngle.apply(this, argv) - halfPi$1,

-         sx0 = sr * cos(sa0),

-         sy0 = sr * sin(sa0),

-         tr = +radius.apply(this, (argv[0] = t, argv)),

-         ta0 = startAngle.apply(this, argv) - halfPi$1,

-         ta1 = endAngle.apply(this, argv) - halfPi$1;

- 

-     if (!context) context = buffer = path();

- 

-     context.moveTo(sx0, sy0);

-     context.arc(0, 0, sr, sa0, sa1);

-     if (sa0 !== ta0 || sa1 !== ta1) { // TODO sr !== tr?

-       context.quadraticCurveTo(0, 0, tr * cos(ta0), tr * sin(ta0));

-       context.arc(0, 0, tr, ta0, ta1);

-     }

-     context.quadraticCurveTo(0, 0, sx0, sy0);

-     context.closePath();

- 

-     if (buffer) return context = null, buffer + "" || null;

-   }

- 

-   ribbon.radius = function(_) {

-     return arguments.length ? (radius = typeof _ === "function" ? _ : constant$5(+_), ribbon) : radius;

-   };

- 

-   ribbon.startAngle = function(_) {

-     return arguments.length ? (startAngle = typeof _ === "function" ? _ : constant$5(+_), ribbon) : startAngle;

-   };

- 

-   ribbon.endAngle = function(_) {

-     return arguments.length ? (endAngle = typeof _ === "function" ? _ : constant$5(+_), ribbon) : endAngle;

-   };

- 

-   ribbon.source = function(_) {

-     return arguments.length ? (source = _, ribbon) : source;

-   };

- 

-   ribbon.target = function(_) {

-     return arguments.length ? (target = _, ribbon) : target;

-   };

- 

-   ribbon.context = function(_) {

-     return arguments.length ? ((context = _ == null ? null : _), ribbon) : context;

-   };

- 

-   return ribbon;

- };

- 

- var prefix = "$";

- 

- function Map() {}

- 

- Map.prototype = map$1.prototype = {

-   constructor: Map,

-   has: function(key) {

-     return (prefix + key) in this;

-   },

-   get: function(key) {

-     return this[prefix + key];

-   },

-   set: function(key, value) {

-     this[prefix + key] = value;

-     return this;

-   },

-   remove: function(key) {

-     var property = prefix + key;

-     return property in this && delete this[property];

-   },

-   clear: function() {

-     for (var property in this) if (property[0] === prefix) delete this[property];

-   },

-   keys: function() {

-     var keys = [];

-     for (var property in this) if (property[0] === prefix) keys.push(property.slice(1));

-     return keys;

-   },

-   values: function() {

-     var values = [];

-     for (var property in this) if (property[0] === prefix) values.push(this[property]);

-     return values;

-   },

-   entries: function() {

-     var entries = [];

-     for (var property in this) if (property[0] === prefix) entries.push({key: property.slice(1), value: this[property]});

-     return entries;

-   },

-   size: function() {

-     var size = 0;

-     for (var property in this) if (property[0] === prefix) ++size;

-     return size;

-   },

-   empty: function() {

-     for (var property in this) if (property[0] === prefix) return false;

-     return true;

-   },

-   each: function(f) {

-     for (var property in this) if (property[0] === prefix) f(this[property], property.slice(1), this);

-   }

- };

- 

- function map$1(object, f) {

-   var map = new Map;

- 

-   // Copy constructor.

-   if (object instanceof Map) object.each(function(value, key) { map.set(key, value); });

- 

-   // Index array by numeric index or specified key function.

-   else if (Array.isArray(object)) {

-     var i = -1,

-         n = object.length,

-         o;

- 

-     if (f == null) while (++i < n) map.set(i, object[i]);

-     else while (++i < n) map.set(f(o = object[i], i, object), o);

-   }

- 

-   // Convert object to map.

-   else if (object) for (var key in object) map.set(key, object[key]);

- 

-   return map;

- }

- 

- var nest = function() {

-   var keys = [],

-       sortKeys = [],

-       sortValues,

-       rollup,

-       nest;

- 

-   function apply(array, depth, createResult, setResult) {

-     if (depth >= keys.length) {

-       if (sortValues != null) array.sort(sortValues);

-       return rollup != null ? rollup(array) : array;

-     }

- 

-     var i = -1,

-         n = array.length,

-         key = keys[depth++],

-         keyValue,

-         value,

-         valuesByKey = map$1(),

-         values,

-         result = createResult();

- 

-     while (++i < n) {

-       if (values = valuesByKey.get(keyValue = key(value = array[i]) + "")) {

-         values.push(value);

-       } else {

-         valuesByKey.set(keyValue, [value]);

-       }

-     }

- 

-     valuesByKey.each(function(values, key) {

-       setResult(result, key, apply(values, depth, createResult, setResult));

-     });

- 

-     return result;

-   }

- 

-   function entries(map, depth) {

-     if (++depth > keys.length) return map;

-     var array, sortKey = sortKeys[depth - 1];

-     if (rollup != null && depth >= keys.length) array = map.entries();

-     else array = [], map.each(function(v, k) { array.push({key: k, values: entries(v, depth)}); });

-     return sortKey != null ? array.sort(function(a, b) { return sortKey(a.key, b.key); }) : array;

-   }

- 

-   return nest = {

-     object: function(array) { return apply(array, 0, createObject, setObject); },

-     map: function(array) { return apply(array, 0, createMap, setMap); },

-     entries: function(array) { return entries(apply(array, 0, createMap, setMap), 0); },

-     key: function(d) { keys.push(d); return nest; },

-     sortKeys: function(order) { sortKeys[keys.length - 1] = order; return nest; },

-     sortValues: function(order) { sortValues = order; return nest; },

-     rollup: function(f) { rollup = f; return nest; }

-   };

- };

- 

- function createObject() {

-   return {};

- }

- 

- function setObject(object, key, value) {

-   object[key] = value;

- }

- 

- function createMap() {

-   return map$1();

- }

- 

- function setMap(map, key, value) {

-   map.set(key, value);

- }

- 

- function Set() {}

- 

- var proto = map$1.prototype;

- 

- Set.prototype = set$2.prototype = {

-   constructor: Set,

-   has: proto.has,

-   add: function(value) {

-     value += "";

-     this[prefix + value] = value;

-     return this;

-   },

-   remove: proto.remove,

-   clear: proto.clear,

-   values: proto.keys,

-   size: proto.size,

-   empty: proto.empty,

-   each: proto.each

- };

- 

- function set$2(object, f) {

-   var set = new Set;

- 

-   // Copy constructor.

-   if (object instanceof Set) object.each(function(value) { set.add(value); });

- 

-   // Otherwise, assume it’s an array.

-   else if (object) {

-     var i = -1, n = object.length;

-     if (f == null) while (++i < n) set.add(object[i]);

-     else while (++i < n) set.add(f(object[i], i, object));

-   }

- 

-   return set;

- }

- 

- var keys = function(map) {

-   var keys = [];

-   for (var key in map) keys.push(key);

-   return keys;

- };

- 

- var values = function(map) {

-   var values = [];

-   for (var key in map) values.push(map[key]);

-   return values;

- };

- 

- var entries = function(map) {

-   var entries = [];

-   for (var key in map) entries.push({key: key, value: map[key]});

-   return entries;

- };

- 

- var EOL = {};

- var EOF = {};

- var QUOTE = 34;

- var NEWLINE = 10;

- var RETURN = 13;

- 

- function objectConverter(columns) {

-   return new Function("d", "return {" + columns.map(function(name, i) {

-     return JSON.stringify(name) + ": d[" + i + "]";

-   }).join(",") + "}");

- }

- 

- function customConverter(columns, f) {

-   var object = objectConverter(columns);

-   return function(row, i) {

-     return f(object(row), i, columns);

-   };

- }

- 

- // Compute unique columns in order of discovery.

- function inferColumns(rows) {

-   var columnSet = Object.create(null),

-       columns = [];

- 

-   rows.forEach(function(row) {

-     for (var column in row) {

-       if (!(column in columnSet)) {

-         columns.push(columnSet[column] = column);

-       }

-     }

-   });

- 

-   return columns;

- }

- 

- var dsv = function(delimiter) {

-   var reFormat = new RegExp("[\"" + delimiter + "\n\r]"),

-       DELIMITER = delimiter.charCodeAt(0);

- 

-   function parse(text, f) {

-     var convert, columns, rows = parseRows(text, function(row, i) {

-       if (convert) return convert(row, i - 1);

-       columns = row, convert = f ? customConverter(row, f) : objectConverter(row);

-     });

-     rows.columns = columns;

-     return rows;

-   }

- 

-   function parseRows(text, f) {

-     var rows = [], // output rows

-         N = text.length,

-         I = 0, // current character index

-         n = 0, // current line number

-         t, // current token

-         eof = N <= 0, // current token followed by EOF?

-         eol = false; // current token followed by EOL?

- 

-     // Strip the trailing newline.

-     if (text.charCodeAt(N - 1) === NEWLINE) --N;

-     if (text.charCodeAt(N - 1) === RETURN) --N;

- 

-     function token() {

-       if (eof) return EOF;

-       if (eol) return eol = false, EOL;

- 

-       // Unescape quotes.

-       var i, j = I, c;

-       if (text.charCodeAt(j) === QUOTE) {

-         while (I++ < N && text.charCodeAt(I) !== QUOTE || text.charCodeAt(++I) === QUOTE);

-         if ((i = I) >= N) eof = true;

-         else if ((c = text.charCodeAt(I++)) === NEWLINE) eol = true;

-         else if (c === RETURN) { eol = true; if (text.charCodeAt(I) === NEWLINE) ++I; }

-         return text.slice(j + 1, i - 1).replace(/""/g, "\"");

-       }

- 

-       // Find next delimiter or newline.

-       while (I < N) {

-         if ((c = text.charCodeAt(i = I++)) === NEWLINE) eol = true;

-         else if (c === RETURN) { eol = true; if (text.charCodeAt(I) === NEWLINE) ++I; }

-         else if (c !== DELIMITER) continue;

-         return text.slice(j, i);

-       }

- 

-       // Return last token before EOF.

-       return eof = true, text.slice(j, N);

-     }

- 

-     while ((t = token()) !== EOF) {

-       var row = [];

-       while (t !== EOL && t !== EOF) row.push(t), t = token();

-       if (f && (row = f(row, n++)) == null) continue;

-       rows.push(row);

-     }

- 

-     return rows;

-   }

- 

-   function format(rows, columns) {

-     if (columns == null) columns = inferColumns(rows);

-     return [columns.map(formatValue).join(delimiter)].concat(rows.map(function(row) {

-       return columns.map(function(column) {

-         return formatValue(row[column]);

-       }).join(delimiter);

-     })).join("\n");

-   }

- 

-   function formatRows(rows) {

-     return rows.map(formatRow).join("\n");

-   }

- 

-   function formatRow(row) {

-     return row.map(formatValue).join(delimiter);

-   }

- 

-   function formatValue(text) {

-     return text == null ? ""

-         : reFormat.test(text += "") ? "\"" + text.replace(/"/g, "\"\"") + "\""

-         : text;

-   }

- 

-   return {

-     parse: parse,

-     parseRows: parseRows,

-     format: format,

-     formatRows: formatRows

-   };

- };

- 

- var csv = dsv(",");

- 

- var csvParse = csv.parse;

- var csvParseRows = csv.parseRows;

- var csvFormat = csv.format;

- var csvFormatRows = csv.formatRows;

- 

- var tsv = dsv("\t");

- 

- var tsvParse = tsv.parse;

- var tsvParseRows = tsv.parseRows;

- var tsvFormat = tsv.format;

- var tsvFormatRows = tsv.formatRows;

- 

- var center$1 = function(x, y) {

-   var nodes;

- 

-   if (x == null) x = 0;

-   if (y == null) y = 0;

- 

-   function force() {

-     var i,

-         n = nodes.length,

-         node,

-         sx = 0,

-         sy = 0;

- 

-     for (i = 0; i < n; ++i) {

-       node = nodes[i], sx += node.x, sy += node.y;

-     }

- 

-     for (sx = sx / n - x, sy = sy / n - y, i = 0; i < n; ++i) {

-       node = nodes[i], node.x -= sx, node.y -= sy;

-     }

-   }

- 

-   force.initialize = function(_) {

-     nodes = _;

-   };

- 

-   force.x = function(_) {

-     return arguments.length ? (x = +_, force) : x;

-   };

- 

-   force.y = function(_) {

-     return arguments.length ? (y = +_, force) : y;

-   };

- 

-   return force;

- };

- 

- var constant$6 = function(x) {

-   return function() {

-     return x;

-   };

- };

- 

- var jiggle = function() {

-   return (Math.random() - 0.5) * 1e-6;

- };

- 

- var tree_add = function(d) {

-   var x = +this._x.call(null, d),

-       y = +this._y.call(null, d);

-   return add(this.cover(x, y), x, y, d);

- };

- 

- function add(tree, x, y, d) {

-   if (isNaN(x) || isNaN(y)) return tree; // ignore invalid points

- 

-   var parent,

-       node = tree._root,

-       leaf = {data: d},

-       x0 = tree._x0,

-       y0 = tree._y0,

-       x1 = tree._x1,

-       y1 = tree._y1,

-       xm,

-       ym,

-       xp,

-       yp,

-       right,

-       bottom,

-       i,

-       j;

- 

-   // If the tree is empty, initialize the root as a leaf.

-   if (!node) return tree._root = leaf, tree;

- 

-   // Find the existing leaf for the new point, or add it.

-   while (node.length) {

-     if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;

-     if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;

-     if (parent = node, !(node = node[i = bottom << 1 | right])) return parent[i] = leaf, tree;

-   }

- 

-   // Is the new point is exactly coincident with the existing point?

-   xp = +tree._x.call(null, node.data);

-   yp = +tree._y.call(null, node.data);

-   if (x === xp && y === yp) return leaf.next = node, parent ? parent[i] = leaf : tree._root = leaf, tree;

- 

-   // Otherwise, split the leaf node until the old and new point are separated.

-   do {

-     parent = parent ? parent[i] = new Array(4) : tree._root = new Array(4);

-     if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;

-     if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;

-   } while ((i = bottom << 1 | right) === (j = (yp >= ym) << 1 | (xp >= xm)));

-   return parent[j] = node, parent[i] = leaf, tree;

- }

- 

- function addAll(data) {

-   var d, i, n = data.length,

-       x,

-       y,

-       xz = new Array(n),

-       yz = new Array(n),

-       x0 = Infinity,

-       y0 = Infinity,

-       x1 = -Infinity,

-       y1 = -Infinity;

- 

-   // Compute the points and their extent.

-   for (i = 0; i < n; ++i) {

-     if (isNaN(x = +this._x.call(null, d = data[i])) || isNaN(y = +this._y.call(null, d))) continue;

-     xz[i] = x;

-     yz[i] = y;

-     if (x < x0) x0 = x;

-     if (x > x1) x1 = x;

-     if (y < y0) y0 = y;

-     if (y > y1) y1 = y;

-   }

- 

-   // If there were no (valid) points, inherit the existing extent.

-   if (x1 < x0) x0 = this._x0, x1 = this._x1;

-   if (y1 < y0) y0 = this._y0, y1 = this._y1;

- 

-   // Expand the tree to cover the new points.

-   this.cover(x0, y0).cover(x1, y1);

- 

-   // Add the new points.

-   for (i = 0; i < n; ++i) {

-     add(this, xz[i], yz[i], data[i]);

-   }

- 

-   return this;

- }

- 

- var tree_cover = function(x, y) {

-   if (isNaN(x = +x) || isNaN(y = +y)) return this; // ignore invalid points

- 

-   var x0 = this._x0,

-       y0 = this._y0,

-       x1 = this._x1,

-       y1 = this._y1;

- 

-   // If the quadtree has no extent, initialize them.

-   // Integer extent are necessary so that if we later double the extent,

-   // the existing quadrant boundaries don’t change due to floating point error!

-   if (isNaN(x0)) {

-     x1 = (x0 = Math.floor(x)) + 1;

-     y1 = (y0 = Math.floor(y)) + 1;

-   }

- 

-   // Otherwise, double repeatedly to cover.

-   else if (x0 > x || x > x1 || y0 > y || y > y1) {

-     var z = x1 - x0,

-         node = this._root,

-         parent,

-         i;

- 

-     switch (i = (y < (y0 + y1) / 2) << 1 | (x < (x0 + x1) / 2)) {

-       case 0: {

-         do parent = new Array(4), parent[i] = node, node = parent;

-         while (z *= 2, x1 = x0 + z, y1 = y0 + z, x > x1 || y > y1);

-         break;

-       }

-       case 1: {

-         do parent = new Array(4), parent[i] = node, node = parent;

-         while (z *= 2, x0 = x1 - z, y1 = y0 + z, x0 > x || y > y1);

-         break;

-       }

-       case 2: {

-         do parent = new Array(4), parent[i] = node, node = parent;

-         while (z *= 2, x1 = x0 + z, y0 = y1 - z, x > x1 || y0 > y);

-         break;

-       }

-       case 3: {

-         do parent = new Array(4), parent[i] = node, node = parent;

-         while (z *= 2, x0 = x1 - z, y0 = y1 - z, x0 > x || y0 > y);

-         break;

-       }

-     }

- 

-     if (this._root && this._root.length) this._root = node;

-   }

- 

-   // If the quadtree covers the point already, just return.

-   else return this;

- 

-   this._x0 = x0;

-   this._y0 = y0;

-   this._x1 = x1;

-   this._y1 = y1;

-   return this;

- };

- 

- var tree_data = function() {

-   var data = [];

-   this.visit(function(node) {

-     if (!node.length) do data.push(node.data); while (node = node.next)

-   });

-   return data;

- };

- 

- var tree_extent = function(_) {

-   return arguments.length

-       ? this.cover(+_[0][0], +_[0][1]).cover(+_[1][0], +_[1][1])

-       : isNaN(this._x0) ? undefined : [[this._x0, this._y0], [this._x1, this._y1]];

- };

- 

- var Quad = function(node, x0, y0, x1, y1) {

-   this.node = node;

-   this.x0 = x0;

-   this.y0 = y0;

-   this.x1 = x1;

-   this.y1 = y1;

- };

- 

- var tree_find = function(x, y, radius) {

-   var data,

-       x0 = this._x0,

-       y0 = this._y0,

-       x1,

-       y1,

-       x2,

-       y2,

-       x3 = this._x1,

-       y3 = this._y1,

-       quads = [],

-       node = this._root,

-       q,

-       i;

- 

-   if (node) quads.push(new Quad(node, x0, y0, x3, y3));

-   if (radius == null) radius = Infinity;

-   else {

-     x0 = x - radius, y0 = y - radius;

-     x3 = x + radius, y3 = y + radius;

-     radius *= radius;

-   }

- 

-   while (q = quads.pop()) {

- 

-     // Stop searching if this quadrant can’t contain a closer node.

-     if (!(node = q.node)

-         || (x1 = q.x0) > x3

-         || (y1 = q.y0) > y3

-         || (x2 = q.x1) < x0

-         || (y2 = q.y1) < y0) continue;

- 

-     // Bisect the current quadrant.

-     if (node.length) {

-       var xm = (x1 + x2) / 2,

-           ym = (y1 + y2) / 2;

- 

-       quads.push(

-         new Quad(node[3], xm, ym, x2, y2),

-         new Quad(node[2], x1, ym, xm, y2),

-         new Quad(node[1], xm, y1, x2, ym),

-         new Quad(node[0], x1, y1, xm, ym)

-       );

- 

-       // Visit the closest quadrant first.

-       if (i = (y >= ym) << 1 | (x >= xm)) {

-         q = quads[quads.length - 1];

-         quads[quads.length - 1] = quads[quads.length - 1 - i];

-         quads[quads.length - 1 - i] = q;

-       }

-     }

- 

-     // Visit this point. (Visiting coincident points isn’t necessary!)

-     else {

-       var dx = x - +this._x.call(null, node.data),

-           dy = y - +this._y.call(null, node.data),

-           d2 = dx * dx + dy * dy;

-       if (d2 < radius) {

-         var d = Math.sqrt(radius = d2);

-         x0 = x - d, y0 = y - d;

-         x3 = x + d, y3 = y + d;

-         data = node.data;

-       }

-     }

-   }

- 

-   return data;

- };

- 

- var tree_remove = function(d) {

-   if (isNaN(x = +this._x.call(null, d)) || isNaN(y = +this._y.call(null, d))) return this; // ignore invalid points

- 

-   var parent,

-       node = this._root,

-       retainer,

-       previous,

-       next,

-       x0 = this._x0,

-       y0 = this._y0,

-       x1 = this._x1,

-       y1 = this._y1,

-       x,

-       y,

-       xm,

-       ym,

-       right,

-       bottom,

-       i,

-       j;

- 

-   // If the tree is empty, initialize the root as a leaf.

-   if (!node) return this;

- 

-   // Find the leaf node for the point.

-   // While descending, also retain the deepest parent with a non-removed sibling.

-   if (node.length) while (true) {

-     if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;

-     if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;

-     if (!(parent = node, node = node[i = bottom << 1 | right])) return this;

-     if (!node.length) break;

-     if (parent[(i + 1) & 3] || parent[(i + 2) & 3] || parent[(i + 3) & 3]) retainer = parent, j = i;

-   }

- 

-   // Find the point to remove.

-   while (node.data !== d) if (!(previous = node, node = node.next)) return this;

-   if (next = node.next) delete node.next;

- 

-   // If there are multiple coincident points, remove just the point.

-   if (previous) return (next ? previous.next = next : delete previous.next), this;

- 

-   // If this is the root point, remove it.

-   if (!parent) return this._root = next, this;

- 

-   // Remove this leaf.

-   next ? parent[i] = next : delete parent[i];

- 

-   // If the parent now contains exactly one leaf, collapse superfluous parents.

-   if ((node = parent[0] || parent[1] || parent[2] || parent[3])

-       && node === (parent[3] || parent[2] || parent[1] || parent[0])

-       && !node.length) {

-     if (retainer) retainer[j] = node;

-     else this._root = node;

-   }

- 

-   return this;

- };

- 

- function removeAll(data) {

-   for (var i = 0, n = data.length; i < n; ++i) this.remove(data[i]);

-   return this;

- }

- 

- var tree_root = function() {

-   return this._root;

- };

- 

- var tree_size = function() {

-   var size = 0;

-   this.visit(function(node) {

-     if (!node.length) do ++size; while (node = node.next)

-   });

-   return size;

- };

- 

- var tree_visit = function(callback) {

-   var quads = [], q, node = this._root, child, x0, y0, x1, y1;

-   if (node) quads.push(new Quad(node, this._x0, this._y0, this._x1, this._y1));

-   while (q = quads.pop()) {

-     if (!callback(node = q.node, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1) && node.length) {

-       var xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;

-       if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));

-       if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));

-       if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));

-       if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));

-     }

-   }

-   return this;

- };

- 

- var tree_visitAfter = function(callback) {

-   var quads = [], next = [], q;

-   if (this._root) quads.push(new Quad(this._root, this._x0, this._y0, this._x1, this._y1));

-   while (q = quads.pop()) {

-     var node = q.node;

-     if (node.length) {

-       var child, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1, xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;

-       if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));

-       if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));

-       if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));

-       if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));

-     }

-     next.push(q);

-   }

-   while (q = next.pop()) {

-     callback(q.node, q.x0, q.y0, q.x1, q.y1);

-   }

-   return this;

- };

- 

- function defaultX(d) {

-   return d[0];

- }

- 

- var tree_x = function(_) {

-   return arguments.length ? (this._x = _, this) : this._x;

- };

- 

- function defaultY(d) {

-   return d[1];

- }

- 

- var tree_y = function(_) {

-   return arguments.length ? (this._y = _, this) : this._y;

- };

- 

- function quadtree(nodes, x, y) {

-   var tree = new Quadtree(x == null ? defaultX : x, y == null ? defaultY : y, NaN, NaN, NaN, NaN);

-   return nodes == null ? tree : tree.addAll(nodes);

- }

- 

- function Quadtree(x, y, x0, y0, x1, y1) {

-   this._x = x;

-   this._y = y;

-   this._x0 = x0;

-   this._y0 = y0;

-   this._x1 = x1;

-   this._y1 = y1;

-   this._root = undefined;

- }

- 

- function leaf_copy(leaf) {

-   var copy = {data: leaf.data}, next = copy;

-   while (leaf = leaf.next) next = next.next = {data: leaf.data};

-   return copy;

- }

- 

- var treeProto = quadtree.prototype = Quadtree.prototype;

- 

- treeProto.copy = function() {

-   var copy = new Quadtree(this._x, this._y, this._x0, this._y0, this._x1, this._y1),

-       node = this._root,

-       nodes,

-       child;

- 

-   if (!node) return copy;

- 

-   if (!node.length) return copy._root = leaf_copy(node), copy;

- 

-   nodes = [{source: node, target: copy._root = new Array(4)}];

-   while (node = nodes.pop()) {

-     for (var i = 0; i < 4; ++i) {

-       if (child = node.source[i]) {

-         if (child.length) nodes.push({source: child, target: node.target[i] = new Array(4)});

-         else node.target[i] = leaf_copy(child);

-       }

-     }

-   }

- 

-   return copy;

- };

- 

- treeProto.add = tree_add;

- treeProto.addAll = addAll;

- treeProto.cover = tree_cover;

- treeProto.data = tree_data;

- treeProto.extent = tree_extent;

- treeProto.find = tree_find;

- treeProto.remove = tree_remove;

- treeProto.removeAll = removeAll;

- treeProto.root = tree_root;

- treeProto.size = tree_size;

- treeProto.visit = tree_visit;

- treeProto.visitAfter = tree_visitAfter;

- treeProto.x = tree_x;

- treeProto.y = tree_y;

- 

- function x(d) {

-   return d.x + d.vx;

- }

- 

- function y(d) {

-   return d.y + d.vy;

- }

- 

- var collide = function(radius) {

-   var nodes,

-       radii,

-       strength = 1,

-       iterations = 1;

- 

-   if (typeof radius !== "function") radius = constant$6(radius == null ? 1 : +radius);

- 

-   function force() {

-     var i, n = nodes.length,

-         tree,

-         node,

-         xi,

-         yi,

-         ri,

-         ri2;

- 

-     for (var k = 0; k < iterations; ++k) {

-       tree = quadtree(nodes, x, y).visitAfter(prepare);

-       for (i = 0; i < n; ++i) {

-         node = nodes[i];

-         ri = radii[node.index], ri2 = ri * ri;

-         xi = node.x + node.vx;

-         yi = node.y + node.vy;

-         tree.visit(apply);

-       }

-     }

- 

-     function apply(quad, x0, y0, x1, y1) {

-       var data = quad.data, rj = quad.r, r = ri + rj;

-       if (data) {

-         if (data.index > node.index) {

-           var x = xi - data.x - data.vx,

-               y = yi - data.y - data.vy,

-               l = x * x + y * y;

-           if (l < r * r) {

-             if (x === 0) x = jiggle(), l += x * x;

-             if (y === 0) y = jiggle(), l += y * y;

-             l = (r - (l = Math.sqrt(l))) / l * strength;

-             node.vx += (x *= l) * (r = (rj *= rj) / (ri2 + rj));

-             node.vy += (y *= l) * r;

-             data.vx -= x * (r = 1 - r);

-             data.vy -= y * r;

-           }

-         }

-         return;

-       }

-       return x0 > xi + r || x1 < xi - r || y0 > yi + r || y1 < yi - r;

-     }

-   }

- 

-   function prepare(quad) {

-     if (quad.data) return quad.r = radii[quad.data.index];

-     for (var i = quad.r = 0; i < 4; ++i) {

-       if (quad[i] && quad[i].r > quad.r) {

-         quad.r = quad[i].r;

-       }

-     }

-   }

- 

-   function initialize() {

-     if (!nodes) return;

-     var i, n = nodes.length, node;

-     radii = new Array(n);

-     for (i = 0; i < n; ++i) node = nodes[i], radii[node.index] = +radius(node, i, nodes);

-   }

- 

-   force.initialize = function(_) {

-     nodes = _;

-     initialize();

-   };

- 

-   force.iterations = function(_) {

-     return arguments.length ? (iterations = +_, force) : iterations;

-   };

- 

-   force.strength = function(_) {

-     return arguments.length ? (strength = +_, force) : strength;

-   };

- 

-   force.radius = function(_) {

-     return arguments.length ? (radius = typeof _ === "function" ? _ : constant$6(+_), initialize(), force) : radius;

-   };

- 

-   return force;

- };

- 

- function index(d) {

-   return d.index;

- }

- 

- function find(nodeById, nodeId) {

-   var node = nodeById.get(nodeId);

-   if (!node) throw new Error("missing: " + nodeId);

-   return node;

- }

- 

- var link = function(links) {

-   var id = index,

-       strength = defaultStrength,

-       strengths,

-       distance = constant$6(30),

-       distances,

-       nodes,

-       count,

-       bias,

-       iterations = 1;

- 

-   if (links == null) links = [];

- 

-   function defaultStrength(link) {

-     return 1 / Math.min(count[link.source.index], count[link.target.index]);

-   }

- 

-   function force(alpha) {

-     for (var k = 0, n = links.length; k < iterations; ++k) {

-       for (var i = 0, link, source, target, x, y, l, b; i < n; ++i) {

-         link = links[i], source = link.source, target = link.target;

-         x = target.x + target.vx - source.x - source.vx || jiggle();

-         y = target.y + target.vy - source.y - source.vy || jiggle();

-         l = Math.sqrt(x * x + y * y);

-         l = (l - distances[i]) / l * alpha * strengths[i];

-         x *= l, y *= l;

-         target.vx -= x * (b = bias[i]);

-         target.vy -= y * b;

-         source.vx += x * (b = 1 - b);

-         source.vy += y * b;

-       }

-     }

-   }

- 

-   function initialize() {

-     if (!nodes) return;

- 

-     var i,

-         n = nodes.length,

-         m = links.length,

-         nodeById = map$1(nodes, id),

-         link;

- 

-     for (i = 0, count = new Array(n); i < m; ++i) {

-       link = links[i], link.index = i;

-       if (typeof link.source !== "object") link.source = find(nodeById, link.source);

-       if (typeof link.target !== "object") link.target = find(nodeById, link.target);

-       count[link.source.index] = (count[link.source.index] || 0) + 1;

-       count[link.target.index] = (count[link.target.index] || 0) + 1;

-     }

- 

-     for (i = 0, bias = new Array(m); i < m; ++i) {

-       link = links[i], bias[i] = count[link.source.index] / (count[link.source.index] + count[link.target.index]);

-     }

- 

-     strengths = new Array(m), initializeStrength();

-     distances = new Array(m), initializeDistance();

-   }

- 

-   function initializeStrength() {

-     if (!nodes) return;

- 

-     for (var i = 0, n = links.length; i < n; ++i) {

-       strengths[i] = +strength(links[i], i, links);

-     }

-   }

- 

-   function initializeDistance() {

-     if (!nodes) return;

- 

-     for (var i = 0, n = links.length; i < n; ++i) {

-       distances[i] = +distance(links[i], i, links);

-     }

-   }

- 

-   force.initialize = function(_) {

-     nodes = _;

-     initialize();

-   };

- 

-   force.links = function(_) {

-     return arguments.length ? (links = _, initialize(), force) : links;

-   };

- 

-   force.id = function(_) {

-     return arguments.length ? (id = _, force) : id;

-   };

- 

-   force.iterations = function(_) {

-     return arguments.length ? (iterations = +_, force) : iterations;

-   };

- 

-   force.strength = function(_) {

-     return arguments.length ? (strength = typeof _ === "function" ? _ : constant$6(+_), initializeStrength(), force) : strength;

-   };

- 

-   force.distance = function(_) {

-     return arguments.length ? (distance = typeof _ === "function" ? _ : constant$6(+_), initializeDistance(), force) : distance;

-   };

- 

-   return force;

- };

- 

- function x$1(d) {

-   return d.x;

- }

- 

- function y$1(d) {

-   return d.y;

- }

- 

- var initialRadius = 10;

- var initialAngle = Math.PI * (3 - Math.sqrt(5));

- 

- var simulation = function(nodes) {

-   var simulation,

-       alpha = 1,

-       alphaMin = 0.001,

-       alphaDecay = 1 - Math.pow(alphaMin, 1 / 300),

-       alphaTarget = 0,

-       velocityDecay = 0.6,

-       forces = map$1(),

-       stepper = timer(step),

-       event = dispatch("tick", "end");

- 

-   if (nodes == null) nodes = [];

- 

-   function step() {

-     tick();

-     event.call("tick", simulation);

-     if (alpha < alphaMin) {

-       stepper.stop();

-       event.call("end", simulation);

-     }

-   }

- 

-   function tick() {

-     var i, n = nodes.length, node;

- 

-     alpha += (alphaTarget - alpha) * alphaDecay;

- 

-     forces.each(function(force) {

-       force(alpha);

-     });

- 

-     for (i = 0; i < n; ++i) {

-       node = nodes[i];

-       if (node.fx == null) node.x += node.vx *= velocityDecay;

-       else node.x = node.fx, node.vx = 0;

-       if (node.fy == null) node.y += node.vy *= velocityDecay;

-       else node.y = node.fy, node.vy = 0;

-     }

-   }

- 

-   function initializeNodes() {

-     for (var i = 0, n = nodes.length, node; i < n; ++i) {

-       node = nodes[i], node.index = i;

-       if (isNaN(node.x) || isNaN(node.y)) {

-         var radius = initialRadius * Math.sqrt(i), angle = i * initialAngle;

-         node.x = radius * Math.cos(angle);

-         node.y = radius * Math.sin(angle);

-       }

-       if (isNaN(node.vx) || isNaN(node.vy)) {

-         node.vx = node.vy = 0;

-       }

-     }

-   }

- 

-   function initializeForce(force) {

-     if (force.initialize) force.initialize(nodes);

-     return force;

-   }

- 

-   initializeNodes();

- 

-   return simulation = {

-     tick: tick,

- 

-     restart: function() {

-       return stepper.restart(step), simulation;

-     },

- 

-     stop: function() {

-       return stepper.stop(), simulation;

-     },

- 

-     nodes: function(_) {

-       return arguments.length ? (nodes = _, initializeNodes(), forces.each(initializeForce), simulation) : nodes;

-     },

- 

-     alpha: function(_) {

-       return arguments.length ? (alpha = +_, simulation) : alpha;

-     },

- 

-     alphaMin: function(_) {

-       return arguments.length ? (alphaMin = +_, simulation) : alphaMin;

-     },

- 

-     alphaDecay: function(_) {

-       return arguments.length ? (alphaDecay = +_, simulation) : +alphaDecay;

-     },

- 

-     alphaTarget: function(_) {

-       return arguments.length ? (alphaTarget = +_, simulation) : alphaTarget;

-     },

- 

-     velocityDecay: function(_) {

-       return arguments.length ? (velocityDecay = 1 - _, simulation) : 1 - velocityDecay;

-     },

- 

-     force: function(name, _) {

-       return arguments.length > 1 ? ((_ == null ? forces.remove(name) : forces.set(name, initializeForce(_))), simulation) : forces.get(name);

-     },

- 

-     find: function(x, y, radius) {

-       var i = 0,

-           n = nodes.length,

-           dx,

-           dy,

-           d2,

-           node,

-           closest;

- 

-       if (radius == null) radius = Infinity;

-       else radius *= radius;

- 

-       for (i = 0; i < n; ++i) {

-         node = nodes[i];

-         dx = x - node.x;

-         dy = y - node.y;

-         d2 = dx * dx + dy * dy;

-         if (d2 < radius) closest = node, radius = d2;

-       }

- 

-       return closest;

-     },

- 

-     on: function(name, _) {

-       return arguments.length > 1 ? (event.on(name, _), simulation) : event.on(name);

-     }

-   };

- };

- 

- var manyBody = function() {

-   var nodes,

-       node,

-       alpha,

-       strength = constant$6(-30),

-       strengths,

-       distanceMin2 = 1,

-       distanceMax2 = Infinity,

-       theta2 = 0.81;

- 

-   function force(_) {

-     var i, n = nodes.length, tree = quadtree(nodes, x$1, y$1).visitAfter(accumulate);

-     for (alpha = _, i = 0; i < n; ++i) node = nodes[i], tree.visit(apply);

-   }

- 

-   function initialize() {

-     if (!nodes) return;

-     var i, n = nodes.length, node;

-     strengths = new Array(n);

-     for (i = 0; i < n; ++i) node = nodes[i], strengths[node.index] = +strength(node, i, nodes);

-   }

- 

-   function accumulate(quad) {

-     var strength = 0, q, c, weight = 0, x, y, i;

- 

-     // For internal nodes, accumulate forces from child quadrants.

-     if (quad.length) {

-       for (x = y = i = 0; i < 4; ++i) {

-         if ((q = quad[i]) && (c = Math.abs(q.value))) {

-           strength += q.value, weight += c, x += c * q.x, y += c * q.y;

-         }

-       }

-       quad.x = x / weight;

-       quad.y = y / weight;

-     }

- 

-     // For leaf nodes, accumulate forces from coincident quadrants.

-     else {

-       q = quad;

-       q.x = q.data.x;

-       q.y = q.data.y;

-       do strength += strengths[q.data.index];

-       while (q = q.next);

-     }

- 

-     quad.value = strength;

-   }

- 

-   function apply(quad, x1, _, x2) {

-     if (!quad.value) return true;

- 

-     var x = quad.x - node.x,

-         y = quad.y - node.y,

-         w = x2 - x1,

-         l = x * x + y * y;

- 

-     // Apply the Barnes-Hut approximation if possible.

-     // Limit forces for very close nodes; randomize direction if coincident.

-     if (w * w / theta2 < l) {

-       if (l < distanceMax2) {

-         if (x === 0) x = jiggle(), l += x * x;

-         if (y === 0) y = jiggle(), l += y * y;

-         if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);

-         node.vx += x * quad.value * alpha / l;

-         node.vy += y * quad.value * alpha / l;

-       }

-       return true;

-     }

- 

-     // Otherwise, process points directly.

-     else if (quad.length || l >= distanceMax2) return;

- 

-     // Limit forces for very close nodes; randomize direction if coincident.

-     if (quad.data !== node || quad.next) {

-       if (x === 0) x = jiggle(), l += x * x;

-       if (y === 0) y = jiggle(), l += y * y;

-       if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);

-     }

- 

-     do if (quad.data !== node) {

-       w = strengths[quad.data.index] * alpha / l;

-       node.vx += x * w;

-       node.vy += y * w;

-     } while (quad = quad.next);

-   }

- 

-   force.initialize = function(_) {

-     nodes = _;

-     initialize();

-   };

- 

-   force.strength = function(_) {

-     return arguments.length ? (strength = typeof _ === "function" ? _ : constant$6(+_), initialize(), force) : strength;

-   };

- 

-   force.distanceMin = function(_) {

-     return arguments.length ? (distanceMin2 = _ * _, force) : Math.sqrt(distanceMin2);

-   };

- 

-   force.distanceMax = function(_) {

-     return arguments.length ? (distanceMax2 = _ * _, force) : Math.sqrt(distanceMax2);

-   };

- 

-   force.theta = function(_) {

-     return arguments.length ? (theta2 = _ * _, force) : Math.sqrt(theta2);

-   };

- 

-   return force;

- };

- 

- var radial = function(radius, x, y) {

-   var nodes,

-       strength = constant$6(0.1),

-       strengths,

-       radiuses;

- 

-   if (typeof radius !== "function") radius = constant$6(+radius);

-   if (x == null) x = 0;

-   if (y == null) y = 0;

- 

-   function force(alpha) {

-     for (var i = 0, n = nodes.length; i < n; ++i) {

-       var node = nodes[i],

-           dx = node.x - x || 1e-6,

-           dy = node.y - y || 1e-6,

-           r = Math.sqrt(dx * dx + dy * dy),

-           k = (radiuses[i] - r) * strengths[i] * alpha / r;

-       node.vx += dx * k;

-       node.vy += dy * k;

-     }

-   }

- 

-   function initialize() {

-     if (!nodes) return;

-     var i, n = nodes.length;

-     strengths = new Array(n);

-     radiuses = new Array(n);

-     for (i = 0; i < n; ++i) {

-       radiuses[i] = +radius(nodes[i], i, nodes);

-       strengths[i] = isNaN(radiuses[i]) ? 0 : +strength(nodes[i], i, nodes);

-     }

-   }

- 

-   force.initialize = function(_) {

-     nodes = _, initialize();

-   };

- 

-   force.strength = function(_) {

-     return arguments.length ? (strength = typeof _ === "function" ? _ : constant$6(+_), initialize(), force) : strength;

-   };

- 

-   force.radius = function(_) {

-     return arguments.length ? (radius = typeof _ === "function" ? _ : constant$6(+_), initialize(), force) : radius;

-   };

- 

-   force.x = function(_) {

-     return arguments.length ? (x = +_, force) : x;

-   };

- 

-   force.y = function(_) {

-     return arguments.length ? (y = +_, force) : y;

-   };

- 

-   return force;

- };

- 

- var x$2 = function(x) {

-   var strength = constant$6(0.1),

-       nodes,

-       strengths,

-       xz;

- 

-   if (typeof x !== "function") x = constant$6(x == null ? 0 : +x);

- 

-   function force(alpha) {

-     for (var i = 0, n = nodes.length, node; i < n; ++i) {

-       node = nodes[i], node.vx += (xz[i] - node.x) * strengths[i] * alpha;

-     }

-   }

- 

-   function initialize() {

-     if (!nodes) return;

-     var i, n = nodes.length;

-     strengths = new Array(n);

-     xz = new Array(n);

-     for (i = 0; i < n; ++i) {

-       strengths[i] = isNaN(xz[i] = +x(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);

-     }

-   }

- 

-   force.initialize = function(_) {

-     nodes = _;

-     initialize();

-   };

- 

-   force.strength = function(_) {

-     return arguments.length ? (strength = typeof _ === "function" ? _ : constant$6(+_), initialize(), force) : strength;

-   };

- 

-   force.x = function(_) {

-     return arguments.length ? (x = typeof _ === "function" ? _ : constant$6(+_), initialize(), force) : x;

-   };

- 

-   return force;

- };

- 

- var y$2 = function(y) {

-   var strength = constant$6(0.1),

-       nodes,

-       strengths,

-       yz;

- 

-   if (typeof y !== "function") y = constant$6(y == null ? 0 : +y);

- 

-   function force(alpha) {

-     for (var i = 0, n = nodes.length, node; i < n; ++i) {

-       node = nodes[i], node.vy += (yz[i] - node.y) * strengths[i] * alpha;

-     }

-   }

- 

-   function initialize() {

-     if (!nodes) return;

-     var i, n = nodes.length;

-     strengths = new Array(n);

-     yz = new Array(n);

-     for (i = 0; i < n; ++i) {

-       strengths[i] = isNaN(yz[i] = +y(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);

-     }

-   }

- 

-   force.initialize = function(_) {

-     nodes = _;

-     initialize();

-   };

- 

-   force.strength = function(_) {

-     return arguments.length ? (strength = typeof _ === "function" ? _ : constant$6(+_), initialize(), force) : strength;

-   };

- 

-   force.y = function(_) {

-     return arguments.length ? (y = typeof _ === "function" ? _ : constant$6(+_), initialize(), force) : y;

-   };

- 

-   return force;

- };

- 

- // Computes the decimal coefficient and exponent of the specified number x with

- // significant digits p, where x is positive and p is in [1, 21] or undefined.

- // For example, formatDecimal(1.23) returns ["123", 0].

- var formatDecimal = function(x, p) {

-   if ((i = (x = p ? x.toExponential(p - 1) : x.toExponential()).indexOf("e")) < 0) return null; // NaN, ±Infinity

-   var i, coefficient = x.slice(0, i);

- 

-   // The string returned by toExponential either has the form \d\.\d+e[-+]\d+

-   // (e.g., 1.2e+3) or the form \de[-+]\d+ (e.g., 1e+3).

-   return [

-     coefficient.length > 1 ? coefficient[0] + coefficient.slice(2) : coefficient,

-     +x.slice(i + 1)

-   ];

- };

- 

- var exponent$1 = function(x) {

-   return x = formatDecimal(Math.abs(x)), x ? x[1] : NaN;

- };

- 

- var formatGroup = function(grouping, thousands) {

-   return function(value, width) {

-     var i = value.length,

-         t = [],

-         j = 0,

-         g = grouping[0],

-         length = 0;

- 

-     while (i > 0 && g > 0) {

-       if (length + g + 1 > width) g = Math.max(1, width - length);

-       t.push(value.substring(i -= g, i + g));

-       if ((length += g + 1) > width) break;

-       g = grouping[j = (j + 1) % grouping.length];

-     }

- 

-     return t.reverse().join(thousands);

-   };

- };

- 

- var formatNumerals = function(numerals) {

-   return function(value) {

-     return value.replace(/[0-9]/g, function(i) {

-       return numerals[+i];

-     });

-   };

- };

- 

- var formatDefault = function(x, p) {

-   x = x.toPrecision(p);

- 

-   out: for (var n = x.length, i = 1, i0 = -1, i1; i < n; ++i) {

-     switch (x[i]) {

-       case ".": i0 = i1 = i; break;

-       case "0": if (i0 === 0) i0 = i; i1 = i; break;

-       case "e": break out;

-       default: if (i0 > 0) i0 = 0; break;

-     }

-   }

- 

-   return i0 > 0 ? x.slice(0, i0) + x.slice(i1 + 1) : x;

- };

- 

- var prefixExponent;

- 

- var formatPrefixAuto = function(x, p) {

-   var d = formatDecimal(x, p);

-   if (!d) return x + "";

-   var coefficient = d[0],

-       exponent = d[1],

-       i = exponent - (prefixExponent = Math.max(-8, Math.min(8, Math.floor(exponent / 3))) * 3) + 1,

-       n = coefficient.length;

-   return i === n ? coefficient

-       : i > n ? coefficient + new Array(i - n + 1).join("0")

-       : i > 0 ? coefficient.slice(0, i) + "." + coefficient.slice(i)

-       : "0." + new Array(1 - i).join("0") + formatDecimal(x, Math.max(0, p + i - 1))[0]; // less than 1y!

- };

- 

- var formatRounded = function(x, p) {

-   var d = formatDecimal(x, p);

-   if (!d) return x + "";

-   var coefficient = d[0],

-       exponent = d[1];

-   return exponent < 0 ? "0." + new Array(-exponent).join("0") + coefficient

-       : coefficient.length > exponent + 1 ? coefficient.slice(0, exponent + 1) + "." + coefficient.slice(exponent + 1)

-       : coefficient + new Array(exponent - coefficient.length + 2).join("0");

- };

- 

- var formatTypes = {

-   "": formatDefault,

-   "%": function(x, p) { return (x * 100).toFixed(p); },

-   "b": function(x) { return Math.round(x).toString(2); },

-   "c": function(x) { return x + ""; },

-   "d": function(x) { return Math.round(x).toString(10); },

-   "e": function(x, p) { return x.toExponential(p); },

-   "f": function(x, p) { return x.toFixed(p); },

-   "g": function(x, p) { return x.toPrecision(p); },

-   "o": function(x) { return Math.round(x).toString(8); },

-   "p": function(x, p) { return formatRounded(x * 100, p); },

-   "r": formatRounded,

-   "s": formatPrefixAuto,

-   "X": function(x) { return Math.round(x).toString(16).toUpperCase(); },

-   "x": function(x) { return Math.round(x).toString(16); }

- };

- 

- // [[fill]align][sign][symbol][0][width][,][.precision][type]

- var re = /^(?:(.)?([<>=^]))?([+\-\( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?([a-z%])?$/i;

- 

- function formatSpecifier(specifier) {

-   return new FormatSpecifier(specifier);

- }

- 

- formatSpecifier.prototype = FormatSpecifier.prototype; // instanceof

- 

- function FormatSpecifier(specifier) {

-   if (!(match = re.exec(specifier))) throw new Error("invalid format: " + specifier);

- 

-   var match,

-       fill = match[1] || " ",

-       align = match[2] || ">",

-       sign = match[3] || "-",

-       symbol = match[4] || "",

-       zero = !!match[5],

-       width = match[6] && +match[6],

-       comma = !!match[7],

-       precision = match[8] && +match[8].slice(1),

-       type = match[9] || "";

- 

-   // The "n" type is an alias for ",g".

-   if (type === "n") comma = true, type = "g";

- 

-   // Map invalid types to the default format.

-   else if (!formatTypes[type]) type = "";

- 

-   // If zero fill is specified, padding goes after sign and before digits.

-   if (zero || (fill === "0" && align === "=")) zero = true, fill = "0", align = "=";

- 

-   this.fill = fill;

-   this.align = align;

-   this.sign = sign;

-   this.symbol = symbol;

-   this.zero = zero;

-   this.width = width;

-   this.comma = comma;

-   this.precision = precision;

-   this.type = type;

- }

- 

- FormatSpecifier.prototype.toString = function() {

-   return this.fill

-       + this.align

-       + this.sign

-       + this.symbol

-       + (this.zero ? "0" : "")

-       + (this.width == null ? "" : Math.max(1, this.width | 0))

-       + (this.comma ? "," : "")

-       + (this.precision == null ? "" : "." + Math.max(0, this.precision | 0))

-       + this.type;

- };

- 

- var identity$3 = function(x) {

-   return x;

- };

- 

- var prefixes = ["y","z","a","f","p","n","\xB5","m","","k","M","G","T","P","E","Z","Y"];

- 

- var formatLocale = function(locale) {

-   var group = locale.grouping && locale.thousands ? formatGroup(locale.grouping, locale.thousands) : identity$3,

-       currency = locale.currency,

-       decimal = locale.decimal,

-       numerals = locale.numerals ? formatNumerals(locale.numerals) : identity$3,

-       percent = locale.percent || "%";

- 

-   function newFormat(specifier) {

-     specifier = formatSpecifier(specifier);

- 

-     var fill = specifier.fill,

-         align = specifier.align,

-         sign = specifier.sign,

-         symbol = specifier.symbol,

-         zero = specifier.zero,

-         width = specifier.width,

-         comma = specifier.comma,

-         precision = specifier.precision,

-         type = specifier.type;

- 

-     // Compute the prefix and suffix.

-     // For SI-prefix, the suffix is lazily computed.

-     var prefix = symbol === "$" ? currency[0] : symbol === "#" && /[boxX]/.test(type) ? "0" + type.toLowerCase() : "",

-         suffix = symbol === "$" ? currency[1] : /[%p]/.test(type) ? percent : "";

- 

-     // What format function should we use?

-     // Is this an integer type?

-     // Can this type generate exponential notation?

-     var formatType = formatTypes[type],

-         maybeSuffix = !type || /[defgprs%]/.test(type);

- 

-     // Set the default precision if not specified,

-     // or clamp the specified precision to the supported range.

-     // For significant precision, it must be in [1, 21].

-     // For fixed precision, it must be in [0, 20].

-     precision = precision == null ? (type ? 6 : 12)

-         : /[gprs]/.test(type) ? Math.max(1, Math.min(21, precision))

-         : Math.max(0, Math.min(20, precision));

- 

-     function format(value) {

-       var valuePrefix = prefix,

-           valueSuffix = suffix,

-           i, n, c;

- 

-       if (type === "c") {

-         valueSuffix = formatType(value) + valueSuffix;

-         value = "";

-       } else {

-         value = +value;

- 

-         // Perform the initial formatting.

-         var valueNegative = value < 0;

-         value = formatType(Math.abs(value), precision);

- 

-         // If a negative value rounds to zero during formatting, treat as positive.

-         if (valueNegative && +value === 0) valueNegative = false;

- 

-         // Compute the prefix and suffix.

-         valuePrefix = (valueNegative ? (sign === "(" ? sign : "-") : sign === "-" || sign === "(" ? "" : sign) + valuePrefix;

-         valueSuffix = valueSuffix + (type === "s" ? prefixes[8 + prefixExponent / 3] : "") + (valueNegative && sign === "(" ? ")" : "");

- 

-         // Break the formatted value into the integer “value” part that can be

-         // grouped, and fractional or exponential “suffix” part that is not.

-         if (maybeSuffix) {

-           i = -1, n = value.length;

-           while (++i < n) {

-             if (c = value.charCodeAt(i), 48 > c || c > 57) {

-               valueSuffix = (c === 46 ? decimal + value.slice(i + 1) : value.slice(i)) + valueSuffix;

-               value = value.slice(0, i);

-               break;

-             }

-           }

-         }

-       }

- 

-       // If the fill character is not "0", grouping is applied before padding.

-       if (comma && !zero) value = group(value, Infinity);

- 

-       // Compute the padding.

-       var length = valuePrefix.length + value.length + valueSuffix.length,

-           padding = length < width ? new Array(width - length + 1).join(fill) : "";

- 

-       // If the fill character is "0", grouping is applied after padding.

-       if (comma && zero) value = group(padding + value, padding.length ? width - valueSuffix.length : Infinity), padding = "";

- 

-       // Reconstruct the final output based on the desired alignment.

-       switch (align) {

-         case "<": value = valuePrefix + value + valueSuffix + padding; break;

-         case "=": value = valuePrefix + padding + value + valueSuffix; break;

-         case "^": value = padding.slice(0, length = padding.length >> 1) + valuePrefix + value + valueSuffix + padding.slice(length); break;

-         default: value = padding + valuePrefix + value + valueSuffix; break;

-       }

- 

-       return numerals(value);

-     }

- 

-     format.toString = function() {

-       return specifier + "";

-     };

- 

-     return format;

-   }

- 

-   function formatPrefix(specifier, value) {

-     var f = newFormat((specifier = formatSpecifier(specifier), specifier.type = "f", specifier)),

-         e = Math.max(-8, Math.min(8, Math.floor(exponent$1(value) / 3))) * 3,

-         k = Math.pow(10, -e),

-         prefix = prefixes[8 + e / 3];

-     return function(value) {

-       return f(k * value) + prefix;

-     };

-   }

- 

-   return {

-     format: newFormat,

-     formatPrefix: formatPrefix

-   };

- };

- 

- var locale;

- 

- 

- 

- defaultLocale({

-   decimal: ".",

-   thousands: ",",

-   grouping: [3],

-   currency: ["$", ""]

- });

- 

- function defaultLocale(definition) {

-   locale = formatLocale(definition);

-   exports.format = locale.format;

-   exports.formatPrefix = locale.formatPrefix;

-   return locale;

- }

- 

- var precisionFixed = function(step) {

-   return Math.max(0, -exponent$1(Math.abs(step)));

- };

- 

- var precisionPrefix = function(step, value) {

-   return Math.max(0, Math.max(-8, Math.min(8, Math.floor(exponent$1(value) / 3))) * 3 - exponent$1(Math.abs(step)));

- };

- 

- var precisionRound = function(step, max) {

-   step = Math.abs(step), max = Math.abs(max) - step;

-   return Math.max(0, exponent$1(max) - exponent$1(step)) + 1;

- };

- 

- // Adds floating point numbers with twice the normal precision.

- // Reference: J. R. Shewchuk, Adaptive Precision Floating-Point Arithmetic and

- // Fast Robust Geometric Predicates, Discrete & Computational Geometry 18(3)

- // 305–363 (1997).

- // Code adapted from GeographicLib by Charles F. F. Karney,

- // http://geographiclib.sourceforge.net/

- 

- var adder = function() {

-   return new Adder;

- };

- 

- function Adder() {

-   this.reset();

- }

- 

- Adder.prototype = {

-   constructor: Adder,

-   reset: function() {

-     this.s = // rounded value

-     this.t = 0; // exact error

-   },

-   add: function(y) {

-     add$1(temp, y, this.t);

-     add$1(this, temp.s, this.s);

-     if (this.s) this.t += temp.t;

-     else this.s = temp.t;

-   },

-   valueOf: function() {

-     return this.s;

-   }

- };

- 

- var temp = new Adder;

- 

- function add$1(adder, a, b) {

-   var x = adder.s = a + b,

-       bv = x - a,

-       av = x - bv;

-   adder.t = (a - av) + (b - bv);

- }

- 

- var epsilon$2 = 1e-6;

- var epsilon2$1 = 1e-12;

- var pi$3 = Math.PI;

- var halfPi$2 = pi$3 / 2;

- var quarterPi = pi$3 / 4;

- var tau$3 = pi$3 * 2;

- 

- var degrees$1 = 180 / pi$3;

- var radians = pi$3 / 180;

- 

- var abs = Math.abs;

- var atan = Math.atan;

- var atan2 = Math.atan2;

- var cos$1 = Math.cos;

- var ceil = Math.ceil;

- var exp = Math.exp;

- 

- var log = Math.log;

- var pow = Math.pow;

- var sin$1 = Math.sin;

- var sign = Math.sign || function(x) { return x > 0 ? 1 : x < 0 ? -1 : 0; };

- var sqrt = Math.sqrt;

- var tan = Math.tan;

- 

- function acos(x) {

-   return x > 1 ? 0 : x < -1 ? pi$3 : Math.acos(x);

- }

- 

- function asin(x) {

-   return x > 1 ? halfPi$2 : x < -1 ? -halfPi$2 : Math.asin(x);

- }

- 

- function haversin(x) {

-   return (x = sin$1(x / 2)) * x;

- }

- 

- function noop$1() {}

- 

- function streamGeometry(geometry, stream) {

-   if (geometry && streamGeometryType.hasOwnProperty(geometry.type)) {

-     streamGeometryType[geometry.type](geometry, stream);

-   }

- }

- 

- var streamObjectType = {

-   Feature: function(object, stream) {

-     streamGeometry(object.geometry, stream);

-   },

-   FeatureCollection: function(object, stream) {

-     var features = object.features, i = -1, n = features.length;

-     while (++i < n) streamGeometry(features[i].geometry, stream);

-   }

- };

- 

- var streamGeometryType = {

-   Sphere: function(object, stream) {

-     stream.sphere();

-   },

-   Point: function(object, stream) {

-     object = object.coordinates;

-     stream.point(object[0], object[1], object[2]);

-   },

-   MultiPoint: function(object, stream) {

-     var coordinates = object.coordinates, i = -1, n = coordinates.length;

-     while (++i < n) object = coordinates[i], stream.point(object[0], object[1], object[2]);

-   },

-   LineString: function(object, stream) {

-     streamLine(object.coordinates, stream, 0);

-   },

-   MultiLineString: function(object, stream) {

-     var coordinates = object.coordinates, i = -1, n = coordinates.length;

-     while (++i < n) streamLine(coordinates[i], stream, 0);

-   },

-   Polygon: function(object, stream) {

-     streamPolygon(object.coordinates, stream);

-   },

-   MultiPolygon: function(object, stream) {

-     var coordinates = object.coordinates, i = -1, n = coordinates.length;

-     while (++i < n) streamPolygon(coordinates[i], stream);

-   },

-   GeometryCollection: function(object, stream) {

-     var geometries = object.geometries, i = -1, n = geometries.length;

-     while (++i < n) streamGeometry(geometries[i], stream);

-   }

- };

- 

- function streamLine(coordinates, stream, closed) {

-   var i = -1, n = coordinates.length - closed, coordinate;

-   stream.lineStart();

-   while (++i < n) coordinate = coordinates[i], stream.point(coordinate[0], coordinate[1], coordinate[2]);

-   stream.lineEnd();

- }

- 

- function streamPolygon(coordinates, stream) {

-   var i = -1, n = coordinates.length;

-   stream.polygonStart();

-   while (++i < n) streamLine(coordinates[i], stream, 1);

-   stream.polygonEnd();

- }

- 

- var geoStream = function(object, stream) {

-   if (object && streamObjectType.hasOwnProperty(object.type)) {

-     streamObjectType[object.type](object, stream);

-   } else {

-     streamGeometry(object, stream);

-   }

- };

- 

- var areaRingSum = adder();

- 

- var areaSum = adder();

- var lambda00;

- var phi00;

- var lambda0;

- var cosPhi0;

- var sinPhi0;

- 

- var areaStream = {

-   point: noop$1,

-   lineStart: noop$1,

-   lineEnd: noop$1,

-   polygonStart: function() {

-     areaRingSum.reset();

-     areaStream.lineStart = areaRingStart;

-     areaStream.lineEnd = areaRingEnd;

-   },

-   polygonEnd: function() {

-     var areaRing = +areaRingSum;

-     areaSum.add(areaRing < 0 ? tau$3 + areaRing : areaRing);

-     this.lineStart = this.lineEnd = this.point = noop$1;

-   },

-   sphere: function() {

-     areaSum.add(tau$3);

-   }

- };

- 

- function areaRingStart() {

-   areaStream.point = areaPointFirst;

- }

- 

- function areaRingEnd() {

-   areaPoint(lambda00, phi00);

- }

- 

- function areaPointFirst(lambda, phi) {

-   areaStream.point = areaPoint;

-   lambda00 = lambda, phi00 = phi;

-   lambda *= radians, phi *= radians;

-   lambda0 = lambda, cosPhi0 = cos$1(phi = phi / 2 + quarterPi), sinPhi0 = sin$1(phi);

- }

- 

- function areaPoint(lambda, phi) {

-   lambda *= radians, phi *= radians;

-   phi = phi / 2 + quarterPi; // half the angular distance from south pole

- 

-   // Spherical excess E for a spherical triangle with vertices: south pole,

-   // previous point, current point.  Uses a formula derived from Cagnoli’s

-   // theorem.  See Todhunter, Spherical Trig. (1871), Sec. 103, Eq. (2).

-   var dLambda = lambda - lambda0,

-       sdLambda = dLambda >= 0 ? 1 : -1,

-       adLambda = sdLambda * dLambda,

-       cosPhi = cos$1(phi),

-       sinPhi = sin$1(phi),

-       k = sinPhi0 * sinPhi,

-       u = cosPhi0 * cosPhi + k * cos$1(adLambda),

-       v = k * sdLambda * sin$1(adLambda);

-   areaRingSum.add(atan2(v, u));

- 

-   // Advance the previous points.

-   lambda0 = lambda, cosPhi0 = cosPhi, sinPhi0 = sinPhi;

- }

- 

- var area = function(object) {

-   areaSum.reset();

-   geoStream(object, areaStream);

-   return areaSum * 2;

- };

- 

- function spherical(cartesian) {

-   return [atan2(cartesian[1], cartesian[0]), asin(cartesian[2])];

- }

- 

- function cartesian(spherical) {

-   var lambda = spherical[0], phi = spherical[1], cosPhi = cos$1(phi);

-   return [cosPhi * cos$1(lambda), cosPhi * sin$1(lambda), sin$1(phi)];

- }

- 

- function cartesianDot(a, b) {

-   return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];

- }

- 

- function cartesianCross(a, b) {

-   return [a[1] * b[2] - a[2] * b[1], a[2] * b[0] - a[0] * b[2], a[0] * b[1] - a[1] * b[0]];

- }

- 

- // TODO return a

- function cartesianAddInPlace(a, b) {

-   a[0] += b[0], a[1] += b[1], a[2] += b[2];

- }

- 

- function cartesianScale(vector, k) {

-   return [vector[0] * k, vector[1] * k, vector[2] * k];

- }

- 

- // TODO return d

- function cartesianNormalizeInPlace(d) {

-   var l = sqrt(d[0] * d[0] + d[1] * d[1] + d[2] * d[2]);

-   d[0] /= l, d[1] /= l, d[2] /= l;

- }

- 

- var lambda0$1;

- var phi0;

- var lambda1;

- var phi1;

- var lambda2;

- var lambda00$1;

- var phi00$1;

- var p0;

- var deltaSum = adder();

- var ranges;

- var range;

- 

- var boundsStream = {

-   point: boundsPoint,

-   lineStart: boundsLineStart,

-   lineEnd: boundsLineEnd,

-   polygonStart: function() {

-     boundsStream.point = boundsRingPoint;

-     boundsStream.lineStart = boundsRingStart;

-     boundsStream.lineEnd = boundsRingEnd;

-     deltaSum.reset();

-     areaStream.polygonStart();

-   },

-   polygonEnd: function() {

-     areaStream.polygonEnd();

-     boundsStream.point = boundsPoint;

-     boundsStream.lineStart = boundsLineStart;

-     boundsStream.lineEnd = boundsLineEnd;

-     if (areaRingSum < 0) lambda0$1 = -(lambda1 = 180), phi0 = -(phi1 = 90);

-     else if (deltaSum > epsilon$2) phi1 = 90;

-     else if (deltaSum < -epsilon$2) phi0 = -90;

-     range[0] = lambda0$1, range[1] = lambda1;

-   }

- };

- 

- function boundsPoint(lambda, phi) {

-   ranges.push(range = [lambda0$1 = lambda, lambda1 = lambda]);

-   if (phi < phi0) phi0 = phi;

-   if (phi > phi1) phi1 = phi;

- }

- 

- function linePoint(lambda, phi) {

-   var p = cartesian([lambda * radians, phi * radians]);

-   if (p0) {

-     var normal = cartesianCross(p0, p),

-         equatorial = [normal[1], -normal[0], 0],

-         inflection = cartesianCross(equatorial, normal);

-     cartesianNormalizeInPlace(inflection);

-     inflection = spherical(inflection);

-     var delta = lambda - lambda2,

-         sign$$1 = delta > 0 ? 1 : -1,

-         lambdai = inflection[0] * degrees$1 * sign$$1,

-         phii,

-         antimeridian = abs(delta) > 180;

-     if (antimeridian ^ (sign$$1 * lambda2 < lambdai && lambdai < sign$$1 * lambda)) {

-       phii = inflection[1] * degrees$1;

-       if (phii > phi1) phi1 = phii;

-     } else if (lambdai = (lambdai + 360) % 360 - 180, antimeridian ^ (sign$$1 * lambda2 < lambdai && lambdai < sign$$1 * lambda)) {

-       phii = -inflection[1] * degrees$1;

-       if (phii < phi0) phi0 = phii;

-     } else {

-       if (phi < phi0) phi0 = phi;

-       if (phi > phi1) phi1 = phi;

-     }

-     if (antimeridian) {

-       if (lambda < lambda2) {

-         if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) lambda1 = lambda;

-       } else {

-         if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) lambda0$1 = lambda;

-       }

-     } else {

-       if (lambda1 >= lambda0$1) {

-         if (lambda < lambda0$1) lambda0$1 = lambda;

-         if (lambda > lambda1) lambda1 = lambda;

-       } else {

-         if (lambda > lambda2) {

-           if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) lambda1 = lambda;

-         } else {

-           if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) lambda0$1 = lambda;

-         }

-       }

-     }

-   } else {

-     ranges.push(range = [lambda0$1 = lambda, lambda1 = lambda]);

-   }

-   if (phi < phi0) phi0 = phi;

-   if (phi > phi1) phi1 = phi;

-   p0 = p, lambda2 = lambda;

- }

- 

- function boundsLineStart() {

-   boundsStream.point = linePoint;

- }

- 

- function boundsLineEnd() {

-   range[0] = lambda0$1, range[1] = lambda1;

-   boundsStream.point = boundsPoint;

-   p0 = null;

- }

- 

- function boundsRingPoint(lambda, phi) {

-   if (p0) {

-     var delta = lambda - lambda2;

-     deltaSum.add(abs(delta) > 180 ? delta + (delta > 0 ? 360 : -360) : delta);

-   } else {

-     lambda00$1 = lambda, phi00$1 = phi;

-   }

-   areaStream.point(lambda, phi);

-   linePoint(lambda, phi);

- }

- 

- function boundsRingStart() {

-   areaStream.lineStart();

- }

- 

- function boundsRingEnd() {

-   boundsRingPoint(lambda00$1, phi00$1);

-   areaStream.lineEnd();

-   if (abs(deltaSum) > epsilon$2) lambda0$1 = -(lambda1 = 180);

-   range[0] = lambda0$1, range[1] = lambda1;

-   p0 = null;

- }

- 

- // Finds the left-right distance between two longitudes.

- // This is almost the same as (lambda1 - lambda0 + 360°) % 360°, except that we want

- // the distance between ±180° to be 360°.

- function angle(lambda0, lambda1) {

-   return (lambda1 -= lambda0) < 0 ? lambda1 + 360 : lambda1;

- }

- 

- function rangeCompare(a, b) {

-   return a[0] - b[0];

- }

- 

- function rangeContains(range, x) {

-   return range[0] <= range[1] ? range[0] <= x && x <= range[1] : x < range[0] || range[1] < x;

- }

- 

- var bounds = function(feature) {

-   var i, n, a, b, merged, deltaMax, delta;

- 

-   phi1 = lambda1 = -(lambda0$1 = phi0 = Infinity);

-   ranges = [];

-   geoStream(feature, boundsStream);

- 

-   // First, sort ranges by their minimum longitudes.

-   if (n = ranges.length) {

-     ranges.sort(rangeCompare);

- 

-     // Then, merge any ranges that overlap.

-     for (i = 1, a = ranges[0], merged = [a]; i < n; ++i) {

-       b = ranges[i];

-       if (rangeContains(a, b[0]) || rangeContains(a, b[1])) {

-         if (angle(a[0], b[1]) > angle(a[0], a[1])) a[1] = b[1];

-         if (angle(b[0], a[1]) > angle(a[0], a[1])) a[0] = b[0];

-       } else {

-         merged.push(a = b);

-       }

-     }

- 

-     // Finally, find the largest gap between the merged ranges.

-     // The final bounding box will be the inverse of this gap.

-     for (deltaMax = -Infinity, n = merged.length - 1, i = 0, a = merged[n]; i <= n; a = b, ++i) {

-       b = merged[i];

-       if ((delta = angle(a[1], b[0])) > deltaMax) deltaMax = delta, lambda0$1 = b[0], lambda1 = a[1];

-     }

-   }

- 

-   ranges = range = null;

- 

-   return lambda0$1 === Infinity || phi0 === Infinity

-       ? [[NaN, NaN], [NaN, NaN]]

-       : [[lambda0$1, phi0], [lambda1, phi1]];

- };

- 

- var W0;

- var W1;

- var X0;

- var Y0;

- var Z0;

- var X1;

- var Y1;

- var Z1;

- var X2;

- var Y2;

- var Z2;

- var lambda00$2;

- var phi00$2;

- var x0;

- var y0;

- var z0; // previous point

- 

- var centroidStream = {

-   sphere: noop$1,

-   point: centroidPoint,

-   lineStart: centroidLineStart,

-   lineEnd: centroidLineEnd,

-   polygonStart: function() {

-     centroidStream.lineStart = centroidRingStart;

-     centroidStream.lineEnd = centroidRingEnd;

-   },

-   polygonEnd: function() {

-     centroidStream.lineStart = centroidLineStart;

-     centroidStream.lineEnd = centroidLineEnd;

-   }

- };

- 

- // Arithmetic mean of Cartesian vectors.

- function centroidPoint(lambda, phi) {

-   lambda *= radians, phi *= radians;

-   var cosPhi = cos$1(phi);

-   centroidPointCartesian(cosPhi * cos$1(lambda), cosPhi * sin$1(lambda), sin$1(phi));

- }

- 

- function centroidPointCartesian(x, y, z) {

-   ++W0;

-   X0 += (x - X0) / W0;

-   Y0 += (y - Y0) / W0;

-   Z0 += (z - Z0) / W0;

- }

- 

- function centroidLineStart() {

-   centroidStream.point = centroidLinePointFirst;

- }

- 

- function centroidLinePointFirst(lambda, phi) {

-   lambda *= radians, phi *= radians;

-   var cosPhi = cos$1(phi);

-   x0 = cosPhi * cos$1(lambda);

-   y0 = cosPhi * sin$1(lambda);

-   z0 = sin$1(phi);

-   centroidStream.point = centroidLinePoint;

-   centroidPointCartesian(x0, y0, z0);

- }

- 

- function centroidLinePoint(lambda, phi) {

-   lambda *= radians, phi *= radians;

-   var cosPhi = cos$1(phi),

-       x = cosPhi * cos$1(lambda),

-       y = cosPhi * sin$1(lambda),

-       z = sin$1(phi),

-       w = atan2(sqrt((w = y0 * z - z0 * y) * w + (w = z0 * x - x0 * z) * w + (w = x0 * y - y0 * x) * w), x0 * x + y0 * y + z0 * z);

-   W1 += w;

-   X1 += w * (x0 + (x0 = x));

-   Y1 += w * (y0 + (y0 = y));

-   Z1 += w * (z0 + (z0 = z));

-   centroidPointCartesian(x0, y0, z0);

- }

- 

- function centroidLineEnd() {

-   centroidStream.point = centroidPoint;

- }

- 

- // See J. E. Brock, The Inertia Tensor for a Spherical Triangle,

- // J. Applied Mechanics 42, 239 (1975).

- function centroidRingStart() {

-   centroidStream.point = centroidRingPointFirst;

- }

- 

- function centroidRingEnd() {

-   centroidRingPoint(lambda00$2, phi00$2);

-   centroidStream.point = centroidPoint;

- }

- 

- function centroidRingPointFirst(lambda, phi) {

-   lambda00$2 = lambda, phi00$2 = phi;

-   lambda *= radians, phi *= radians;

-   centroidStream.point = centroidRingPoint;

-   var cosPhi = cos$1(phi);

-   x0 = cosPhi * cos$1(lambda);

-   y0 = cosPhi * sin$1(lambda);

-   z0 = sin$1(phi);

-   centroidPointCartesian(x0, y0, z0);

- }

- 

- function centroidRingPoint(lambda, phi) {

-   lambda *= radians, phi *= radians;

-   var cosPhi = cos$1(phi),

-       x = cosPhi * cos$1(lambda),

-       y = cosPhi * sin$1(lambda),

-       z = sin$1(phi),

-       cx = y0 * z - z0 * y,

-       cy = z0 * x - x0 * z,

-       cz = x0 * y - y0 * x,

-       m = sqrt(cx * cx + cy * cy + cz * cz),

-       w = asin(m), // line weight = angle

-       v = m && -w / m; // area weight multiplier

-   X2 += v * cx;

-   Y2 += v * cy;

-   Z2 += v * cz;

-   W1 += w;

-   X1 += w * (x0 + (x0 = x));

-   Y1 += w * (y0 + (y0 = y));

-   Z1 += w * (z0 + (z0 = z));

-   centroidPointCartesian(x0, y0, z0);

- }

- 

- var centroid = function(object) {

-   W0 = W1 =

-   X0 = Y0 = Z0 =

-   X1 = Y1 = Z1 =

-   X2 = Y2 = Z2 = 0;

-   geoStream(object, centroidStream);

- 

-   var x = X2,

-       y = Y2,

-       z = Z2,

-       m = x * x + y * y + z * z;

- 

-   // If the area-weighted ccentroid is undefined, fall back to length-weighted ccentroid.

-   if (m < epsilon2$1) {

-     x = X1, y = Y1, z = Z1;

-     // If the feature has zero length, fall back to arithmetic mean of point vectors.

-     if (W1 < epsilon$2) x = X0, y = Y0, z = Z0;

-     m = x * x + y * y + z * z;

-     // If the feature still has an undefined ccentroid, then return.

-     if (m < epsilon2$1) return [NaN, NaN];

-   }

- 

-   return [atan2(y, x) * degrees$1, asin(z / sqrt(m)) * degrees$1];

- };

- 

- var constant$7 = function(x) {

-   return function() {

-     return x;

-   };

- };

- 

- var compose = function(a, b) {

- 

-   function compose(x, y) {

-     return x = a(x, y), b(x[0], x[1]);

-   }

- 

-   if (a.invert && b.invert) compose.invert = function(x, y) {

-     return x = b.invert(x, y), x && a.invert(x[0], x[1]);

-   };

- 

-   return compose;

- };

- 

- function rotationIdentity(lambda, phi) {

-   return [lambda > pi$3 ? lambda - tau$3 : lambda < -pi$3 ? lambda + tau$3 : lambda, phi];

- }

- 

- rotationIdentity.invert = rotationIdentity;

- 

- function rotateRadians(deltaLambda, deltaPhi, deltaGamma) {

-   return (deltaLambda %= tau$3) ? (deltaPhi || deltaGamma ? compose(rotationLambda(deltaLambda), rotationPhiGamma(deltaPhi, deltaGamma))

-     : rotationLambda(deltaLambda))

-     : (deltaPhi || deltaGamma ? rotationPhiGamma(deltaPhi, deltaGamma)

-     : rotationIdentity);

- }

- 

- function forwardRotationLambda(deltaLambda) {

-   return function(lambda, phi) {

-     return lambda += deltaLambda, [lambda > pi$3 ? lambda - tau$3 : lambda < -pi$3 ? lambda + tau$3 : lambda, phi];

-   };

- }

- 

- function rotationLambda(deltaLambda) {

-   var rotation = forwardRotationLambda(deltaLambda);

-   rotation.invert = forwardRotationLambda(-deltaLambda);

-   return rotation;

- }

- 

- function rotationPhiGamma(deltaPhi, deltaGamma) {

-   var cosDeltaPhi = cos$1(deltaPhi),

-       sinDeltaPhi = sin$1(deltaPhi),

-       cosDeltaGamma = cos$1(deltaGamma),

-       sinDeltaGamma = sin$1(deltaGamma);

- 

-   function rotation(lambda, phi) {

-     var cosPhi = cos$1(phi),

-         x = cos$1(lambda) * cosPhi,

-         y = sin$1(lambda) * cosPhi,

-         z = sin$1(phi),

-         k = z * cosDeltaPhi + x * sinDeltaPhi;

-     return [

-       atan2(y * cosDeltaGamma - k * sinDeltaGamma, x * cosDeltaPhi - z * sinDeltaPhi),

-       asin(k * cosDeltaGamma + y * sinDeltaGamma)

-     ];

-   }

- 

-   rotation.invert = function(lambda, phi) {

-     var cosPhi = cos$1(phi),

-         x = cos$1(lambda) * cosPhi,

-         y = sin$1(lambda) * cosPhi,

-         z = sin$1(phi),

-         k = z * cosDeltaGamma - y * sinDeltaGamma;

-     return [

-       atan2(y * cosDeltaGamma + z * sinDeltaGamma, x * cosDeltaPhi + k * sinDeltaPhi),

-       asin(k * cosDeltaPhi - x * sinDeltaPhi)

-     ];

-   };

- 

-   return rotation;

- }

- 

- var rotation = function(rotate) {

-   rotate = rotateRadians(rotate[0] * radians, rotate[1] * radians, rotate.length > 2 ? rotate[2] * radians : 0);

- 

-   function forward(coordinates) {

-     coordinates = rotate(coordinates[0] * radians, coordinates[1] * radians);

-     return coordinates[0] *= degrees$1, coordinates[1] *= degrees$1, coordinates;

-   }

- 

-   forward.invert = function(coordinates) {

-     coordinates = rotate.invert(coordinates[0] * radians, coordinates[1] * radians);

-     return coordinates[0] *= degrees$1, coordinates[1] *= degrees$1, coordinates;

-   };

- 

-   return forward;

- };

- 

- // Generates a circle centered at [0°, 0°], with a given radius and precision.

- function circleStream(stream, radius, delta, direction, t0, t1) {

-   if (!delta) return;

-   var cosRadius = cos$1(radius),

-       sinRadius = sin$1(radius),

-       step = direction * delta;

-   if (t0 == null) {

-     t0 = radius + direction * tau$3;

-     t1 = radius - step / 2;

-   } else {

-     t0 = circleRadius(cosRadius, t0);

-     t1 = circleRadius(cosRadius, t1);

-     if (direction > 0 ? t0 < t1 : t0 > t1) t0 += direction * tau$3;

-   }

-   for (var point, t = t0; direction > 0 ? t > t1 : t < t1; t -= step) {

-     point = spherical([cosRadius, -sinRadius * cos$1(t), -sinRadius * sin$1(t)]);

-     stream.point(point[0], point[1]);

-   }

- }

- 

- // Returns the signed angle of a cartesian point relative to [cosRadius, 0, 0].

- function circleRadius(cosRadius, point) {

-   point = cartesian(point), point[0] -= cosRadius;

-   cartesianNormalizeInPlace(point);

-   var radius = acos(-point[1]);

-   return ((-point[2] < 0 ? -radius : radius) + tau$3 - epsilon$2) % tau$3;

- }

- 

- var circle = function() {

-   var center = constant$7([0, 0]),

-       radius = constant$7(90),

-       precision = constant$7(6),

-       ring,

-       rotate,

-       stream = {point: point};

- 

-   function point(x, y) {

-     ring.push(x = rotate(x, y));

-     x[0] *= degrees$1, x[1] *= degrees$1;

-   }

- 

-   function circle() {

-     var c = center.apply(this, arguments),

-         r = radius.apply(this, arguments) * radians,

-         p = precision.apply(this, arguments) * radians;

-     ring = [];

-     rotate = rotateRadians(-c[0] * radians, -c[1] * radians, 0).invert;

-     circleStream(stream, r, p, 1);

-     c = {type: "Polygon", coordinates: [ring]};

-     ring = rotate = null;

-     return c;

-   }

- 

-   circle.center = function(_) {

-     return arguments.length ? (center = typeof _ === "function" ? _ : constant$7([+_[0], +_[1]]), circle) : center;

-   };

- 

-   circle.radius = function(_) {

-     return arguments.length ? (radius = typeof _ === "function" ? _ : constant$7(+_), circle) : radius;

-   };

- 

-   circle.precision = function(_) {

-     return arguments.length ? (precision = typeof _ === "function" ? _ : constant$7(+_), circle) : precision;

-   };

- 

-   return circle;

- };

- 

- var clipBuffer = function() {

-   var lines = [],

-       line;

-   return {

-     point: function(x, y) {

-       line.push([x, y]);

-     },

-     lineStart: function() {

-       lines.push(line = []);

-     },

-     lineEnd: noop$1,

-     rejoin: function() {

-       if (lines.length > 1) lines.push(lines.pop().concat(lines.shift()));

-     },

-     result: function() {

-       var result = lines;

-       lines = [];

-       line = null;

-       return result;

-     }

-   };

- };

- 

- var pointEqual = function(a, b) {

-   return abs(a[0] - b[0]) < epsilon$2 && abs(a[1] - b[1]) < epsilon$2;

- };

- 

- function Intersection(point, points, other, entry) {

-   this.x = point;

-   this.z = points;

-   this.o = other; // another intersection

-   this.e = entry; // is an entry?

-   this.v = false; // visited

-   this.n = this.p = null; // next & previous

- }

- 

- // A generalized polygon clipping algorithm: given a polygon that has been cut

- // into its visible line segments, and rejoins the segments by interpolating

- // along the clip edge.

- var clipRejoin = function(segments, compareIntersection, startInside, interpolate, stream) {

-   var subject = [],

-       clip = [],

-       i,

-       n;

- 

-   segments.forEach(function(segment) {

-     if ((n = segment.length - 1) <= 0) return;

-     var n, p0 = segment[0], p1 = segment[n], x;

- 

-     // If the first and last points of a segment are coincident, then treat as a

-     // closed ring. TODO if all rings are closed, then the winding order of the

-     // exterior ring should be checked.

-     if (pointEqual(p0, p1)) {

-       stream.lineStart();

-       for (i = 0; i < n; ++i) stream.point((p0 = segment[i])[0], p0[1]);

-       stream.lineEnd();

-       return;

-     }

- 

-     subject.push(x = new Intersection(p0, segment, null, true));

-     clip.push(x.o = new Intersection(p0, null, x, false));

-     subject.push(x = new Intersection(p1, segment, null, false));

-     clip.push(x.o = new Intersection(p1, null, x, true));

-   });

- 

-   if (!subject.length) return;

- 

-   clip.sort(compareIntersection);

-   link$1(subject);

-   link$1(clip);

- 

-   for (i = 0, n = clip.length; i < n; ++i) {

-     clip[i].e = startInside = !startInside;

-   }

- 

-   var start = subject[0],

-       points,

-       point;

- 

-   while (1) {

-     // Find first unvisited intersection.

-     var current = start,

-         isSubject = true;

-     while (current.v) if ((current = current.n) === start) return;

-     points = current.z;

-     stream.lineStart();

-     do {

-       current.v = current.o.v = true;

-       if (current.e) {

-         if (isSubject) {

-           for (i = 0, n = points.length; i < n; ++i) stream.point((point = points[i])[0], point[1]);

-         } else {

-           interpolate(current.x, current.n.x, 1, stream);

-         }

-         current = current.n;

-       } else {

-         if (isSubject) {

-           points = current.p.z;

-           for (i = points.length - 1; i >= 0; --i) stream.point((point = points[i])[0], point[1]);

-         } else {

-           interpolate(current.x, current.p.x, -1, stream);

-         }

-         current = current.p;

-       }

-       current = current.o;

-       points = current.z;

-       isSubject = !isSubject;

-     } while (!current.v);

-     stream.lineEnd();

-   }

- };

- 

- function link$1(array) {

-   if (!(n = array.length)) return;

-   var n,

-       i = 0,

-       a = array[0],

-       b;

-   while (++i < n) {

-     a.n = b = array[i];

-     b.p = a;

-     a = b;

-   }

-   a.n = b = array[0];

-   b.p = a;

- }

- 

- var sum$1 = adder();

- 

- var polygonContains = function(polygon, point) {

-   var lambda = point[0],

-       phi = point[1],

-       normal = [sin$1(lambda), -cos$1(lambda), 0],

-       angle = 0,

-       winding = 0;

- 

-   sum$1.reset();

- 

-   for (var i = 0, n = polygon.length; i < n; ++i) {

-     if (!(m = (ring = polygon[i]).length)) continue;

-     var ring,

-         m,

-         point0 = ring[m - 1],

-         lambda0 = point0[0],

-         phi0 = point0[1] / 2 + quarterPi,

-         sinPhi0 = sin$1(phi0),

-         cosPhi0 = cos$1(phi0);

- 

-     for (var j = 0; j < m; ++j, lambda0 = lambda1, sinPhi0 = sinPhi1, cosPhi0 = cosPhi1, point0 = point1) {

-       var point1 = ring[j],

-           lambda1 = point1[0],

-           phi1 = point1[1] / 2 + quarterPi,

-           sinPhi1 = sin$1(phi1),

-           cosPhi1 = cos$1(phi1),

-           delta = lambda1 - lambda0,

-           sign$$1 = delta >= 0 ? 1 : -1,

-           absDelta = sign$$1 * delta,

-           antimeridian = absDelta > pi$3,

-           k = sinPhi0 * sinPhi1;

- 

-       sum$1.add(atan2(k * sign$$1 * sin$1(absDelta), cosPhi0 * cosPhi1 + k * cos$1(absDelta)));

-       angle += antimeridian ? delta + sign$$1 * tau$3 : delta;

- 

-       // Are the longitudes either side of the point’s meridian (lambda),

-       // and are the latitudes smaller than the parallel (phi)?

-       if (antimeridian ^ lambda0 >= lambda ^ lambda1 >= lambda) {

-         var arc = cartesianCross(cartesian(point0), cartesian(point1));

-         cartesianNormalizeInPlace(arc);

-         var intersection = cartesianCross(normal, arc);

-         cartesianNormalizeInPlace(intersection);

-         var phiArc = (antimeridian ^ delta >= 0 ? -1 : 1) * asin(intersection[2]);

-         if (phi > phiArc || phi === phiArc && (arc[0] || arc[1])) {

-           winding += antimeridian ^ delta >= 0 ? 1 : -1;

-         }

-       }

-     }

-   }

- 

-   // First, determine whether the South pole is inside or outside:

-   //

-   // It is inside if:

-   // * the polygon winds around it in a clockwise direction.

-   // * the polygon does not (cumulatively) wind around it, but has a negative

-   //   (counter-clockwise) area.

-   //

-   // Second, count the (signed) number of times a segment crosses a lambda

-   // from the point to the South pole.  If it is zero, then the point is the

-   // same side as the South pole.

- 

-   return (angle < -epsilon$2 || angle < epsilon$2 && sum$1 < -epsilon$2) ^ (winding & 1);

- };

- 

- var clip = function(pointVisible, clipLine, interpolate, start) {

-   return function(sink) {

-     var line = clipLine(sink),

-         ringBuffer = clipBuffer(),

-         ringSink = clipLine(ringBuffer),

-         polygonStarted = false,

-         polygon,

-         segments,

-         ring;

- 

-     var clip = {

-       point: point,

-       lineStart: lineStart,

-       lineEnd: lineEnd,

-       polygonStart: function() {

-         clip.point = pointRing;

-         clip.lineStart = ringStart;

-         clip.lineEnd = ringEnd;

-         segments = [];

-         polygon = [];

-       },

-       polygonEnd: function() {

-         clip.point = point;

-         clip.lineStart = lineStart;

-         clip.lineEnd = lineEnd;

-         segments = merge(segments);

-         var startInside = polygonContains(polygon, start);

-         if (segments.length) {

-           if (!polygonStarted) sink.polygonStart(), polygonStarted = true;

-           clipRejoin(segments, compareIntersection, startInside, interpolate, sink);

-         } else if (startInside) {

-           if (!polygonStarted) sink.polygonStart(), polygonStarted = true;

-           sink.lineStart();

-           interpolate(null, null, 1, sink);

-           sink.lineEnd();

-         }

-         if (polygonStarted) sink.polygonEnd(), polygonStarted = false;

-         segments = polygon = null;

-       },

-       sphere: function() {

-         sink.polygonStart();

-         sink.lineStart();

-         interpolate(null, null, 1, sink);

-         sink.lineEnd();

-         sink.polygonEnd();

-       }

-     };

- 

-     function point(lambda, phi) {

-       if (pointVisible(lambda, phi)) sink.point(lambda, phi);

-     }

- 

-     function pointLine(lambda, phi) {

-       line.point(lambda, phi);

-     }

- 

-     function lineStart() {

-       clip.point = pointLine;

-       line.lineStart();

-     }

- 

-     function lineEnd() {

-       clip.point = point;

-       line.lineEnd();

-     }

- 

-     function pointRing(lambda, phi) {

-       ring.push([lambda, phi]);

-       ringSink.point(lambda, phi);

-     }

- 

-     function ringStart() {

-       ringSink.lineStart();

-       ring = [];

-     }

- 

-     function ringEnd() {

-       pointRing(ring[0][0], ring[0][1]);

-       ringSink.lineEnd();

- 

-       var clean = ringSink.clean(),

-           ringSegments = ringBuffer.result(),

-           i, n = ringSegments.length, m,

-           segment,

-           point;

- 

-       ring.pop();

-       polygon.push(ring);

-       ring = null;

- 

-       if (!n) return;

- 

-       // No intersections.

-       if (clean & 1) {

-         segment = ringSegments[0];

-         if ((m = segment.length - 1) > 0) {

-           if (!polygonStarted) sink.polygonStart(), polygonStarted = true;

-           sink.lineStart();

-           for (i = 0; i < m; ++i) sink.point((point = segment[i])[0], point[1]);

-           sink.lineEnd();

-         }

-         return;

-       }

- 

-       // Rejoin connected segments.

-       // TODO reuse ringBuffer.rejoin()?

-       if (n > 1 && clean & 2) ringSegments.push(ringSegments.pop().concat(ringSegments.shift()));

- 

-       segments.push(ringSegments.filter(validSegment));

-     }

- 

-     return clip;

-   };

- };

- 

- function validSegment(segment) {

-   return segment.length > 1;

- }

- 

- // Intersections are sorted along the clip edge. For both antimeridian cutting

- // and circle clipping, the same comparison is used.

- function compareIntersection(a, b) {

-   return ((a = a.x)[0] < 0 ? a[1] - halfPi$2 - epsilon$2 : halfPi$2 - a[1])

-        - ((b = b.x)[0] < 0 ? b[1] - halfPi$2 - epsilon$2 : halfPi$2 - b[1]);

- }

- 

- var clipAntimeridian = clip(

-   function() { return true; },

-   clipAntimeridianLine,

-   clipAntimeridianInterpolate,

-   [-pi$3, -halfPi$2]

- );

- 

- // Takes a line and cuts into visible segments. Return values: 0 - there were

- // intersections or the line was empty; 1 - no intersections; 2 - there were

- // intersections, and the first and last segments should be rejoined.

- function clipAntimeridianLine(stream) {

-   var lambda0 = NaN,

-       phi0 = NaN,

-       sign0 = NaN,

-       clean; // no intersections

- 

-   return {

-     lineStart: function() {

-       stream.lineStart();

-       clean = 1;

-     },

-     point: function(lambda1, phi1) {

-       var sign1 = lambda1 > 0 ? pi$3 : -pi$3,

-           delta = abs(lambda1 - lambda0);

-       if (abs(delta - pi$3) < epsilon$2) { // line crosses a pole

-         stream.point(lambda0, phi0 = (phi0 + phi1) / 2 > 0 ? halfPi$2 : -halfPi$2);

-         stream.point(sign0, phi0);

-         stream.lineEnd();

-         stream.lineStart();

-         stream.point(sign1, phi0);

-         stream.point(lambda1, phi0);

-         clean = 0;

-       } else if (sign0 !== sign1 && delta >= pi$3) { // line crosses antimeridian

-         if (abs(lambda0 - sign0) < epsilon$2) lambda0 -= sign0 * epsilon$2; // handle degeneracies

-         if (abs(lambda1 - sign1) < epsilon$2) lambda1 -= sign1 * epsilon$2;

-         phi0 = clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1);

-         stream.point(sign0, phi0);

-         stream.lineEnd();

-         stream.lineStart();

-         stream.point(sign1, phi0);

-         clean = 0;

-       }

-       stream.point(lambda0 = lambda1, phi0 = phi1);

-       sign0 = sign1;

-     },

-     lineEnd: function() {

-       stream.lineEnd();

-       lambda0 = phi0 = NaN;

-     },

-     clean: function() {

-       return 2 - clean; // if intersections, rejoin first and last segments

-     }

-   };

- }

- 

- function clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1) {

-   var cosPhi0,

-       cosPhi1,

-       sinLambda0Lambda1 = sin$1(lambda0 - lambda1);

-   return abs(sinLambda0Lambda1) > epsilon$2

-       ? atan((sin$1(phi0) * (cosPhi1 = cos$1(phi1)) * sin$1(lambda1)

-           - sin$1(phi1) * (cosPhi0 = cos$1(phi0)) * sin$1(lambda0))

-           / (cosPhi0 * cosPhi1 * sinLambda0Lambda1))

-       : (phi0 + phi1) / 2;

- }

- 

- function clipAntimeridianInterpolate(from, to, direction, stream) {

-   var phi;

-   if (from == null) {

-     phi = direction * halfPi$2;

-     stream.point(-pi$3, phi);

-     stream.point(0, phi);

-     stream.point(pi$3, phi);

-     stream.point(pi$3, 0);

-     stream.point(pi$3, -phi);

-     stream.point(0, -phi);

-     stream.point(-pi$3, -phi);

-     stream.point(-pi$3, 0);

-     stream.point(-pi$3, phi);

-   } else if (abs(from[0] - to[0]) > epsilon$2) {

-     var lambda = from[0] < to[0] ? pi$3 : -pi$3;

-     phi = direction * lambda / 2;

-     stream.point(-lambda, phi);

-     stream.point(0, phi);

-     stream.point(lambda, phi);

-   } else {

-     stream.point(to[0], to[1]);

-   }

- }

- 

- var clipCircle = function(radius) {

-   var cr = cos$1(radius),

-       delta = 6 * radians,

-       smallRadius = cr > 0,

-       notHemisphere = abs(cr) > epsilon$2; // TODO optimise for this common case

- 

-   function interpolate(from, to, direction, stream) {

-     circleStream(stream, radius, delta, direction, from, to);

-   }

- 

-   function visible(lambda, phi) {

-     return cos$1(lambda) * cos$1(phi) > cr;

-   }

- 

-   // Takes a line and cuts into visible segments. Return values used for polygon

-   // clipping: 0 - there were intersections or the line was empty; 1 - no

-   // intersections 2 - there were intersections, and the first and last segments

-   // should be rejoined.

-   function clipLine(stream) {

-     var point0, // previous point

-         c0, // code for previous point

-         v0, // visibility of previous point

-         v00, // visibility of first point

-         clean; // no intersections

-     return {

-       lineStart: function() {

-         v00 = v0 = false;

-         clean = 1;

-       },

-       point: function(lambda, phi) {

-         var point1 = [lambda, phi],

-             point2,

-             v = visible(lambda, phi),

-             c = smallRadius

-               ? v ? 0 : code(lambda, phi)

-               : v ? code(lambda + (lambda < 0 ? pi$3 : -pi$3), phi) : 0;

-         if (!point0 && (v00 = v0 = v)) stream.lineStart();

-         // Handle degeneracies.

-         // TODO ignore if not clipping polygons.

-         if (v !== v0) {

-           point2 = intersect(point0, point1);

-           if (!point2 || pointEqual(point0, point2) || pointEqual(point1, point2)) {

-             point1[0] += epsilon$2;

-             point1[1] += epsilon$2;

-             v = visible(point1[0], point1[1]);

-           }

-         }

-         if (v !== v0) {

-           clean = 0;

-           if (v) {

-             // outside going in

-             stream.lineStart();

-             point2 = intersect(point1, point0);

-             stream.point(point2[0], point2[1]);

-           } else {

-             // inside going out

-             point2 = intersect(point0, point1);

-             stream.point(point2[0], point2[1]);

-             stream.lineEnd();

-           }

-           point0 = point2;

-         } else if (notHemisphere && point0 && smallRadius ^ v) {

-           var t;

-           // If the codes for two points are different, or are both zero,

-           // and there this segment intersects with the small circle.

-           if (!(c & c0) && (t = intersect(point1, point0, true))) {

-             clean = 0;

-             if (smallRadius) {

-               stream.lineStart();

-               stream.point(t[0][0], t[0][1]);

-               stream.point(t[1][0], t[1][1]);

-               stream.lineEnd();

-             } else {

-               stream.point(t[1][0], t[1][1]);

-               stream.lineEnd();

-               stream.lineStart();

-               stream.point(t[0][0], t[0][1]);

-             }

-           }

-         }

-         if (v && (!point0 || !pointEqual(point0, point1))) {

-           stream.point(point1[0], point1[1]);

-         }

-         point0 = point1, v0 = v, c0 = c;

-       },

-       lineEnd: function() {

-         if (v0) stream.lineEnd();

-         point0 = null;

-       },

-       // Rejoin first and last segments if there were intersections and the first

-       // and last points were visible.

-       clean: function() {

-         return clean | ((v00 && v0) << 1);

-       }

-     };

-   }

- 

-   // Intersects the great circle between a and b with the clip circle.

-   function intersect(a, b, two) {

-     var pa = cartesian(a),

-         pb = cartesian(b);

- 

-     // We have two planes, n1.p = d1 and n2.p = d2.

-     // Find intersection line p(t) = c1 n1 + c2 n2 + t (n1 ⨯ n2).

-     var n1 = [1, 0, 0], // normal

-         n2 = cartesianCross(pa, pb),

-         n2n2 = cartesianDot(n2, n2),

-         n1n2 = n2[0], // cartesianDot(n1, n2),

-         determinant = n2n2 - n1n2 * n1n2;

- 

-     // Two polar points.

-     if (!determinant) return !two && a;

- 

-     var c1 =  cr * n2n2 / determinant,

-         c2 = -cr * n1n2 / determinant,

-         n1xn2 = cartesianCross(n1, n2),

-         A = cartesianScale(n1, c1),

-         B = cartesianScale(n2, c2);

-     cartesianAddInPlace(A, B);

- 

-     // Solve |p(t)|^2 = 1.

-     var u = n1xn2,

-         w = cartesianDot(A, u),

-         uu = cartesianDot(u, u),

-         t2 = w * w - uu * (cartesianDot(A, A) - 1);

- 

-     if (t2 < 0) return;

- 

-     var t = sqrt(t2),

-         q = cartesianScale(u, (-w - t) / uu);

-     cartesianAddInPlace(q, A);

-     q = spherical(q);

- 

-     if (!two) return q;

- 

-     // Two intersection points.

-     var lambda0 = a[0],

-         lambda1 = b[0],

-         phi0 = a[1],

-         phi1 = b[1],

-         z;

- 

-     if (lambda1 < lambda0) z = lambda0, lambda0 = lambda1, lambda1 = z;

- 

-     var delta = lambda1 - lambda0,

-         polar = abs(delta - pi$3) < epsilon$2,

-         meridian = polar || delta < epsilon$2;

- 

-     if (!polar && phi1 < phi0) z = phi0, phi0 = phi1, phi1 = z;

- 

-     // Check that the first point is between a and b.

-     if (meridian

-         ? polar

-           ? phi0 + phi1 > 0 ^ q[1] < (abs(q[0] - lambda0) < epsilon$2 ? phi0 : phi1)

-           : phi0 <= q[1] && q[1] <= phi1

-         : delta > pi$3 ^ (lambda0 <= q[0] && q[0] <= lambda1)) {

-       var q1 = cartesianScale(u, (-w + t) / uu);

-       cartesianAddInPlace(q1, A);

-       return [q, spherical(q1)];

-     }

-   }

- 

-   // Generates a 4-bit vector representing the location of a point relative to

-   // the small circle's bounding box.

-   function code(lambda, phi) {

-     var r = smallRadius ? radius : pi$3 - radius,

-         code = 0;

-     if (lambda < -r) code |= 1; // left

-     else if (lambda > r) code |= 2; // right

-     if (phi < -r) code |= 4; // below

-     else if (phi > r) code |= 8; // above

-     return code;

-   }

- 

-   return clip(visible, clipLine, interpolate, smallRadius ? [0, -radius] : [-pi$3, radius - pi$3]);

- };

- 

- var clipLine = function(a, b, x0, y0, x1, y1) {

-   var ax = a[0],

-       ay = a[1],

-       bx = b[0],

-       by = b[1],

-       t0 = 0,

-       t1 = 1,

-       dx = bx - ax,

-       dy = by - ay,

-       r;

- 

-   r = x0 - ax;

-   if (!dx && r > 0) return;

-   r /= dx;

-   if (dx < 0) {

-     if (r < t0) return;

-     if (r < t1) t1 = r;

-   } else if (dx > 0) {

-     if (r > t1) return;

-     if (r > t0) t0 = r;

-   }

- 

-   r = x1 - ax;

-   if (!dx && r < 0) return;

-   r /= dx;

-   if (dx < 0) {

-     if (r > t1) return;

-     if (r > t0) t0 = r;

-   } else if (dx > 0) {

-     if (r < t0) return;

-     if (r < t1) t1 = r;

-   }

- 

-   r = y0 - ay;

-   if (!dy && r > 0) return;

-   r /= dy;

-   if (dy < 0) {

-     if (r < t0) return;

-     if (r < t1) t1 = r;

-   } else if (dy > 0) {

-     if (r > t1) return;

-     if (r > t0) t0 = r;

-   }

- 

-   r = y1 - ay;

-   if (!dy && r < 0) return;

-   r /= dy;

-   if (dy < 0) {

-     if (r > t1) return;

-     if (r > t0) t0 = r;

-   } else if (dy > 0) {

-     if (r < t0) return;

-     if (r < t1) t1 = r;

-   }

- 

-   if (t0 > 0) a[0] = ax + t0 * dx, a[1] = ay + t0 * dy;

-   if (t1 < 1) b[0] = ax + t1 * dx, b[1] = ay + t1 * dy;

-   return true;

- };

- 

- var clipMax = 1e9;

- var clipMin = -clipMax;

- 

- // TODO Use d3-polygon’s polygonContains here for the ring check?

- // TODO Eliminate duplicate buffering in clipBuffer and polygon.push?

- 

- function clipRectangle(x0, y0, x1, y1) {

- 

-   function visible(x, y) {

-     return x0 <= x && x <= x1 && y0 <= y && y <= y1;

-   }

- 

-   function interpolate(from, to, direction, stream) {

-     var a = 0, a1 = 0;

-     if (from == null

-         || (a = corner(from, direction)) !== (a1 = corner(to, direction))

-         || comparePoint(from, to) < 0 ^ direction > 0) {

-       do stream.point(a === 0 || a === 3 ? x0 : x1, a > 1 ? y1 : y0);

-       while ((a = (a + direction + 4) % 4) !== a1);

-     } else {

-       stream.point(to[0], to[1]);

-     }

-   }

- 

-   function corner(p, direction) {

-     return abs(p[0] - x0) < epsilon$2 ? direction > 0 ? 0 : 3

-         : abs(p[0] - x1) < epsilon$2 ? direction > 0 ? 2 : 1

-         : abs(p[1] - y0) < epsilon$2 ? direction > 0 ? 1 : 0

-         : direction > 0 ? 3 : 2; // abs(p[1] - y1) < epsilon

-   }

- 

-   function compareIntersection(a, b) {

-     return comparePoint(a.x, b.x);

-   }

- 

-   function comparePoint(a, b) {

-     var ca = corner(a, 1),

-         cb = corner(b, 1);

-     return ca !== cb ? ca - cb

-         : ca === 0 ? b[1] - a[1]

-         : ca === 1 ? a[0] - b[0]

-         : ca === 2 ? a[1] - b[1]

-         : b[0] - a[0];

-   }

- 

-   return function(stream) {

-     var activeStream = stream,

-         bufferStream = clipBuffer(),

-         segments,

-         polygon,

-         ring,

-         x__, y__, v__, // first point

-         x_, y_, v_, // previous point

-         first,

-         clean;

- 

-     var clipStream = {

-       point: point,

-       lineStart: lineStart,

-       lineEnd: lineEnd,

-       polygonStart: polygonStart,

-       polygonEnd: polygonEnd

-     };

- 

-     function point(x, y) {

-       if (visible(x, y)) activeStream.point(x, y);

-     }

- 

-     function polygonInside() {

-       var winding = 0;

- 

-       for (var i = 0, n = polygon.length; i < n; ++i) {

-         for (var ring = polygon[i], j = 1, m = ring.length, point = ring[0], a0, a1, b0 = point[0], b1 = point[1]; j < m; ++j) {

-           a0 = b0, a1 = b1, point = ring[j], b0 = point[0], b1 = point[1];

-           if (a1 <= y1) { if (b1 > y1 && (b0 - a0) * (y1 - a1) > (b1 - a1) * (x0 - a0)) ++winding; }

-           else { if (b1 <= y1 && (b0 - a0) * (y1 - a1) < (b1 - a1) * (x0 - a0)) --winding; }

-         }

-       }

- 

-       return winding;

-     }

- 

-     // Buffer geometry within a polygon and then clip it en masse.

-     function polygonStart() {

-       activeStream = bufferStream, segments = [], polygon = [], clean = true;

-     }

- 

-     function polygonEnd() {

-       var startInside = polygonInside(),

-           cleanInside = clean && startInside,

-           visible = (segments = merge(segments)).length;

-       if (cleanInside || visible) {

-         stream.polygonStart();

-         if (cleanInside) {

-           stream.lineStart();

-           interpolate(null, null, 1, stream);

-           stream.lineEnd();

-         }

-         if (visible) {

-           clipRejoin(segments, compareIntersection, startInside, interpolate, stream);

-         }

-         stream.polygonEnd();

-       }

-       activeStream = stream, segments = polygon = ring = null;

-     }

- 

-     function lineStart() {

-       clipStream.point = linePoint;

-       if (polygon) polygon.push(ring = []);

-       first = true;

-       v_ = false;

-       x_ = y_ = NaN;

-     }

- 

-     // TODO rather than special-case polygons, simply handle them separately.

-     // Ideally, coincident intersection points should be jittered to avoid

-     // clipping issues.

-     function lineEnd() {

-       if (segments) {

-         linePoint(x__, y__);

-         if (v__ && v_) bufferStream.rejoin();

-         segments.push(bufferStream.result());

-       }

-       clipStream.point = point;

-       if (v_) activeStream.lineEnd();

-     }

- 

-     function linePoint(x, y) {

-       var v = visible(x, y);

-       if (polygon) ring.push([x, y]);

-       if (first) {

-         x__ = x, y__ = y, v__ = v;

-         first = false;

-         if (v) {

-           activeStream.lineStart();

-           activeStream.point(x, y);

-         }

-       } else {

-         if (v && v_) activeStream.point(x, y);

-         else {

-           var a = [x_ = Math.max(clipMin, Math.min(clipMax, x_)), y_ = Math.max(clipMin, Math.min(clipMax, y_))],

-               b = [x = Math.max(clipMin, Math.min(clipMax, x)), y = Math.max(clipMin, Math.min(clipMax, y))];

-           if (clipLine(a, b, x0, y0, x1, y1)) {

-             if (!v_) {

-               activeStream.lineStart();

-               activeStream.point(a[0], a[1]);

-             }

-             activeStream.point(b[0], b[1]);

-             if (!v) activeStream.lineEnd();

-             clean = false;

-           } else if (v) {

-             activeStream.lineStart();

-             activeStream.point(x, y);

-             clean = false;

-           }

-         }

-       }

-       x_ = x, y_ = y, v_ = v;

-     }

- 

-     return clipStream;

-   };

- }

- 

- var extent$1 = function() {

-   var x0 = 0,

-       y0 = 0,

-       x1 = 960,

-       y1 = 500,

-       cache,

-       cacheStream,

-       clip;

- 

-   return clip = {

-     stream: function(stream) {

-       return cache && cacheStream === stream ? cache : cache = clipRectangle(x0, y0, x1, y1)(cacheStream = stream);

-     },

-     extent: function(_) {

-       return arguments.length ? (x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1], cache = cacheStream = null, clip) : [[x0, y0], [x1, y1]];

-     }

-   };

- };

- 

- var lengthSum = adder();

- var lambda0$2;

- var sinPhi0$1;

- var cosPhi0$1;

- 

- var lengthStream = {

-   sphere: noop$1,

-   point: noop$1,

-   lineStart: lengthLineStart,

-   lineEnd: noop$1,

-   polygonStart: noop$1,

-   polygonEnd: noop$1

- };

- 

- function lengthLineStart() {

-   lengthStream.point = lengthPointFirst;

-   lengthStream.lineEnd = lengthLineEnd;

- }

- 

- function lengthLineEnd() {

-   lengthStream.point = lengthStream.lineEnd = noop$1;

- }

- 

- function lengthPointFirst(lambda, phi) {

-   lambda *= radians, phi *= radians;

-   lambda0$2 = lambda, sinPhi0$1 = sin$1(phi), cosPhi0$1 = cos$1(phi);

-   lengthStream.point = lengthPoint;

- }

- 

- function lengthPoint(lambda, phi) {

-   lambda *= radians, phi *= radians;

-   var sinPhi = sin$1(phi),

-       cosPhi = cos$1(phi),

-       delta = abs(lambda - lambda0$2),

-       cosDelta = cos$1(delta),

-       sinDelta = sin$1(delta),

-       x = cosPhi * sinDelta,

-       y = cosPhi0$1 * sinPhi - sinPhi0$1 * cosPhi * cosDelta,

-       z = sinPhi0$1 * sinPhi + cosPhi0$1 * cosPhi * cosDelta;

-   lengthSum.add(atan2(sqrt(x * x + y * y), z));

-   lambda0$2 = lambda, sinPhi0$1 = sinPhi, cosPhi0$1 = cosPhi;

- }

- 

- var length$1 = function(object) {

-   lengthSum.reset();

-   geoStream(object, lengthStream);

-   return +lengthSum;

- };

- 

- var coordinates = [null, null];

- var object$1 = {type: "LineString", coordinates: coordinates};

- 

- var distance = function(a, b) {

-   coordinates[0] = a;

-   coordinates[1] = b;

-   return length$1(object$1);

- };

- 

- var containsObjectType = {

-   Feature: function(object, point) {

-     return containsGeometry(object.geometry, point);

-   },

-   FeatureCollection: function(object, point) {

-     var features = object.features, i = -1, n = features.length;

-     while (++i < n) if (containsGeometry(features[i].geometry, point)) return true;

-     return false;

-   }

- };

- 

- var containsGeometryType = {

-   Sphere: function() {

-     return true;

-   },

-   Point: function(object, point) {

-     return containsPoint(object.coordinates, point);

-   },

-   MultiPoint: function(object, point) {

-     var coordinates = object.coordinates, i = -1, n = coordinates.length;

-     while (++i < n) if (containsPoint(coordinates[i], point)) return true;

-     return false;

-   },

-   LineString: function(object, point) {

-     return containsLine(object.coordinates, point);

-   },

-   MultiLineString: function(object, point) {

-     var coordinates = object.coordinates, i = -1, n = coordinates.length;

-     while (++i < n) if (containsLine(coordinates[i], point)) return true;

-     return false;

-   },

-   Polygon: function(object, point) {

-     return containsPolygon(object.coordinates, point);

-   },

-   MultiPolygon: function(object, point) {

-     var coordinates = object.coordinates, i = -1, n = coordinates.length;

-     while (++i < n) if (containsPolygon(coordinates[i], point)) return true;

-     return false;

-   },

-   GeometryCollection: function(object, point) {

-     var geometries = object.geometries, i = -1, n = geometries.length;

-     while (++i < n) if (containsGeometry(geometries[i], point)) return true;

-     return false;

-   }

- };

- 

- function containsGeometry(geometry, point) {

-   return geometry && containsGeometryType.hasOwnProperty(geometry.type)

-       ? containsGeometryType[geometry.type](geometry, point)

-       : false;

- }

- 

- function containsPoint(coordinates, point) {

-   return distance(coordinates, point) === 0;

- }

- 

- function containsLine(coordinates, point) {

-   var ab = distance(coordinates[0], coordinates[1]),

-       ao = distance(coordinates[0], point),

-       ob = distance(point, coordinates[1]);

-   return ao + ob <= ab + epsilon$2;

- }

- 

- function containsPolygon(coordinates, point) {

-   return !!polygonContains(coordinates.map(ringRadians), pointRadians(point));

- }

- 

- function ringRadians(ring) {

-   return ring = ring.map(pointRadians), ring.pop(), ring;

- }

- 

- function pointRadians(point) {

-   return [point[0] * radians, point[1] * radians];

- }

- 

- var contains = function(object, point) {

-   return (object && containsObjectType.hasOwnProperty(object.type)

-       ? containsObjectType[object.type]

-       : containsGeometry)(object, point);

- };

- 

- function graticuleX(y0, y1, dy) {

-   var y = sequence(y0, y1 - epsilon$2, dy).concat(y1);

-   return function(x) { return y.map(function(y) { return [x, y]; }); };

- }

- 

- function graticuleY(x0, x1, dx) {

-   var x = sequence(x0, x1 - epsilon$2, dx).concat(x1);

-   return function(y) { return x.map(function(x) { return [x, y]; }); };

- }

- 

- function graticule() {

-   var x1, x0, X1, X0,

-       y1, y0, Y1, Y0,

-       dx = 10, dy = dx, DX = 90, DY = 360,

-       x, y, X, Y,

-       precision = 2.5;

- 

-   function graticule() {

-     return {type: "MultiLineString", coordinates: lines()};

-   }

- 

-   function lines() {

-     return sequence(ceil(X0 / DX) * DX, X1, DX).map(X)

-         .concat(sequence(ceil(Y0 / DY) * DY, Y1, DY).map(Y))

-         .concat(sequence(ceil(x0 / dx) * dx, x1, dx).filter(function(x) { return abs(x % DX) > epsilon$2; }).map(x))

-         .concat(sequence(ceil(y0 / dy) * dy, y1, dy).filter(function(y) { return abs(y % DY) > epsilon$2; }).map(y));

-   }

- 

-   graticule.lines = function() {

-     return lines().map(function(coordinates) { return {type: "LineString", coordinates: coordinates}; });

-   };

- 

-   graticule.outline = function() {

-     return {

-       type: "Polygon",

-       coordinates: [

-         X(X0).concat(

-         Y(Y1).slice(1),

-         X(X1).reverse().slice(1),

-         Y(Y0).reverse().slice(1))

-       ]

-     };

-   };

- 

-   graticule.extent = function(_) {

-     if (!arguments.length) return graticule.extentMinor();

-     return graticule.extentMajor(_).extentMinor(_);

-   };

- 

-   graticule.extentMajor = function(_) {

-     if (!arguments.length) return [[X0, Y0], [X1, Y1]];

-     X0 = +_[0][0], X1 = +_[1][0];

-     Y0 = +_[0][1], Y1 = +_[1][1];

-     if (X0 > X1) _ = X0, X0 = X1, X1 = _;

-     if (Y0 > Y1) _ = Y0, Y0 = Y1, Y1 = _;

-     return graticule.precision(precision);

-   };

- 

-   graticule.extentMinor = function(_) {

-     if (!arguments.length) return [[x0, y0], [x1, y1]];

-     x0 = +_[0][0], x1 = +_[1][0];

-     y0 = +_[0][1], y1 = +_[1][1];

-     if (x0 > x1) _ = x0, x0 = x1, x1 = _;

-     if (y0 > y1) _ = y0, y0 = y1, y1 = _;

-     return graticule.precision(precision);

-   };

- 

-   graticule.step = function(_) {

-     if (!arguments.length) return graticule.stepMinor();

-     return graticule.stepMajor(_).stepMinor(_);

-   };

- 

-   graticule.stepMajor = function(_) {

-     if (!arguments.length) return [DX, DY];

-     DX = +_[0], DY = +_[1];

-     return graticule;

-   };

- 

-   graticule.stepMinor = function(_) {

-     if (!arguments.length) return [dx, dy];

-     dx = +_[0], dy = +_[1];

-     return graticule;

-   };

- 

-   graticule.precision = function(_) {

-     if (!arguments.length) return precision;

-     precision = +_;

-     x = graticuleX(y0, y1, 90);

-     y = graticuleY(x0, x1, precision);

-     X = graticuleX(Y0, Y1, 90);

-     Y = graticuleY(X0, X1, precision);

-     return graticule;

-   };

- 

-   return graticule

-       .extentMajor([[-180, -90 + epsilon$2], [180, 90 - epsilon$2]])

-       .extentMinor([[-180, -80 - epsilon$2], [180, 80 + epsilon$2]]);

- }

- 

- function graticule10() {

-   return graticule()();

- }

- 

- var interpolate$1 = function(a, b) {

-   var x0 = a[0] * radians,

-       y0 = a[1] * radians,

-       x1 = b[0] * radians,

-       y1 = b[1] * radians,

-       cy0 = cos$1(y0),

-       sy0 = sin$1(y0),

-       cy1 = cos$1(y1),

-       sy1 = sin$1(y1),

-       kx0 = cy0 * cos$1(x0),

-       ky0 = cy0 * sin$1(x0),

-       kx1 = cy1 * cos$1(x1),

-       ky1 = cy1 * sin$1(x1),

-       d = 2 * asin(sqrt(haversin(y1 - y0) + cy0 * cy1 * haversin(x1 - x0))),

-       k = sin$1(d);

- 

-   var interpolate = d ? function(t) {

-     var B = sin$1(t *= d) / k,

-         A = sin$1(d - t) / k,

-         x = A * kx0 + B * kx1,

-         y = A * ky0 + B * ky1,

-         z = A * sy0 + B * sy1;

-     return [

-       atan2(y, x) * degrees$1,

-       atan2(z, sqrt(x * x + y * y)) * degrees$1

-     ];

-   } : function() {

-     return [x0 * degrees$1, y0 * degrees$1];

-   };

- 

-   interpolate.distance = d;

- 

-   return interpolate;

- };

- 

- var identity$4 = function(x) {

-   return x;

- };

- 

- var areaSum$1 = adder();

- var areaRingSum$1 = adder();

- var x00;

- var y00;

- var x0$1;

- var y0$1;

- 

- var areaStream$1 = {

-   point: noop$1,

-   lineStart: noop$1,

-   lineEnd: noop$1,

-   polygonStart: function() {

-     areaStream$1.lineStart = areaRingStart$1;

-     areaStream$1.lineEnd = areaRingEnd$1;

-   },

-   polygonEnd: function() {

-     areaStream$1.lineStart = areaStream$1.lineEnd = areaStream$1.point = noop$1;

-     areaSum$1.add(abs(areaRingSum$1));

-     areaRingSum$1.reset();

-   },

-   result: function() {

-     var area = areaSum$1 / 2;

-     areaSum$1.reset();

-     return area;

-   }

- };

- 

- function areaRingStart$1() {

-   areaStream$1.point = areaPointFirst$1;

- }

- 

- function areaPointFirst$1(x, y) {

-   areaStream$1.point = areaPoint$1;

-   x00 = x0$1 = x, y00 = y0$1 = y;

- }

- 

- function areaPoint$1(x, y) {

-   areaRingSum$1.add(y0$1 * x - x0$1 * y);

-   x0$1 = x, y0$1 = y;

- }

- 

- function areaRingEnd$1() {

-   areaPoint$1(x00, y00);

- }

- 

- var x0$2 = Infinity;

- var y0$2 = x0$2;

- var x1 = -x0$2;

- var y1 = x1;

- 

- var boundsStream$1 = {

-   point: boundsPoint$1,

-   lineStart: noop$1,

-   lineEnd: noop$1,

-   polygonStart: noop$1,

-   polygonEnd: noop$1,

-   result: function() {

-     var bounds = [[x0$2, y0$2], [x1, y1]];

-     x1 = y1 = -(y0$2 = x0$2 = Infinity);

-     return bounds;

-   }

- };

- 

- function boundsPoint$1(x, y) {

-   if (x < x0$2) x0$2 = x;

-   if (x > x1) x1 = x;

-   if (y < y0$2) y0$2 = y;

-   if (y > y1) y1 = y;

- }

- 

- // TODO Enforce positive area for exterior, negative area for interior?

- 

- var X0$1 = 0;

- var Y0$1 = 0;

- var Z0$1 = 0;

- var X1$1 = 0;

- var Y1$1 = 0;

- var Z1$1 = 0;

- var X2$1 = 0;

- var Y2$1 = 0;

- var Z2$1 = 0;

- var x00$1;

- var y00$1;

- var x0$3;

- var y0$3;

- 

- var centroidStream$1 = {

-   point: centroidPoint$1,

-   lineStart: centroidLineStart$1,

-   lineEnd: centroidLineEnd$1,

-   polygonStart: function() {

-     centroidStream$1.lineStart = centroidRingStart$1;

-     centroidStream$1.lineEnd = centroidRingEnd$1;

-   },

-   polygonEnd: function() {

-     centroidStream$1.point = centroidPoint$1;

-     centroidStream$1.lineStart = centroidLineStart$1;

-     centroidStream$1.lineEnd = centroidLineEnd$1;

-   },

-   result: function() {

-     var centroid = Z2$1 ? [X2$1 / Z2$1, Y2$1 / Z2$1]

-         : Z1$1 ? [X1$1 / Z1$1, Y1$1 / Z1$1]

-         : Z0$1 ? [X0$1 / Z0$1, Y0$1 / Z0$1]

-         : [NaN, NaN];

-     X0$1 = Y0$1 = Z0$1 =

-     X1$1 = Y1$1 = Z1$1 =

-     X2$1 = Y2$1 = Z2$1 = 0;

-     return centroid;

-   }

- };

- 

- function centroidPoint$1(x, y) {

-   X0$1 += x;

-   Y0$1 += y;

-   ++Z0$1;

- }

- 

- function centroidLineStart$1() {

-   centroidStream$1.point = centroidPointFirstLine;

- }

- 

- function centroidPointFirstLine(x, y) {

-   centroidStream$1.point = centroidPointLine;

-   centroidPoint$1(x0$3 = x, y0$3 = y);

- }

- 

- function centroidPointLine(x, y) {

-   var dx = x - x0$3, dy = y - y0$3, z = sqrt(dx * dx + dy * dy);

-   X1$1 += z * (x0$3 + x) / 2;

-   Y1$1 += z * (y0$3 + y) / 2;

-   Z1$1 += z;

-   centroidPoint$1(x0$3 = x, y0$3 = y);

- }

- 

- function centroidLineEnd$1() {

-   centroidStream$1.point = centroidPoint$1;

- }

- 

- function centroidRingStart$1() {

-   centroidStream$1.point = centroidPointFirstRing;

- }

- 

- function centroidRingEnd$1() {

-   centroidPointRing(x00$1, y00$1);

- }

- 

- function centroidPointFirstRing(x, y) {

-   centroidStream$1.point = centroidPointRing;

-   centroidPoint$1(x00$1 = x0$3 = x, y00$1 = y0$3 = y);

- }

- 

- function centroidPointRing(x, y) {

-   var dx = x - x0$3,

-       dy = y - y0$3,

-       z = sqrt(dx * dx + dy * dy);

- 

-   X1$1 += z * (x0$3 + x) / 2;

-   Y1$1 += z * (y0$3 + y) / 2;

-   Z1$1 += z;

- 

-   z = y0$3 * x - x0$3 * y;

-   X2$1 += z * (x0$3 + x);

-   Y2$1 += z * (y0$3 + y);

-   Z2$1 += z * 3;

-   centroidPoint$1(x0$3 = x, y0$3 = y);

- }

- 

- function PathContext(context) {

-   this._context = context;

- }

- 

- PathContext.prototype = {

-   _radius: 4.5,

-   pointRadius: function(_) {

-     return this._radius = _, this;

-   },

-   polygonStart: function() {

-     this._line = 0;

-   },

-   polygonEnd: function() {

-     this._line = NaN;

-   },

-   lineStart: function() {

-     this._point = 0;

-   },

-   lineEnd: function() {

-     if (this._line === 0) this._context.closePath();

-     this._point = NaN;

-   },

-   point: function(x, y) {

-     switch (this._point) {

-       case 0: {

-         this._context.moveTo(x, y);

-         this._point = 1;

-         break;

-       }

-       case 1: {

-         this._context.lineTo(x, y);

-         break;

-       }

-       default: {

-         this._context.moveTo(x + this._radius, y);

-         this._context.arc(x, y, this._radius, 0, tau$3);

-         break;

-       }

-     }

-   },

-   result: noop$1

- };

- 

- var lengthSum$1 = adder();

- var lengthRing;

- var x00$2;

- var y00$2;

- var x0$4;

- var y0$4;

- 

- var lengthStream$1 = {

-   point: noop$1,

-   lineStart: function() {

-     lengthStream$1.point = lengthPointFirst$1;

-   },

-   lineEnd: function() {

-     if (lengthRing) lengthPoint$1(x00$2, y00$2);

-     lengthStream$1.point = noop$1;

-   },

-   polygonStart: function() {

-     lengthRing = true;

-   },

-   polygonEnd: function() {

-     lengthRing = null;

-   },

-   result: function() {

-     var length = +lengthSum$1;

-     lengthSum$1.reset();

-     return length;

-   }

- };

- 

- function lengthPointFirst$1(x, y) {

-   lengthStream$1.point = lengthPoint$1;

-   x00$2 = x0$4 = x, y00$2 = y0$4 = y;

- }

- 

- function lengthPoint$1(x, y) {

-   x0$4 -= x, y0$4 -= y;

-   lengthSum$1.add(sqrt(x0$4 * x0$4 + y0$4 * y0$4));

-   x0$4 = x, y0$4 = y;

- }

- 

- function PathString() {

-   this._string = [];

- }

- 

- PathString.prototype = {

-   _radius: 4.5,

-   _circle: circle$1(4.5),

-   pointRadius: function(_) {

-     if ((_ = +_) !== this._radius) this._radius = _, this._circle = null;

-     return this;

-   },

-   polygonStart: function() {

-     this._line = 0;

-   },

-   polygonEnd: function() {

-     this._line = NaN;

-   },

-   lineStart: function() {

-     this._point = 0;

-   },

-   lineEnd: function() {

-     if (this._line === 0) this._string.push("Z");

-     this._point = NaN;

-   },

-   point: function(x, y) {

-     switch (this._point) {

-       case 0: {

-         this._string.push("M", x, ",", y);

-         this._point = 1;

-         break;

-       }

-       case 1: {

-         this._string.push("L", x, ",", y);

-         break;

-       }

-       default: {

-         if (this._circle == null) this._circle = circle$1(this._radius);

-         this._string.push("M", x, ",", y, this._circle);

-         break;

-       }

-     }

-   },

-   result: function() {

-     if (this._string.length) {

-       var result = this._string.join("");

-       this._string = [];

-       return result;

-     } else {

-       return null;

-     }

-   }

- };

- 

- function circle$1(radius) {

-   return "m0," + radius

-       + "a" + radius + "," + radius + " 0 1,1 0," + -2 * radius

-       + "a" + radius + "," + radius + " 0 1,1 0," + 2 * radius

-       + "z";

- }

- 

- var index$1 = function(projection, context) {

-   var pointRadius = 4.5,

-       projectionStream,

-       contextStream;

- 

-   function path(object) {

-     if (object) {

-       if (typeof pointRadius === "function") contextStream.pointRadius(+pointRadius.apply(this, arguments));

-       geoStream(object, projectionStream(contextStream));

-     }

-     return contextStream.result();

-   }

- 

-   path.area = function(object) {

-     geoStream(object, projectionStream(areaStream$1));

-     return areaStream$1.result();

-   };

- 

-   path.measure = function(object) {

-     geoStream(object, projectionStream(lengthStream$1));

-     return lengthStream$1.result();

-   };

- 

-   path.bounds = function(object) {

-     geoStream(object, projectionStream(boundsStream$1));

-     return boundsStream$1.result();

-   };

- 

-   path.centroid = function(object) {

-     geoStream(object, projectionStream(centroidStream$1));

-     return centroidStream$1.result();

-   };

- 

-   path.projection = function(_) {

-     return arguments.length ? (projectionStream = _ == null ? (projection = null, identity$4) : (projection = _).stream, path) : projection;

-   };

- 

-   path.context = function(_) {

-     if (!arguments.length) return context;

-     contextStream = _ == null ? (context = null, new PathString) : new PathContext(context = _);

-     if (typeof pointRadius !== "function") contextStream.pointRadius(pointRadius);

-     return path;

-   };

- 

-   path.pointRadius = function(_) {

-     if (!arguments.length) return pointRadius;

-     pointRadius = typeof _ === "function" ? _ : (contextStream.pointRadius(+_), +_);

-     return path;

-   };

- 

-   return path.projection(projection).context(context);

- };

- 

- var transform = function(methods) {

-   return {

-     stream: transformer(methods)

-   };

- };

- 

- function transformer(methods) {

-   return function(stream) {

-     var s = new TransformStream;

-     for (var key in methods) s[key] = methods[key];

-     s.stream = stream;

-     return s;

-   };

- }

- 

- function TransformStream() {}

- 

- TransformStream.prototype = {

-   constructor: TransformStream,

-   point: function(x, y) { this.stream.point(x, y); },

-   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 fitExtent(projection, extent, object) {

-   var w = extent[1][0] - extent[0][0],

-       h = extent[1][1] - extent[0][1],

-       clip = projection.clipExtent && projection.clipExtent();

- 

-   projection

-       .scale(150)

-       .translate([0, 0]);

- 

-   if (clip != null) projection.clipExtent(null);

- 

-   geoStream(object, projection.stream(boundsStream$1));

- 

-   var b = boundsStream$1.result(),

-       k = Math.min(w / (b[1][0] - b[0][0]), h / (b[1][1] - b[0][1])),

-       x = +extent[0][0] + (w - k * (b[1][0] + b[0][0])) / 2,

-       y = +extent[0][1] + (h - k * (b[1][1] + b[0][1])) / 2;

- 

-   if (clip != null) projection.clipExtent(clip);

- 

-   return projection

-       .scale(k * 150)

-       .translate([x, y]);

- }

- 

- function fitSize(projection, size, object) {

-   return fitExtent(projection, [[0, 0], size], object);

- }

- 

- var maxDepth = 16;

- var cosMinDistance = cos$1(30 * radians); // cos(minimum angular distance)

- 

- var resample = function(project, delta2) {

-   return +delta2 ? resample$1(project, delta2) : resampleNone(project);

- };

- 

- function resampleNone(project) {

-   return transformer({

-     point: function(x, y) {

-       x = project(x, y);

-       this.stream.point(x[0], x[1]);

-     }

-   });

- }

- 

- function resample$1(project, delta2) {

- 

-   function resampleLineTo(x0, y0, lambda0, a0, b0, c0, x1, y1, lambda1, a1, b1, c1, depth, stream) {

-     var dx = x1 - x0,

-         dy = y1 - y0,

-         d2 = dx * dx + dy * dy;

-     if (d2 > 4 * delta2 && depth--) {

-       var a = a0 + a1,

-           b = b0 + b1,

-           c = c0 + c1,

-           m = sqrt(a * a + b * b + c * c),

-           phi2 = asin(c /= m),

-           lambda2 = abs(abs(c) - 1) < epsilon$2 || abs(lambda0 - lambda1) < epsilon$2 ? (lambda0 + lambda1) / 2 : atan2(b, a),

-           p = project(lambda2, phi2),

-           x2 = p[0],

-           y2 = p[1],

-           dx2 = x2 - x0,

-           dy2 = y2 - y0,

-           dz = dy * dx2 - dx * dy2;

-       if (dz * dz / d2 > delta2 // perpendicular projected distance

-           || abs((dx * dx2 + dy * dy2) / d2 - 0.5) > 0.3 // midpoint close to an end

-           || a0 * a1 + b0 * b1 + c0 * c1 < cosMinDistance) { // angular distance

-         resampleLineTo(x0, y0, lambda0, a0, b0, c0, x2, y2, lambda2, a /= m, b /= m, c, depth, stream);

-         stream.point(x2, y2);

-         resampleLineTo(x2, y2, lambda2, a, b, c, x1, y1, lambda1, a1, b1, c1, depth, stream);

-       }

-     }

-   }

-   return function(stream) {

-     var lambda00, x00, y00, a00, b00, c00, // first point

-         lambda0, x0, y0, a0, b0, c0; // previous point

- 

-     var resampleStream = {

-       point: point,

-       lineStart: lineStart,

-       lineEnd: lineEnd,

-       polygonStart: function() { stream.polygonStart(); resampleStream.lineStart = ringStart; },

-       polygonEnd: function() { stream.polygonEnd(); resampleStream.lineStart = lineStart; }

-     };

- 

-     function point(x, y) {

-       x = project(x, y);

-       stream.point(x[0], x[1]);

-     }

- 

-     function lineStart() {

-       x0 = NaN;

-       resampleStream.point = linePoint;

-       stream.lineStart();

-     }

- 

-     function linePoint(lambda, phi) {

-       var c = cartesian([lambda, phi]), p = project(lambda, phi);

-       resampleLineTo(x0, y0, lambda0, a0, b0, c0, x0 = p[0], y0 = p[1], lambda0 = lambda, a0 = c[0], b0 = c[1], c0 = c[2], maxDepth, stream);

-       stream.point(x0, y0);

-     }

- 

-     function lineEnd() {

-       resampleStream.point = point;

-       stream.lineEnd();

-     }

- 

-     function ringStart() {

-       lineStart();

-       resampleStream.point = ringPoint;

-       resampleStream.lineEnd = ringEnd;

-     }

- 

-     function ringPoint(lambda, phi) {

-       linePoint(lambda00 = lambda, phi), x00 = x0, y00 = y0, a00 = a0, b00 = b0, c00 = c0;

-       resampleStream.point = linePoint;

-     }

- 

-     function ringEnd() {

-       resampleLineTo(x0, y0, lambda0, a0, b0, c0, x00, y00, lambda00, a00, b00, c00, maxDepth, stream);

-       resampleStream.lineEnd = lineEnd;

-       lineEnd();

-     }

- 

-     return resampleStream;

-   };

- }

- 

- var transformRadians = transformer({

-   point: function(x, y) {

-     this.stream.point(x * radians, y * radians);

-   }

- });

- 

- function transformRotate(rotate) {

-   return transformer({

-     point: function(x, y) {

-       var r = rotate(x, y);

-       return this.stream.point(r[0], r[1]);

-     }

-   });

- }

- 

- function projection(project) {

-   return projectionMutator(function() { return project; })();

- }

- 

- function projectionMutator(projectAt) {

-   var project,

-       k = 150, // scale

-       x = 480, y = 250, // translate

-       dx, dy, lambda = 0, phi = 0, // center

-       deltaLambda = 0, deltaPhi = 0, deltaGamma = 0, rotate, projectRotate, // rotate

-       theta = null, preclip = clipAntimeridian, // clip angle

-       x0 = null, y0, x1, y1, postclip = identity$4, // clip extent

-       delta2 = 0.5, projectResample = resample(projectTransform, delta2), // precision

-       cache,

-       cacheStream;

- 

-   function projection(point) {

-     point = projectRotate(point[0] * radians, point[1] * radians);

-     return [point[0] * k + dx, dy - point[1] * k];

-   }

- 

-   function invert(point) {

-     point = projectRotate.invert((point[0] - dx) / k, (dy - point[1]) / k);

-     return point && [point[0] * degrees$1, point[1] * degrees$1];

-   }

- 

-   function projectTransform(x, y) {

-     return x = project(x, y), [x[0] * k + dx, dy - x[1] * k];

-   }

- 

-   projection.stream = function(stream) {

-     return cache && cacheStream === stream ? cache : cache = transformRadians(transformRotate(rotate)(preclip(projectResample(postclip(cacheStream = stream)))));

-   };

- 

-   projection.preclip = function(_) {

-     return arguments.length ? (preclip = _, theta = undefined, reset()) : preclip;

-   };

- 

-   projection.postclip = function(_) {

-     return arguments.length ? (postclip = _, x0 = y0 = x1 = y1 = null, reset()) : postclip;

-   };

- 

-   projection.clipAngle = function(_) {

-     return arguments.length ? (preclip = +_ ? clipCircle(theta = _ * radians) : (theta = null, clipAntimeridian), reset()) : theta * degrees$1;

-   };

- 

-   projection.clipExtent = function(_) {

-     return arguments.length ? (postclip = _ == null ? (x0 = y0 = x1 = y1 = null, identity$4) : clipRectangle(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];

-   };

- 

-   projection.scale = function(_) {

-     return arguments.length ? (k = +_, recenter()) : k;

-   };

- 

-   projection.translate = function(_) {

-     return arguments.length ? (x = +_[0], y = +_[1], recenter()) : [x, y];

-   };

- 

-   projection.center = function(_) {

-     return arguments.length ? (lambda = _[0] % 360 * radians, phi = _[1] % 360 * radians, recenter()) : [lambda * degrees$1, phi * degrees$1];

-   };

- 

-   projection.rotate = function(_) {

-     return arguments.length ? (deltaLambda = _[0] % 360 * radians, deltaPhi = _[1] % 360 * radians, deltaGamma = _.length > 2 ? _[2] % 360 * radians : 0, recenter()) : [deltaLambda * degrees$1, deltaPhi * degrees$1, deltaGamma * degrees$1];

-   };

- 

-   projection.precision = function(_) {

-     return arguments.length ? (projectResample = resample(projectTransform, delta2 = _ * _), reset()) : sqrt(delta2);

-   };

- 

-   projection.fitExtent = function(extent, object) {

-     return fitExtent(projection, extent, object);

-   };

- 

-   projection.fitSize = function(size, object) {

-     return fitSize(projection, size, object);

-   };

- 

-   function recenter() {

-     projectRotate = compose(rotate = rotateRadians(deltaLambda, deltaPhi, deltaGamma), project);

-     var center = project(lambda, phi);

-     dx = x - center[0] * k;

-     dy = y + center[1] * k;

-     return reset();

-   }

- 

-   function reset() {

-     cache = cacheStream = null;

-     return projection;

-   }

- 

-   return function() {

-     project = projectAt.apply(this, arguments);

-     projection.invert = project.invert && invert;

-     return recenter();

-   };

- }

- 

- function conicProjection(projectAt) {

-   var phi0 = 0,

-       phi1 = pi$3 / 3,

-       m = projectionMutator(projectAt),

-       p = m(phi0, phi1);

- 

-   p.parallels = function(_) {

-     return arguments.length ? m(phi0 = _[0] * radians, phi1 = _[1] * radians) : [phi0 * degrees$1, phi1 * degrees$1];

-   };

- 

-   return p;

- }

- 

- function cylindricalEqualAreaRaw(phi0) {

-   var cosPhi0 = cos$1(phi0);

- 

-   function forward(lambda, phi) {

-     return [lambda * cosPhi0, sin$1(phi) / cosPhi0];

-   }

- 

-   forward.invert = function(x, y) {

-     return [x / cosPhi0, asin(y * cosPhi0)];

-   };

- 

-   return forward;

- }

- 

- function conicEqualAreaRaw(y0, y1) {

-   var sy0 = sin$1(y0), n = (sy0 + sin$1(y1)) / 2;

- 

-   // Are the parallels symmetrical around the Equator?

-   if (abs(n) < epsilon$2) return cylindricalEqualAreaRaw(y0);

- 

-   var c = 1 + sy0 * (2 * n - sy0), r0 = sqrt(c) / n;

- 

-   function project(x, y) {

-     var r = sqrt(c - 2 * n * sin$1(y)) / n;

-     return [r * sin$1(x *= n), r0 - r * cos$1(x)];

-   }

- 

-   project.invert = function(x, y) {

-     var r0y = r0 - y;

-     return [atan2(x, abs(r0y)) / n * sign(r0y), asin((c - (x * x + r0y * r0y) * n * n) / (2 * n))];

-   };

- 

-   return project;

- }

- 

- var conicEqualArea = function() {

-   return conicProjection(conicEqualAreaRaw)

-       .scale(155.424)

-       .center([0, 33.6442]);

- };

- 

- var albers = function() {

-   return conicEqualArea()

-       .parallels([29.5, 45.5])

-       .scale(1070)

-       .translate([480, 250])

-       .rotate([96, 0])

-       .center([-0.6, 38.7]);

- };

- 

- // The projections must have mutually exclusive clip regions on the sphere,

- // as this will avoid emitting interleaving lines and polygons.

- function multiplex(streams) {

-   var n = streams.length;

-   return {

-     point: function(x, y) { var i = -1; while (++i < n) streams[i].point(x, y); },

-     sphere: function() { var i = -1; while (++i < n) streams[i].sphere(); },

-     lineStart: function() { var i = -1; while (++i < n) streams[i].lineStart(); },

-     lineEnd: function() { var i = -1; while (++i < n) streams[i].lineEnd(); },

-     polygonStart: function() { var i = -1; while (++i < n) streams[i].polygonStart(); },

-     polygonEnd: function() { var i = -1; while (++i < n) streams[i].polygonEnd(); }

-   };

- }

- 

- // A composite projection for the United States, configured by default for

- // 960×500. The projection also works quite well at 960×600 if you change the

- // scale to 1285 and adjust the translate accordingly. The set of standard

- // parallels for each region comes from USGS, which is published here:

- // http://egsc.usgs.gov/isb/pubs/MapProjections/projections.html#albers

- var albersUsa = function() {

-   var cache,

-       cacheStream,

-       lower48 = albers(), lower48Point,

-       alaska = conicEqualArea().rotate([154, 0]).center([-2, 58.5]).parallels([55, 65]), alaskaPoint, // EPSG:3338

-       hawaii = conicEqualArea().rotate([157, 0]).center([-3, 19.9]).parallels([8, 18]), hawaiiPoint, // ESRI:102007

-       point, pointStream = {point: function(x, y) { point = [x, y]; }};

- 

-   function albersUsa(coordinates) {

-     var x = coordinates[0], y = coordinates[1];

-     return point = null,

-         (lower48Point.point(x, y), point)

-         || (alaskaPoint.point(x, y), point)

-         || (hawaiiPoint.point(x, y), point);

-   }

- 

-   albersUsa.invert = function(coordinates) {

-     var k = lower48.scale(),

-         t = lower48.translate(),

-         x = (coordinates[0] - t[0]) / k,

-         y = (coordinates[1] - t[1]) / k;

-     return (y >= 0.120 && y < 0.234 && x >= -0.425 && x < -0.214 ? alaska

-         : y >= 0.166 && y < 0.234 && x >= -0.214 && x < -0.115 ? hawaii

-         : lower48).invert(coordinates);

-   };

- 

-   albersUsa.stream = function(stream) {

-     return cache && cacheStream === stream ? cache : cache = multiplex([lower48.stream(cacheStream = stream), alaska.stream(stream), hawaii.stream(stream)]);

-   };

- 

-   albersUsa.precision = function(_) {

-     if (!arguments.length) return lower48.precision();

-     lower48.precision(_), alaska.precision(_), hawaii.precision(_);

-     return reset();

-   };

- 

-   albersUsa.scale = function(_) {

-     if (!arguments.length) return lower48.scale();

-     lower48.scale(_), alaska.scale(_ * 0.35), hawaii.scale(_);

-     return albersUsa.translate(lower48.translate());

-   };

- 

-   albersUsa.translate = function(_) {

-     if (!arguments.length) return lower48.translate();

-     var k = lower48.scale(), x = +_[0], y = +_[1];

- 

-     lower48Point = lower48

-         .translate(_)

-         .clipExtent([[x - 0.455 * k, y - 0.238 * k], [x + 0.455 * k, y + 0.238 * k]])

-         .stream(pointStream);

- 

-     alaskaPoint = alaska

-         .translate([x - 0.307 * k, y + 0.201 * k])

-         .clipExtent([[x - 0.425 * k + epsilon$2, y + 0.120 * k + epsilon$2], [x - 0.214 * k - epsilon$2, y + 0.234 * k - epsilon$2]])

-         .stream(pointStream);

- 

-     hawaiiPoint = hawaii

-         .translate([x - 0.205 * k, y + 0.212 * k])

-         .clipExtent([[x - 0.214 * k + epsilon$2, y + 0.166 * k + epsilon$2], [x - 0.115 * k - epsilon$2, y + 0.234 * k - epsilon$2]])

-         .stream(pointStream);

- 

-     return reset();

-   };

- 

-   albersUsa.fitExtent = function(extent, object) {

-     return fitExtent(albersUsa, extent, object);

-   };

- 

-   albersUsa.fitSize = function(size, object) {

-     return fitSize(albersUsa, size, object);

-   };

- 

-   function reset() {

-     cache = cacheStream = null;

-     return albersUsa;

-   }

- 

-   return albersUsa.scale(1070);

- };

- 

- function azimuthalRaw(scale) {

-   return function(x, y) {

-     var cx = cos$1(x),

-         cy = cos$1(y),

-         k = scale(cx * cy);

-     return [

-       k * cy * sin$1(x),

-       k * sin$1(y)

-     ];

-   }

- }

- 

- function azimuthalInvert(angle) {

-   return function(x, y) {

-     var z = sqrt(x * x + y * y),

-         c = angle(z),

-         sc = sin$1(c),

-         cc = cos$1(c);

-     return [

-       atan2(x * sc, z * cc),

-       asin(z && y * sc / z)

-     ];

-   }

- }

- 

- var azimuthalEqualAreaRaw = azimuthalRaw(function(cxcy) {

-   return sqrt(2 / (1 + cxcy));

- });

- 

- azimuthalEqualAreaRaw.invert = azimuthalInvert(function(z) {

-   return 2 * asin(z / 2);

- });

- 

- var azimuthalEqualArea = function() {

-   return projection(azimuthalEqualAreaRaw)

-       .scale(124.75)

-       .clipAngle(180 - 1e-3);

- };

- 

- var azimuthalEquidistantRaw = azimuthalRaw(function(c) {

-   return (c = acos(c)) && c / sin$1(c);

- });

- 

- azimuthalEquidistantRaw.invert = azimuthalInvert(function(z) {

-   return z;

- });

- 

- var azimuthalEquidistant = function() {

-   return projection(azimuthalEquidistantRaw)

-       .scale(79.4188)

-       .clipAngle(180 - 1e-3);

- };

- 

- function mercatorRaw(lambda, phi) {

-   return [lambda, log(tan((halfPi$2 + phi) / 2))];

- }

- 

- mercatorRaw.invert = function(x, y) {

-   return [x, 2 * atan(exp(y)) - halfPi$2];

- };

- 

- var mercator = function() {

-   return mercatorProjection(mercatorRaw)

-       .scale(961 / tau$3);

- };

- 

- function mercatorProjection(project) {

-   var m = projection(project),

-       center = m.center,

-       scale = m.scale,

-       translate = m.translate,

-       clipExtent = m.clipExtent,

-       x0 = null, y0, x1, y1; // clip extent

- 

-   m.scale = function(_) {

-     return arguments.length ? (scale(_), reclip()) : scale();

-   };

- 

-   m.translate = function(_) {

-     return arguments.length ? (translate(_), reclip()) : translate();

-   };

- 

-   m.center = function(_) {

-     return arguments.length ? (center(_), reclip()) : center();

-   };

- 

-   m.clipExtent = function(_) {

-     return arguments.length ? ((_ == null ? x0 = y0 = x1 = y1 = null : (x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1])), reclip()) : x0 == null ? null : [[x0, y0], [x1, y1]];

-   };

- 

-   function reclip() {

-     var k = pi$3 * scale(),

-         t = m(rotation(m.rotate()).invert([0, 0]));

-     return clipExtent(x0 == null

-         ? [[t[0] - k, t[1] - k], [t[0] + k, t[1] + k]] : project === mercatorRaw

-         ? [[Math.max(t[0] - k, x0), y0], [Math.min(t[0] + k, x1), y1]]

-         : [[x0, Math.max(t[1] - k, y0)], [x1, Math.min(t[1] + k, y1)]]);

-   }

- 

-   return reclip();

- }

- 

- function tany(y) {

-   return tan((halfPi$2 + y) / 2);

- }

- 

- function conicConformalRaw(y0, y1) {

-   var cy0 = cos$1(y0),

-       n = y0 === y1 ? sin$1(y0) : log(cy0 / cos$1(y1)) / log(tany(y1) / tany(y0)),

-       f = cy0 * pow(tany(y0), n) / n;

- 

-   if (!n) return mercatorRaw;

- 

-   function project(x, y) {

-     if (f > 0) { if (y < -halfPi$2 + epsilon$2) y = -halfPi$2 + epsilon$2; }

-     else { if (y > halfPi$2 - epsilon$2) y = halfPi$2 - epsilon$2; }

-     var r = f / pow(tany(y), n);

-     return [r * sin$1(n * x), f - r * cos$1(n * x)];

-   }

- 

-   project.invert = function(x, y) {

-     var fy = f - y, r = sign(n) * sqrt(x * x + fy * fy);

-     return [atan2(x, abs(fy)) / n * sign(fy), 2 * atan(pow(f / r, 1 / n)) - halfPi$2];

-   };

- 

-   return project;

- }

- 

- var conicConformal = function() {

-   return conicProjection(conicConformalRaw)

-       .scale(109.5)

-       .parallels([30, 30]);

- };

- 

- function equirectangularRaw(lambda, phi) {

-   return [lambda, phi];

- }

- 

- equirectangularRaw.invert = equirectangularRaw;

- 

- var equirectangular = function() {

-   return projection(equirectangularRaw)

-       .scale(152.63);

- };

- 

- function conicEquidistantRaw(y0, y1) {

-   var cy0 = cos$1(y0),

-       n = y0 === y1 ? sin$1(y0) : (cy0 - cos$1(y1)) / (y1 - y0),

-       g = cy0 / n + y0;

- 

-   if (abs(n) < epsilon$2) return equirectangularRaw;

- 

-   function project(x, y) {

-     var gy = g - y, nx = n * x;

-     return [gy * sin$1(nx), g - gy * cos$1(nx)];

-   }

- 

-   project.invert = function(x, y) {

-     var gy = g - y;

-     return [atan2(x, abs(gy)) / n * sign(gy), g - sign(n) * sqrt(x * x + gy * gy)];

-   };

- 

-   return project;

- }

- 

- var conicEquidistant = function() {

-   return conicProjection(conicEquidistantRaw)

-       .scale(131.154)

-       .center([0, 13.9389]);

- };

- 

- function gnomonicRaw(x, y) {

-   var cy = cos$1(y), k = cos$1(x) * cy;

-   return [cy * sin$1(x) / k, sin$1(y) / k];

- }

- 

- gnomonicRaw.invert = azimuthalInvert(atan);

- 

- var gnomonic = function() {

-   return projection(gnomonicRaw)

-       .scale(144.049)

-       .clipAngle(60);

- };

- 

- function scaleTranslate(kx, ky, tx, ty) {

-   return kx === 1 && ky === 1 && tx === 0 && ty === 0 ? identity$4 : transformer({

-     point: function(x, y) {

-       this.stream.point(x * kx + tx, y * ky + ty);

-     }

-   });

- }

- 

- var identity$5 = function() {

-   var k = 1, tx = 0, ty = 0, sx = 1, sy = 1, transform$$1 = identity$4, // scale, translate and reflect

-       x0 = null, y0, x1, y1, // clip extent

-       postclip = identity$4,

-       cache,

-       cacheStream,

-       projection;

- 

-   function reset() {

-     cache = cacheStream = null;

-     return projection;

-   }

- 

-   return projection = {

-     stream: function(stream) {

-       return cache && cacheStream === stream ? cache : cache = transform$$1(postclip(cacheStream = stream));

-     },

-     postclip: function(_) {

-       return arguments.length ? (postclip = _, x0 = y0 = x1 = y1 = null, reset()) : postclip;

-     },

-     clipExtent: function(_) {

-       return arguments.length ? (postclip = _ == null ? (x0 = y0 = x1 = y1 = null, identity$4) : clipRectangle(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];

-     },

-     scale: function(_) {

-       return arguments.length ? (transform$$1 = scaleTranslate((k = +_) * sx, k * sy, tx, ty), reset()) : k;

-     },

-     translate: function(_) {

-       return arguments.length ? (transform$$1 = scaleTranslate(k * sx, k * sy, tx = +_[0], ty = +_[1]), reset()) : [tx, ty];

-     },

-     reflectX: function(_) {

-       return arguments.length ? (transform$$1 = scaleTranslate(k * (sx = _ ? -1 : 1), k * sy, tx, ty), reset()) : sx < 0;

-     },

-     reflectY: function(_) {

-       return arguments.length ? (transform$$1 = scaleTranslate(k * sx, k * (sy = _ ? -1 : 1), tx, ty), reset()) : sy < 0;

-     },

-     fitExtent: function(extent, object) {

-       return fitExtent(projection, extent, object);

-     },

-     fitSize: function(size, object) {

-       return fitSize(projection, size, object);

-     }

-   };

- };

- 

- function naturalEarth1Raw(lambda, phi) {

-   var phi2 = phi * phi, phi4 = phi2 * phi2;

-   return [

-     lambda * (0.8707 - 0.131979 * phi2 + phi4 * (-0.013791 + phi4 * (0.003971 * phi2 - 0.001529 * phi4))),

-     phi * (1.007226 + phi2 * (0.015085 + phi4 * (-0.044475 + 0.028874 * phi2 - 0.005916 * phi4)))

-   ];

- }

- 

- naturalEarth1Raw.invert = function(x, y) {

-   var phi = y, i = 25, delta;

-   do {

-     var phi2 = phi * phi, phi4 = phi2 * phi2;

-     phi -= delta = (phi * (1.007226 + phi2 * (0.015085 + phi4 * (-0.044475 + 0.028874 * phi2 - 0.005916 * phi4))) - y) /

-         (1.007226 + phi2 * (0.015085 * 3 + phi4 * (-0.044475 * 7 + 0.028874 * 9 * phi2 - 0.005916 * 11 * phi4)));

-   } while (abs(delta) > epsilon$2 && --i > 0);

-   return [

-     x / (0.8707 + (phi2 = phi * phi) * (-0.131979 + phi2 * (-0.013791 + phi2 * phi2 * phi2 * (0.003971 - 0.001529 * phi2)))),

-     phi

-   ];

- };

- 

- var naturalEarth1 = function() {

-   return projection(naturalEarth1Raw)

-       .scale(175.295);

- };

- 

- function orthographicRaw(x, y) {

-   return [cos$1(y) * sin$1(x), sin$1(y)];

- }

- 

- orthographicRaw.invert = azimuthalInvert(asin);

- 

- var orthographic = function() {

-   return projection(orthographicRaw)

-       .scale(249.5)

-       .clipAngle(90 + epsilon$2);

- };

- 

- function stereographicRaw(x, y) {

-   var cy = cos$1(y), k = 1 + cos$1(x) * cy;

-   return [cy * sin$1(x) / k, sin$1(y) / k];

- }

- 

- stereographicRaw.invert = azimuthalInvert(function(z) {

-   return 2 * atan(z);

- });

- 

- var stereographic = function() {

-   return projection(stereographicRaw)

-       .scale(250)

-       .clipAngle(142);

- };

- 

- function transverseMercatorRaw(lambda, phi) {

-   return [log(tan((halfPi$2 + phi) / 2)), -lambda];

- }

- 

- transverseMercatorRaw.invert = function(x, y) {

-   return [-y, 2 * atan(exp(x)) - halfPi$2];

- };

- 

- var transverseMercator = function() {

-   var m = mercatorProjection(transverseMercatorRaw),

-       center = m.center,

-       rotate = m.rotate;

- 

-   m.center = function(_) {

-     return arguments.length ? center([-_[1], _[0]]) : (_ = center(), [_[1], -_[0]]);

-   };

- 

-   m.rotate = function(_) {

-     return arguments.length ? rotate([_[0], _[1], _.length > 2 ? _[2] + 90 : 90]) : (_ = rotate(), [_[0], _[1], _[2] - 90]);

-   };

- 

-   return rotate([0, 0, 90])

-       .scale(159.155);

- };

- 

- function defaultSeparation(a, b) {

-   return a.parent === b.parent ? 1 : 2;

- }

- 

- function meanX(children) {

-   return children.reduce(meanXReduce, 0) / children.length;

- }

- 

- function meanXReduce(x, c) {

-   return x + c.x;

- }

- 

- function maxY(children) {

-   return 1 + children.reduce(maxYReduce, 0);

- }

- 

- function maxYReduce(y, c) {

-   return Math.max(y, c.y);

- }

- 

- function leafLeft(node) {

-   var children;

-   while (children = node.children) node = children[0];

-   return node;

- }

- 

- function leafRight(node) {

-   var children;

-   while (children = node.children) node = children[children.length - 1];

-   return node;

- }

- 

- var cluster = function() {

-   var separation = defaultSeparation,

-       dx = 1,

-       dy = 1,

-       nodeSize = false;

- 

-   function cluster(root) {

-     var previousNode,

-         x = 0;

- 

-     // First walk, computing the initial x & y values.

-     root.eachAfter(function(node) {

-       var children = node.children;

-       if (children) {

-         node.x = meanX(children);

-         node.y = maxY(children);

-       } else {

-         node.x = previousNode ? x += separation(node, previousNode) : 0;

-         node.y = 0;

-         previousNode = node;

-       }

-     });

- 

-     var left = leafLeft(root),

-         right = leafRight(root),

-         x0 = left.x - separation(left, right) / 2,

-         x1 = right.x + separation(right, left) / 2;

- 

-     // Second walk, normalizing x & y to the desired size.

-     return root.eachAfter(nodeSize ? function(node) {

-       node.x = (node.x - root.x) * dx;

-       node.y = (root.y - node.y) * dy;

-     } : function(node) {

-       node.x = (node.x - x0) / (x1 - x0) * dx;

-       node.y = (1 - (root.y ? node.y / root.y : 1)) * dy;

-     });

-   }

- 

-   cluster.separation = function(x) {

-     return arguments.length ? (separation = x, cluster) : separation;

-   };

- 

-   cluster.size = function(x) {

-     return arguments.length ? (nodeSize = false, dx = +x[0], dy = +x[1], cluster) : (nodeSize ? null : [dx, dy]);

-   };

- 

-   cluster.nodeSize = function(x) {

-     return arguments.length ? (nodeSize = true, dx = +x[0], dy = +x[1], cluster) : (nodeSize ? [dx, dy] : null);

-   };

- 

-   return cluster;

- };

- 

- function count(node) {

-   var sum = 0,

-       children = node.children,

-       i = children && children.length;

-   if (!i) sum = 1;

-   else while (--i >= 0) sum += children[i].value;

-   node.value = sum;

- }

- 

- var node_count = function() {

-   return this.eachAfter(count);

- };

- 

- var node_each = function(callback) {

-   var node = this, current, next = [node], children, i, n;

-   do {

-     current = next.reverse(), next = [];

-     while (node = current.pop()) {

-       callback(node), children = node.children;

-       if (children) for (i = 0, n = children.length; i < n; ++i) {

-         next.push(children[i]);

-       }

-     }

-   } while (next.length);

-   return this;

- };

- 

- var node_eachBefore = function(callback) {

-   var node = this, nodes = [node], children, i;

-   while (node = nodes.pop()) {

-     callback(node), children = node.children;

-     if (children) for (i = children.length - 1; i >= 0; --i) {

-       nodes.push(children[i]);

-     }

-   }

-   return this;

- };

- 

- var node_eachAfter = function(callback) {

-   var node = this, nodes = [node], next = [], children, i, n;

-   while (node = nodes.pop()) {

-     next.push(node), children = node.children;

-     if (children) for (i = 0, n = children.length; i < n; ++i) {

-       nodes.push(children[i]);

-     }

-   }

-   while (node = next.pop()) {

-     callback(node);

-   }

-   return this;

- };

- 

- var node_sum = function(value) {

-   return this.eachAfter(function(node) {

-     var sum = +value(node.data) || 0,

-         children = node.children,

-         i = children && children.length;

-     while (--i >= 0) sum += children[i].value;

-     node.value = sum;

-   });

- };

- 

- var node_sort = function(compare) {

-   return this.eachBefore(function(node) {

-     if (node.children) {

-       node.children.sort(compare);

-     }

-   });

- };

- 

- var node_path = function(end) {

-   var start = this,

-       ancestor = leastCommonAncestor(start, end),

-       nodes = [start];

-   while (start !== ancestor) {

-     start = start.parent;

-     nodes.push(start);

-   }

-   var k = nodes.length;

-   while (end !== ancestor) {

-     nodes.splice(k, 0, end);

-     end = end.parent;

-   }

-   return nodes;

- };

- 

- function leastCommonAncestor(a, b) {

-   if (a === b) return a;

-   var aNodes = a.ancestors(),

-       bNodes = b.ancestors(),

-       c = null;

-   a = aNodes.pop();

-   b = bNodes.pop();

-   while (a === b) {

-     c = a;

-     a = aNodes.pop();

-     b = bNodes.pop();

-   }

-   return c;

- }

- 

- var node_ancestors = function() {

-   var node = this, nodes = [node];

-   while (node = node.parent) {

-     nodes.push(node);

-   }

-   return nodes;

- };

- 

- var node_descendants = function() {

-   var nodes = [];

-   this.each(function(node) {

-     nodes.push(node);

-   });

-   return nodes;

- };

- 

- var node_leaves = function() {

-   var leaves = [];

-   this.eachBefore(function(node) {

-     if (!node.children) {

-       leaves.push(node);

-     }

-   });

-   return leaves;

- };

- 

- var node_links = function() {

-   var root = this, links = [];

-   root.each(function(node) {

-     if (node !== root) { // Don’t include the root’s parent, if any.

-       links.push({source: node.parent, target: node});

-     }

-   });

-   return links;

- };

- 

- function hierarchy(data, children) {

-   var root = new Node(data),

-       valued = +data.value && (root.value = data.value),

-       node,

-       nodes = [root],

-       child,

-       childs,

-       i,

-       n;

- 

-   if (children == null) children = defaultChildren;

- 

-   while (node = nodes.pop()) {

-     if (valued) node.value = +node.data.value;

-     if ((childs = children(node.data)) && (n = childs.length)) {

-       node.children = new Array(n);

-       for (i = n - 1; i >= 0; --i) {

-         nodes.push(child = node.children[i] = new Node(childs[i]));

-         child.parent = node;

-         child.depth = node.depth + 1;

-       }

-     }

-   }

- 

-   return root.eachBefore(computeHeight);

- }

- 

- function node_copy() {

-   return hierarchy(this).eachBefore(copyData);

- }

- 

- function defaultChildren(d) {

-   return d.children;

- }

- 

- function copyData(node) {

-   node.data = node.data.data;

- }

- 

- function computeHeight(node) {

-   var height = 0;

-   do node.height = height;

-   while ((node = node.parent) && (node.height < ++height));

- }

- 

- function Node(data) {

-   this.data = data;

-   this.depth =

-   this.height = 0;

-   this.parent = null;

- }

- 

- Node.prototype = hierarchy.prototype = {

-   constructor: Node,

-   count: node_count,

-   each: node_each,

-   eachAfter: node_eachAfter,

-   eachBefore: node_eachBefore,

-   sum: node_sum,

-   sort: node_sort,

-   path: node_path,

-   ancestors: node_ancestors,

-   descendants: node_descendants,

-   leaves: node_leaves,

-   links: node_links,

-   copy: node_copy

- };

- 

- var slice$3 = Array.prototype.slice;

- 

- function shuffle$1(array) {

-   var m = array.length,

-       t,

-       i;

- 

-   while (m) {

-     i = Math.random() * m-- | 0;

-     t = array[m];

-     array[m] = array[i];

-     array[i] = t;

-   }

- 

-   return array;

- }

- 

- var enclose = function(circles) {

-   var i = 0, n = (circles = shuffle$1(slice$3.call(circles))).length, B = [], p, e;

- 

-   while (i < n) {

-     p = circles[i];

-     if (e && enclosesWeak(e, p)) ++i;

-     else e = encloseBasis(B = extendBasis(B, p)), i = 0;

-   }

- 

-   return e;

- };

- 

- function extendBasis(B, p) {

-   var i, j;

- 

-   if (enclosesWeakAll(p, B)) return [p];

- 

-   // If we get here then B must have at least one element.

-   for (i = 0; i < B.length; ++i) {

-     if (enclosesNot(p, B[i])

-         && enclosesWeakAll(encloseBasis2(B[i], p), B)) {

-       return [B[i], p];

-     }

-   }

- 

-   // If we get here then B must have at least two elements.

-   for (i = 0; i < B.length - 1; ++i) {

-     for (j = i + 1; j < B.length; ++j) {

-       if (enclosesNot(encloseBasis2(B[i], B[j]), p)

-           && enclosesNot(encloseBasis2(B[i], p), B[j])

-           && enclosesNot(encloseBasis2(B[j], p), B[i])

-           && enclosesWeakAll(encloseBasis3(B[i], B[j], p), B)) {

-         return [B[i], B[j], p];

-       }

-     }

-   }

- 

-   // If we get here then something is very wrong.

-   throw new Error;

- }

- 

- function enclosesNot(a, b) {

-   var dr = a.r - b.r, dx = b.x - a.x, dy = b.y - a.y;

-   return dr < 0 || dr * dr < dx * dx + dy * dy;

- }

- 

- function enclosesWeak(a, b) {

-   var dr = a.r - b.r + 1e-6, dx = b.x - a.x, dy = b.y - a.y;

-   return dr > 0 && dr * dr > dx * dx + dy * dy;

- }

- 

- function enclosesWeakAll(a, B) {

-   for (var i = 0; i < B.length; ++i) {

-     if (!enclosesWeak(a, B[i])) {

-       return false;

-     }

-   }

-   return true;

- }

- 

- function encloseBasis(B) {

-   switch (B.length) {

-     case 1: return encloseBasis1(B[0]);

-     case 2: return encloseBasis2(B[0], B[1]);

-     case 3: return encloseBasis3(B[0], B[1], B[2]);

-   }

- }

- 

- function encloseBasis1(a) {

-   return {

-     x: a.x,

-     y: a.y,

-     r: a.r

-   };

- }

- 

- function encloseBasis2(a, b) {

-   var x1 = a.x, y1 = a.y, r1 = a.r,

-       x2 = b.x, y2 = b.y, r2 = b.r,

-       x21 = x2 - x1, y21 = y2 - y1, r21 = r2 - r1,

-       l = Math.sqrt(x21 * x21 + y21 * y21);

-   return {

-     x: (x1 + x2 + x21 / l * r21) / 2,

-     y: (y1 + y2 + y21 / l * r21) / 2,

-     r: (l + r1 + r2) / 2

-   };

- }

- 

- function encloseBasis3(a, b, c) {

-   var x1 = a.x, y1 = a.y, r1 = a.r,

-       x2 = b.x, y2 = b.y, r2 = b.r,

-       x3 = c.x, y3 = c.y, r3 = c.r,

-       a2 = x1 - x2,

-       a3 = x1 - x3,

-       b2 = y1 - y2,

-       b3 = y1 - y3,

-       c2 = r2 - r1,

-       c3 = r3 - r1,

-       d1 = x1 * x1 + y1 * y1 - r1 * r1,

-       d2 = d1 - x2 * x2 - y2 * y2 + r2 * r2,

-       d3 = d1 - x3 * x3 - y3 * y3 + r3 * r3,

-       ab = a3 * b2 - a2 * b3,

-       xa = (b2 * d3 - b3 * d2) / (ab * 2) - x1,

-       xb = (b3 * c2 - b2 * c3) / ab,

-       ya = (a3 * d2 - a2 * d3) / (ab * 2) - y1,

-       yb = (a2 * c3 - a3 * c2) / ab,

-       A = xb * xb + yb * yb - 1,

-       B = 2 * (r1 + xa * xb + ya * yb),

-       C = xa * xa + ya * ya - r1 * r1,

-       r = -(A ? (B + Math.sqrt(B * B - 4 * A * C)) / (2 * A) : C / B);

-   return {

-     x: x1 + xa + xb * r,

-     y: y1 + ya + yb * r,

-     r: r

-   };

- }

- 

- function place(a, b, c) {

-   var ax = a.x,

-       ay = a.y,

-       da = b.r + c.r,

-       db = a.r + c.r,

-       dx = b.x - ax,

-       dy = b.y - ay,

-       dc = dx * dx + dy * dy;

-   if (dc) {

-     var x = 0.5 + ((db *= db) - (da *= da)) / (2 * dc),

-         y = Math.sqrt(Math.max(0, 2 * da * (db + dc) - (db -= dc) * db - da * da)) / (2 * dc);

-     c.x = ax + x * dx + y * dy;

-     c.y = ay + x * dy - y * dx;

-   } else {

-     c.x = ax + db;

-     c.y = ay;

-   }

- }

- 

- function intersects(a, b) {

-   var dx = b.x - a.x,

-       dy = b.y - a.y,

-       dr = a.r + b.r;

-   return dr * dr - 1e-6 > dx * dx + dy * dy;

- }

- 

- function score(node) {

-   var a = node._,

-       b = node.next._,

-       ab = a.r + b.r,

-       dx = (a.x * b.r + b.x * a.r) / ab,

-       dy = (a.y * b.r + b.y * a.r) / ab;

-   return dx * dx + dy * dy;

- }

- 

- function Node$1(circle) {

-   this._ = circle;

-   this.next = null;

-   this.previous = null;

- }

- 

- function packEnclose(circles) {

-   if (!(n = circles.length)) return 0;

- 

-   var a, b, c, n, aa, ca, i, j, k, sj, sk;

- 

-   // Place the first circle.

-   a = circles[0], a.x = 0, a.y = 0;

-   if (!(n > 1)) return a.r;

- 

-   // Place the second circle.

-   b = circles[1], a.x = -b.r, b.x = a.r, b.y = 0;

-   if (!(n > 2)) return a.r + b.r;

- 

-   // Place the third circle.

-   place(b, a, c = circles[2]);

- 

-   // Initialize the front-chain using the first three circles a, b and c.

-   a = new Node$1(a), b = new Node$1(b), c = new Node$1(c);

-   a.next = c.previous = b;

-   b.next = a.previous = c;

-   c.next = b.previous = a;

- 

-   // Attempt to place each remaining circle…

-   pack: for (i = 3; i < n; ++i) {

-     place(a._, b._, c = circles[i]), c = new Node$1(c);

- 

-     // Find the closest intersecting circle on the front-chain, if any.

-     // “Closeness” is determined by linear distance along the front-chain.

-     // “Ahead” or “behind” is likewise determined by linear distance.

-     j = b.next, k = a.previous, sj = b._.r, sk = a._.r;

-     do {

-       if (sj <= sk) {

-         if (intersects(j._, c._)) {

-           b = j, a.next = b, b.previous = a, --i;

-           continue pack;

-         }

-         sj += j._.r, j = j.next;

-       } else {

-         if (intersects(k._, c._)) {

-           a = k, a.next = b, b.previous = a, --i;

-           continue pack;

-         }

-         sk += k._.r, k = k.previous;

-       }

-     } while (j !== k.next);

- 

-     // Success! Insert the new circle c between a and b.

-     c.previous = a, c.next = b, a.next = b.previous = b = c;

- 

-     // Compute the new closest circle pair to the centroid.

-     aa = score(a);

-     while ((c = c.next) !== b) {

-       if ((ca = score(c)) < aa) {

-         a = c, aa = ca;

-       }

-     }

-     b = a.next;

-   }

- 

-   // Compute the enclosing circle of the front chain.

-   a = [b._], c = b; while ((c = c.next) !== b) a.push(c._); c = enclose(a);

- 

-   // Translate the circles to put the enclosing circle around the origin.

-   for (i = 0; i < n; ++i) a = circles[i], a.x -= c.x, a.y -= c.y;

- 

-   return c.r;

- }

- 

- var siblings = function(circles) {

-   packEnclose(circles);

-   return circles;

- };

- 

- function optional(f) {

-   return f == null ? null : required(f);

- }

- 

- function required(f) {

-   if (typeof f !== "function") throw new Error;

-   return f;

- }

- 

- function constantZero() {

-   return 0;

- }

- 

- var constant$8 = function(x) {

-   return function() {

-     return x;

-   };

- };

- 

- function defaultRadius$1(d) {

-   return Math.sqrt(d.value);

- }

- 

- var index$2 = function() {

-   var radius = null,

-       dx = 1,

-       dy = 1,

-       padding = constantZero;

- 

-   function pack(root) {

-     root.x = dx / 2, root.y = dy / 2;

-     if (radius) {

-       root.eachBefore(radiusLeaf(radius))

-           .eachAfter(packChildren(padding, 0.5))

-           .eachBefore(translateChild(1));

-     } else {

-       root.eachBefore(radiusLeaf(defaultRadius$1))

-           .eachAfter(packChildren(constantZero, 1))

-           .eachAfter(packChildren(padding, root.r / Math.min(dx, dy)))

-           .eachBefore(translateChild(Math.min(dx, dy) / (2 * root.r)));

-     }

-     return root;

-   }

- 

-   pack.radius = function(x) {

-     return arguments.length ? (radius = optional(x), pack) : radius;

-   };

- 

-   pack.size = function(x) {

-     return arguments.length ? (dx = +x[0], dy = +x[1], pack) : [dx, dy];

-   };

- 

-   pack.padding = function(x) {

-     return arguments.length ? (padding = typeof x === "function" ? x : constant$8(+x), pack) : padding;

-   };

- 

-   return pack;

- };

- 

- function radiusLeaf(radius) {

-   return function(node) {

-     if (!node.children) {

-       node.r = Math.max(0, +radius(node) || 0);

-     }

-   };

- }

- 

- function packChildren(padding, k) {

-   return function(node) {

-     if (children = node.children) {

-       var children,

-           i,

-           n = children.length,

-           r = padding(node) * k || 0,

-           e;

- 

-       if (r) for (i = 0; i < n; ++i) children[i].r += r;

-       e = packEnclose(children);

-       if (r) for (i = 0; i < n; ++i) children[i].r -= r;

-       node.r = e + r;

-     }

-   };

- }

- 

- function translateChild(k) {

-   return function(node) {

-     var parent = node.parent;

-     node.r *= k;

-     if (parent) {

-       node.x = parent.x + k * node.x;

-       node.y = parent.y + k * node.y;

-     }

-   };

- }

- 

- var roundNode = function(node) {

-   node.x0 = Math.round(node.x0);

-   node.y0 = Math.round(node.y0);

-   node.x1 = Math.round(node.x1);

-   node.y1 = Math.round(node.y1);

- };

- 

- var treemapDice = function(parent, x0, y0, x1, y1) {

-   var nodes = parent.children,

-       node,

-       i = -1,

-       n = nodes.length,

-       k = parent.value && (x1 - x0) / parent.value;

- 

-   while (++i < n) {

-     node = nodes[i], node.y0 = y0, node.y1 = y1;

-     node.x0 = x0, node.x1 = x0 += node.value * k;

-   }

- };

- 

- var partition = function() {

-   var dx = 1,

-       dy = 1,

-       padding = 0,

-       round = false;

- 

-   function partition(root) {

-     var n = root.height + 1;

-     root.x0 =

-     root.y0 = padding;

-     root.x1 = dx;

-     root.y1 = dy / n;

-     root.eachBefore(positionNode(dy, n));

-     if (round) root.eachBefore(roundNode);

-     return root;

-   }

- 

-   function positionNode(dy, n) {

-     return function(node) {

-       if (node.children) {

-         treemapDice(node, node.x0, dy * (node.depth + 1) / n, node.x1, dy * (node.depth + 2) / n);

-       }

-       var x0 = node.x0,

-           y0 = node.y0,

-           x1 = node.x1 - padding,

-           y1 = node.y1 - padding;

-       if (x1 < x0) x0 = x1 = (x0 + x1) / 2;

-       if (y1 < y0) y0 = y1 = (y0 + y1) / 2;

-       node.x0 = x0;

-       node.y0 = y0;

-       node.x1 = x1;

-       node.y1 = y1;

-     };

-   }

- 

-   partition.round = function(x) {

-     return arguments.length ? (round = !!x, partition) : round;

-   };

- 

-   partition.size = function(x) {

-     return arguments.length ? (dx = +x[0], dy = +x[1], partition) : [dx, dy];

-   };

- 

-   partition.padding = function(x) {

-     return arguments.length ? (padding = +x, partition) : padding;

-   };

- 

-   return partition;

- };

- 

- var keyPrefix$1 = "$";

- var preroot = {depth: -1};

- var ambiguous = {};

- 

- function defaultId(d) {

-   return d.id;

- }

- 

- function defaultParentId(d) {

-   return d.parentId;

- }

- 

- var stratify = function() {

-   var id = defaultId,

-       parentId = defaultParentId;

- 

-   function stratify(data) {

-     var d,

-         i,

-         n = data.length,

-         root,

-         parent,

-         node,

-         nodes = new Array(n),

-         nodeId,

-         nodeKey,

-         nodeByKey = {};

- 

-     for (i = 0; i < n; ++i) {

-       d = data[i], node = nodes[i] = new Node(d);

-       if ((nodeId = id(d, i, data)) != null && (nodeId += "")) {

-         nodeKey = keyPrefix$1 + (node.id = nodeId);

-         nodeByKey[nodeKey] = nodeKey in nodeByKey ? ambiguous : node;

-       }

-     }

- 

-     for (i = 0; i < n; ++i) {

-       node = nodes[i], nodeId = parentId(data[i], i, data);

-       if (nodeId == null || !(nodeId += "")) {

-         if (root) throw new Error("multiple roots");

-         root = node;

-       } else {

-         parent = nodeByKey[keyPrefix$1 + nodeId];

-         if (!parent) throw new Error("missing: " + nodeId);

-         if (parent === ambiguous) throw new Error("ambiguous: " + nodeId);

-         if (parent.children) parent.children.push(node);

-         else parent.children = [node];

-         node.parent = parent;

-       }

-     }

- 

-     if (!root) throw new Error("no root");

-     root.parent = preroot;

-     root.eachBefore(function(node) { node.depth = node.parent.depth + 1; --n; }).eachBefore(computeHeight);

-     root.parent = null;

-     if (n > 0) throw new Error("cycle");

- 

-     return root;

-   }

- 

-   stratify.id = function(x) {

-     return arguments.length ? (id = required(x), stratify) : id;

-   };

- 

-   stratify.parentId = function(x) {

-     return arguments.length ? (parentId = required(x), stratify) : parentId;

-   };

- 

-   return stratify;

- };

- 

- function defaultSeparation$1(a, b) {

-   return a.parent === b.parent ? 1 : 2;

- }

- 

- // function radialSeparation(a, b) {

- //   return (a.parent === b.parent ? 1 : 2) / a.depth;

- // }

- 

- // This function is used to traverse the left contour of a subtree (or

- // subforest). It returns the successor of v on this contour. This successor is

- // either given by the leftmost child of v or by the thread of v. The function

- // returns null if and only if v is on the highest level of its subtree.

- function nextLeft(v) {

-   var children = v.children;

-   return children ? children[0] : v.t;

- }

- 

- // This function works analogously to nextLeft.

- function nextRight(v) {

-   var children = v.children;

-   return children ? children[children.length - 1] : v.t;

- }

- 

- // Shifts the current subtree rooted at w+. This is done by increasing

- // prelim(w+) and mod(w+) by shift.

- function moveSubtree(wm, wp, shift) {

-   var change = shift / (wp.i - wm.i);

-   wp.c -= change;

-   wp.s += shift;

-   wm.c += change;

-   wp.z += shift;

-   wp.m += shift;

- }

- 

- // All other shifts, applied to the smaller subtrees between w- and w+, are

- // performed by this function. To prepare the shifts, we have to adjust

- // change(w+), shift(w+), and change(w-).

- function executeShifts(v) {

-   var shift = 0,

-       change = 0,

-       children = v.children,

-       i = children.length,

-       w;

-   while (--i >= 0) {

-     w = children[i];

-     w.z += shift;

-     w.m += shift;

-     shift += w.s + (change += w.c);

-   }

- }

- 

- // If vi-’s ancestor is a sibling of v, returns vi-’s ancestor. Otherwise,

- // returns the specified (default) ancestor.

- function nextAncestor(vim, v, ancestor) {

-   return vim.a.parent === v.parent ? vim.a : ancestor;

- }

- 

- function TreeNode(node, i) {

-   this._ = node;

-   this.parent = null;

-   this.children = null;

-   this.A = null; // default ancestor

-   this.a = this; // ancestor

-   this.z = 0; // prelim

-   this.m = 0; // mod

-   this.c = 0; // change

-   this.s = 0; // shift

-   this.t = null; // thread

-   this.i = i; // number

- }

- 

- TreeNode.prototype = Object.create(Node.prototype);

- 

- function treeRoot(root) {

-   var tree = new TreeNode(root, 0),

-       node,

-       nodes = [tree],

-       child,

-       children,

-       i,

-       n;

- 

-   while (node = nodes.pop()) {

-     if (children = node._.children) {

-       node.children = new Array(n = children.length);

-       for (i = n - 1; i >= 0; --i) {

-         nodes.push(child = node.children[i] = new TreeNode(children[i], i));

-         child.parent = node;

-       }

-     }

-   }

- 

-   (tree.parent = new TreeNode(null, 0)).children = [tree];

-   return tree;

- }

- 

- // Node-link tree diagram using the Reingold-Tilford "tidy" algorithm

- var tree = function() {

-   var separation = defaultSeparation$1,

-       dx = 1,

-       dy = 1,

-       nodeSize = null;

- 

-   function tree(root) {

-     var t = treeRoot(root);

- 

-     // Compute the layout using Buchheim et al.’s algorithm.

-     t.eachAfter(firstWalk), t.parent.m = -t.z;

-     t.eachBefore(secondWalk);

- 

-     // If a fixed node size is specified, scale x and y.

-     if (nodeSize) root.eachBefore(sizeNode);

- 

-     // If a fixed tree size is specified, scale x and y based on the extent.

-     // Compute the left-most, right-most, and depth-most nodes for extents.

-     else {

-       var left = root,

-           right = root,

-           bottom = root;

-       root.eachBefore(function(node) {

-         if (node.x < left.x) left = node;

-         if (node.x > right.x) right = node;

-         if (node.depth > bottom.depth) bottom = node;

-       });

-       var s = left === right ? 1 : separation(left, right) / 2,

-           tx = s - left.x,

-           kx = dx / (right.x + s + tx),

-           ky = dy / (bottom.depth || 1);

-       root.eachBefore(function(node) {

-         node.x = (node.x + tx) * kx;

-         node.y = node.depth * ky;

-       });

-     }

- 

-     return root;

-   }

- 

-   // Computes a preliminary x-coordinate for v. Before that, FIRST WALK is

-   // applied recursively to the children of v, as well as the function

-   // APPORTION. After spacing out the children by calling EXECUTE SHIFTS, the

-   // node v is placed to the midpoint of its outermost children.

-   function firstWalk(v) {

-     var children = v.children,

-         siblings = v.parent.children,

-         w = v.i ? siblings[v.i - 1] : null;

-     if (children) {

-       executeShifts(v);

-       var midpoint = (children[0].z + children[children.length - 1].z) / 2;

-       if (w) {

-         v.z = w.z + separation(v._, w._);

-         v.m = v.z - midpoint;

-       } else {

-         v.z = midpoint;

-       }

-     } else if (w) {

-       v.z = w.z + separation(v._, w._);

-     }

-     v.parent.A = apportion(v, w, v.parent.A || siblings[0]);

-   }

- 

-   // Computes all real x-coordinates by summing up the modifiers recursively.

-   function secondWalk(v) {

-     v._.x = v.z + v.parent.m;

-     v.m += v.parent.m;

-   }

- 

-   // The core of the algorithm. Here, a new subtree is combined with the

-   // previous subtrees. Threads are used to traverse the inside and outside

-   // contours of the left and right subtree up to the highest common level. The

-   // vertices used for the traversals are vi+, vi-, vo-, and vo+, where the

-   // superscript o means outside and i means inside, the subscript - means left

-   // subtree and + means right subtree. For summing up the modifiers along the

-   // contour, we use respective variables si+, si-, so-, and so+. Whenever two

-   // nodes of the inside contours conflict, we compute the left one of the

-   // greatest uncommon ancestors using the function ANCESTOR and call MOVE

-   // SUBTREE to shift the subtree and prepare the shifts of smaller subtrees.

-   // Finally, we add a new thread (if necessary).

-   function apportion(v, w, ancestor) {

-     if (w) {

-       var vip = v,

-           vop = v,

-           vim = w,

-           vom = vip.parent.children[0],

-           sip = vip.m,

-           sop = vop.m,

-           sim = vim.m,

-           som = vom.m,

-           shift;

-       while (vim = nextRight(vim), vip = nextLeft(vip), vim && vip) {

-         vom = nextLeft(vom);

-         vop = nextRight(vop);

-         vop.a = v;

-         shift = vim.z + sim - vip.z - sip + separation(vim._, vip._);

-         if (shift > 0) {

-           moveSubtree(nextAncestor(vim, v, ancestor), v, shift);

-           sip += shift;

-           sop += shift;

-         }

-         sim += vim.m;

-         sip += vip.m;

-         som += vom.m;

-         sop += vop.m;

-       }

-       if (vim && !nextRight(vop)) {

-         vop.t = vim;

-         vop.m += sim - sop;

-       }

-       if (vip && !nextLeft(vom)) {

-         vom.t = vip;

-         vom.m += sip - som;

-         ancestor = v;

-       }

-     }

-     return ancestor;

-   }

- 

-   function sizeNode(node) {

-     node.x *= dx;

-     node.y = node.depth * dy;

-   }

- 

-   tree.separation = function(x) {

-     return arguments.length ? (separation = x, tree) : separation;

-   };

- 

-   tree.size = function(x) {

-     return arguments.length ? (nodeSize = false, dx = +x[0], dy = +x[1], tree) : (nodeSize ? null : [dx, dy]);

-   };

- 

-   tree.nodeSize = function(x) {

-     return arguments.length ? (nodeSize = true, dx = +x[0], dy = +x[1], tree) : (nodeSize ? [dx, dy] : null);

-   };

- 

-   return tree;

- };

- 

- var treemapSlice = function(parent, x0, y0, x1, y1) {

-   var nodes = parent.children,

-       node,

-       i = -1,

-       n = nodes.length,

-       k = parent.value && (y1 - y0) / parent.value;

- 

-   while (++i < n) {

-     node = nodes[i], node.x0 = x0, node.x1 = x1;

-     node.y0 = y0, node.y1 = y0 += node.value * k;

-   }

- };

- 

- var phi = (1 + Math.sqrt(5)) / 2;

- 

- function squarifyRatio(ratio, parent, x0, y0, x1, y1) {

-   var rows = [],

-       nodes = parent.children,

-       row,

-       nodeValue,

-       i0 = 0,

-       i1 = 0,

-       n = nodes.length,

-       dx, dy,

-       value = parent.value,

-       sumValue,

-       minValue,

-       maxValue,

-       newRatio,

-       minRatio,

-       alpha,

-       beta;

- 

-   while (i0 < n) {

-     dx = x1 - x0, dy = y1 - y0;

- 

-     // Find the next non-empty node.

-     do sumValue = nodes[i1++].value; while (!sumValue && i1 < n);

-     minValue = maxValue = sumValue;

-     alpha = Math.max(dy / dx, dx / dy) / (value * ratio);

-     beta = sumValue * sumValue * alpha;

-     minRatio = Math.max(maxValue / beta, beta / minValue);

- 

-     // Keep adding nodes while the aspect ratio maintains or improves.

-     for (; i1 < n; ++i1) {

-       sumValue += nodeValue = nodes[i1].value;

-       if (nodeValue < minValue) minValue = nodeValue;

-       if (nodeValue > maxValue) maxValue = nodeValue;

-       beta = sumValue * sumValue * alpha;

-       newRatio = Math.max(maxValue / beta, beta / minValue);

-       if (newRatio > minRatio) { sumValue -= nodeValue; break; }

-       minRatio = newRatio;

-     }

- 

-     // Position and record the row orientation.

-     rows.push(row = {value: sumValue, dice: dx < dy, children: nodes.slice(i0, i1)});

-     if (row.dice) treemapDice(row, x0, y0, x1, value ? y0 += dy * sumValue / value : y1);

-     else treemapSlice(row, x0, y0, value ? x0 += dx * sumValue / value : x1, y1);

-     value -= sumValue, i0 = i1;

-   }

- 

-   return rows;

- }

- 

- var squarify = (function custom(ratio) {

- 

-   function squarify(parent, x0, y0, x1, y1) {

-     squarifyRatio(ratio, parent, x0, y0, x1, y1);

-   }

- 

-   squarify.ratio = function(x) {

-     return custom((x = +x) > 1 ? x : 1);

-   };

- 

-   return squarify;

- })(phi);

- 

- var index$3 = function() {

-   var tile = squarify,

-       round = false,

-       dx = 1,

-       dy = 1,

-       paddingStack = [0],

-       paddingInner = constantZero,

-       paddingTop = constantZero,

-       paddingRight = constantZero,

-       paddingBottom = constantZero,

-       paddingLeft = constantZero;

- 

-   function treemap(root) {

-     root.x0 =

-     root.y0 = 0;

-     root.x1 = dx;

-     root.y1 = dy;

-     root.eachBefore(positionNode);

-     paddingStack = [0];

-     if (round) root.eachBefore(roundNode);

-     return root;

-   }

- 

-   function positionNode(node) {

-     var p = paddingStack[node.depth],

-         x0 = node.x0 + p,

-         y0 = node.y0 + p,

-         x1 = node.x1 - p,

-         y1 = node.y1 - p;

-     if (x1 < x0) x0 = x1 = (x0 + x1) / 2;

-     if (y1 < y0) y0 = y1 = (y0 + y1) / 2;

-     node.x0 = x0;

-     node.y0 = y0;

-     node.x1 = x1;

-     node.y1 = y1;

-     if (node.children) {

-       p = paddingStack[node.depth + 1] = paddingInner(node) / 2;

-       x0 += paddingLeft(node) - p;

-       y0 += paddingTop(node) - p;

-       x1 -= paddingRight(node) - p;

-       y1 -= paddingBottom(node) - p;

-       if (x1 < x0) x0 = x1 = (x0 + x1) / 2;

-       if (y1 < y0) y0 = y1 = (y0 + y1) / 2;

-       tile(node, x0, y0, x1, y1);

-     }

-   }

- 

-   treemap.round = function(x) {

-     return arguments.length ? (round = !!x, treemap) : round;

-   };

- 

-   treemap.size = function(x) {

-     return arguments.length ? (dx = +x[0], dy = +x[1], treemap) : [dx, dy];

-   };

- 

-   treemap.tile = function(x) {

-     return arguments.length ? (tile = required(x), treemap) : tile;

-   };

- 

-   treemap.padding = function(x) {

-     return arguments.length ? treemap.paddingInner(x).paddingOuter(x) : treemap.paddingInner();

-   };

- 

-   treemap.paddingInner = function(x) {

-     return arguments.length ? (paddingInner = typeof x === "function" ? x : constant$8(+x), treemap) : paddingInner;

-   };

- 

-   treemap.paddingOuter = function(x) {

-     return arguments.length ? treemap.paddingTop(x).paddingRight(x).paddingBottom(x).paddingLeft(x) : treemap.paddingTop();

-   };

- 

-   treemap.paddingTop = function(x) {

-     return arguments.length ? (paddingTop = typeof x === "function" ? x : constant$8(+x), treemap) : paddingTop;

-   };

- 

-   treemap.paddingRight = function(x) {

-     return arguments.length ? (paddingRight = typeof x === "function" ? x : constant$8(+x), treemap) : paddingRight;

-   };

- 

-   treemap.paddingBottom = function(x) {

-     return arguments.length ? (paddingBottom = typeof x === "function" ? x : constant$8(+x), treemap) : paddingBottom;

-   };

- 

-   treemap.paddingLeft = function(x) {

-     return arguments.length ? (paddingLeft = typeof x === "function" ? x : constant$8(+x), treemap) : paddingLeft;

-   };

- 

-   return treemap;

- };

- 

- var binary = function(parent, x0, y0, x1, y1) {

-   var nodes = parent.children,

-       i, n = nodes.length,

-       sum, sums = new Array(n + 1);

- 

-   for (sums[0] = sum = i = 0; i < n; ++i) {

-     sums[i + 1] = sum += nodes[i].value;

-   }

- 

-   partition(0, n, parent.value, x0, y0, x1, y1);

- 

-   function partition(i, j, value, x0, y0, x1, y1) {

-     if (i >= j - 1) {

-       var node = nodes[i];

-       node.x0 = x0, node.y0 = y0;

-       node.x1 = x1, node.y1 = y1;

-       return;

-     }

- 

-     var valueOffset = sums[i],

-         valueTarget = (value / 2) + valueOffset,

-         k = i + 1,

-         hi = j - 1;

- 

-     while (k < hi) {

-       var mid = k + hi >>> 1;

-       if (sums[mid] < valueTarget) k = mid + 1;

-       else hi = mid;

-     }

- 

-     if ((valueTarget - sums[k - 1]) < (sums[k] - valueTarget) && i + 1 < k) --k;

- 

-     var valueLeft = sums[k] - valueOffset,

-         valueRight = value - valueLeft;

- 

-     if ((x1 - x0) > (y1 - y0)) {

-       var xk = (x0 * valueRight + x1 * valueLeft) / value;

-       partition(i, k, valueLeft, x0, y0, xk, y1);

-       partition(k, j, valueRight, xk, y0, x1, y1);

-     } else {

-       var yk = (y0 * valueRight + y1 * valueLeft) / value;

-       partition(i, k, valueLeft, x0, y0, x1, yk);

-       partition(k, j, valueRight, x0, yk, x1, y1);

-     }

-   }

- };

- 

- var sliceDice = function(parent, x0, y0, x1, y1) {

-   (parent.depth & 1 ? treemapSlice : treemapDice)(parent, x0, y0, x1, y1);

- };

- 

- var resquarify = (function custom(ratio) {

- 

-   function resquarify(parent, x0, y0, x1, y1) {

-     if ((rows = parent._squarify) && (rows.ratio === ratio)) {

-       var rows,

-           row,

-           nodes,

-           i,

-           j = -1,

-           n,

-           m = rows.length,

-           value = parent.value;

- 

-       while (++j < m) {

-         row = rows[j], nodes = row.children;

-         for (i = row.value = 0, n = nodes.length; i < n; ++i) row.value += nodes[i].value;

-         if (row.dice) treemapDice(row, x0, y0, x1, y0 += (y1 - y0) * row.value / value);

-         else treemapSlice(row, x0, y0, x0 += (x1 - x0) * row.value / value, y1);

-         value -= row.value;

-       }

-     } else {

-       parent._squarify = rows = squarifyRatio(ratio, parent, x0, y0, x1, y1);

-       rows.ratio = ratio;

-     }

-   }

- 

-   resquarify.ratio = function(x) {

-     return custom((x = +x) > 1 ? x : 1);

-   };

- 

-   return resquarify;

- })(phi);

- 

- var area$1 = function(polygon) {

-   var i = -1,

-       n = polygon.length,

-       a,

-       b = polygon[n - 1],

-       area = 0;

- 

-   while (++i < n) {

-     a = b;

-     b = polygon[i];

-     area += a[1] * b[0] - a[0] * b[1];

-   }

- 

-   return area / 2;

- };

- 

- var centroid$1 = function(polygon) {

-   var i = -1,

-       n = polygon.length,

-       x = 0,

-       y = 0,

-       a,

-       b = polygon[n - 1],

-       c,

-       k = 0;

- 

-   while (++i < n) {

-     a = b;

-     b = polygon[i];

-     k += c = a[0] * b[1] - b[0] * a[1];

-     x += (a[0] + b[0]) * c;

-     y += (a[1] + b[1]) * c;

-   }

- 

-   return k *= 3, [x / k, y / k];

- };

- 

- // Returns the 2D cross product of AB and AC vectors, i.e., the z-component of

- // the 3D cross product in a quadrant I Cartesian coordinate system (+x is

- // right, +y is up). Returns a positive value if ABC is counter-clockwise,

- // negative if clockwise, and zero if the points are collinear.

- var cross$1 = function(a, b, c) {

-   return (b[0] - a[0]) * (c[1] - a[1]) - (b[1] - a[1]) * (c[0] - a[0]);

- };

- 

- function lexicographicOrder(a, b) {

-   return a[0] - b[0] || a[1] - b[1];

- }

- 

- // Computes the upper convex hull per the monotone chain algorithm.

- // Assumes points.length >= 3, is sorted by x, unique in y.

- // Returns an array of indices into points in left-to-right order.

- function computeUpperHullIndexes(points) {

-   var n = points.length,

-       indexes = [0, 1],

-       size = 2;

- 

-   for (var i = 2; i < n; ++i) {

-     while (size > 1 && cross$1(points[indexes[size - 2]], points[indexes[size - 1]], points[i]) <= 0) --size;

-     indexes[size++] = i;

-   }

- 

-   return indexes.slice(0, size); // remove popped points

- }

- 

- var hull = function(points) {

-   if ((n = points.length) < 3) return null;

- 

-   var i,

-       n,

-       sortedPoints = new Array(n),

-       flippedPoints = new Array(n);

- 

-   for (i = 0; i < n; ++i) sortedPoints[i] = [+points[i][0], +points[i][1], i];

-   sortedPoints.sort(lexicographicOrder);

-   for (i = 0; i < n; ++i) flippedPoints[i] = [sortedPoints[i][0], -sortedPoints[i][1]];

- 

-   var upperIndexes = computeUpperHullIndexes(sortedPoints),

-       lowerIndexes = computeUpperHullIndexes(flippedPoints);

- 

-   // Construct the hull polygon, removing possible duplicate endpoints.

-   var skipLeft = lowerIndexes[0] === upperIndexes[0],

-       skipRight = lowerIndexes[lowerIndexes.length - 1] === upperIndexes[upperIndexes.length - 1],

-       hull = [];

- 

-   // Add upper hull in right-to-l order.

-   // Then add lower hull in left-to-right order.

-   for (i = upperIndexes.length - 1; i >= 0; --i) hull.push(points[sortedPoints[upperIndexes[i]][2]]);

-   for (i = +skipLeft; i < lowerIndexes.length - skipRight; ++i) hull.push(points[sortedPoints[lowerIndexes[i]][2]]);

- 

-   return hull;

- };

- 

- var contains$1 = function(polygon, point) {

-   var n = polygon.length,

-       p = polygon[n - 1],

-       x = point[0], y = point[1],

-       x0 = p[0], y0 = p[1],

-       x1, y1,

-       inside = false;

- 

-   for (var i = 0; i < n; ++i) {

-     p = polygon[i], x1 = p[0], y1 = p[1];

-     if (((y1 > y) !== (y0 > y)) && (x < (x0 - x1) * (y - y1) / (y0 - y1) + x1)) inside = !inside;

-     x0 = x1, y0 = y1;

-   }

- 

-   return inside;

- };

- 

- var length$2 = function(polygon) {

-   var i = -1,

-       n = polygon.length,

-       b = polygon[n - 1],

-       xa,

-       ya,

-       xb = b[0],

-       yb = b[1],

-       perimeter = 0;

- 

-   while (++i < n) {

-     xa = xb;

-     ya = yb;

-     b = polygon[i];

-     xb = b[0];

-     yb = b[1];

-     xa -= xb;

-     ya -= yb;

-     perimeter += Math.sqrt(xa * xa + ya * ya);

-   }

- 

-   return perimeter;

- };

- 

- var slice$4 = [].slice;

- 

- var noabort = {};

- 

- function Queue(size) {

-   this._size = size;

-   this._call =

-   this._error = null;

-   this._tasks = [];

-   this._data = [];

-   this._waiting =

-   this._active =

-   this._ended =

-   this._start = 0; // inside a synchronous task callback?

- }

- 

- Queue.prototype = queue.prototype = {

-   constructor: Queue,

-   defer: function(callback) {

-     if (typeof callback !== "function") throw new Error("invalid callback");

-     if (this._call) throw new Error("defer after await");

-     if (this._error != null) return this;

-     var t = slice$4.call(arguments, 1);

-     t.push(callback);

-     ++this._waiting, this._tasks.push(t);

-     poke$1(this);

-     return this;

-   },

-   abort: function() {

-     if (this._error == null) abort(this, new Error("abort"));

-     return this;

-   },

-   await: function(callback) {

-     if (typeof callback !== "function") throw new Error("invalid callback");

-     if (this._call) throw new Error("multiple await");

-     this._call = function(error, results) { callback.apply(null, [error].concat(results)); };

-     maybeNotify(this);

-     return this;

-   },

-   awaitAll: function(callback) {

-     if (typeof callback !== "function") throw new Error("invalid callback");

-     if (this._call) throw new Error("multiple await");

-     this._call = callback;

-     maybeNotify(this);

-     return this;

-   }

- };

- 

- function poke$1(q) {

-   if (!q._start) {

-     try { start$1(q); } // let the current task complete

-     catch (e) {

-       if (q._tasks[q._ended + q._active - 1]) abort(q, e); // task errored synchronously

-       else if (!q._data) throw e; // await callback errored synchronously

-     }

-   }

- }

- 

- function start$1(q) {

-   while (q._start = q._waiting && q._active < q._size) {

-     var i = q._ended + q._active,

-         t = q._tasks[i],

-         j = t.length - 1,

-         c = t[j];

-     t[j] = end(q, i);

-     --q._waiting, ++q._active;

-     t = c.apply(null, t);

-     if (!q._tasks[i]) continue; // task finished synchronously

-     q._tasks[i] = t || noabort;

-   }

- }

- 

- function end(q, i) {

-   return function(e, r) {

-     if (!q._tasks[i]) return; // ignore multiple callbacks

-     --q._active, ++q._ended;

-     q._tasks[i] = null;

-     if (q._error != null) return; // ignore secondary errors

-     if (e != null) {

-       abort(q, e);

-     } else {

-       q._data[i] = r;

-       if (q._waiting) poke$1(q);

-       else maybeNotify(q);

-     }

-   };

- }

- 

- function abort(q, e) {

-   var i = q._tasks.length, t;

-   q._error = e; // ignore active callbacks

-   q._data = undefined; // allow gc

-   q._waiting = NaN; // prevent starting

- 

-   while (--i >= 0) {

-     if (t = q._tasks[i]) {

-       q._tasks[i] = null;

-       if (t.abort) {

-         try { t.abort(); }

-         catch (e) { /* ignore */ }

-       }

-     }

-   }

- 

-   q._active = NaN; // allow notification

-   maybeNotify(q);

- }

- 

- function maybeNotify(q) {

-   if (!q._active && q._call) {

-     var d = q._data;

-     q._data = undefined; // allow gc

-     q._call(q._error, d);

-   }

- }

- 

- function queue(concurrency) {

-   if (concurrency == null) concurrency = Infinity;

-   else if (!((concurrency = +concurrency) >= 1)) throw new Error("invalid concurrency");

-   return new Queue(concurrency);

- }

- 

- var defaultSource$1 = function() {

-   return Math.random();

- };

- 

- var uniform = (function sourceRandomUniform(source) {

-   function randomUniform(min, max) {

-     min = min == null ? 0 : +min;

-     max = max == null ? 1 : +max;

-     if (arguments.length === 1) max = min, min = 0;

-     else max -= min;

-     return function() {

-       return source() * max + min;

-     };

-   }

- 

-   randomUniform.source = sourceRandomUniform;

- 

-   return randomUniform;

- })(defaultSource$1);

- 

- var normal = (function sourceRandomNormal(source) {

-   function randomNormal(mu, sigma) {

-     var x, r;

-     mu = mu == null ? 0 : +mu;

-     sigma = sigma == null ? 1 : +sigma;

-     return function() {

-       var y;

- 

-       // If available, use the second previously-generated uniform random.

-       if (x != null) y = x, x = null;

- 

-       // Otherwise, generate a new x and y.

-       else do {

-         x = source() * 2 - 1;

-         y = source() * 2 - 1;

-         r = x * x + y * y;

-       } while (!r || r > 1);

- 

-       return mu + sigma * y * Math.sqrt(-2 * Math.log(r) / r);

-     };

-   }

- 

-   randomNormal.source = sourceRandomNormal;

- 

-   return randomNormal;

- })(defaultSource$1);

- 

- var logNormal = (function sourceRandomLogNormal(source) {

-   function randomLogNormal() {

-     var randomNormal = normal.source(source).apply(this, arguments);

-     return function() {

-       return Math.exp(randomNormal());

-     };

-   }

- 

-   randomLogNormal.source = sourceRandomLogNormal;

- 

-   return randomLogNormal;

- })(defaultSource$1);

- 

- var irwinHall = (function sourceRandomIrwinHall(source) {

-   function randomIrwinHall(n) {

-     return function() {

-       for (var sum = 0, i = 0; i < n; ++i) sum += source();

-       return sum;

-     };

-   }

- 

-   randomIrwinHall.source = sourceRandomIrwinHall;

- 

-   return randomIrwinHall;

- })(defaultSource$1);

- 

- var bates = (function sourceRandomBates(source) {

-   function randomBates(n) {

-     var randomIrwinHall = irwinHall.source(source)(n);

-     return function() {

-       return randomIrwinHall() / n;

-     };

-   }

- 

-   randomBates.source = sourceRandomBates;

- 

-   return randomBates;

- })(defaultSource$1);

- 

- var exponential$1 = (function sourceRandomExponential(source) {

-   function randomExponential(lambda) {

-     return function() {

-       return -Math.log(1 - source()) / lambda;

-     };

-   }

- 

-   randomExponential.source = sourceRandomExponential;

- 

-   return randomExponential;

- })(defaultSource$1);

- 

- var request = function(url, callback) {

-   var request,

-       event = dispatch("beforesend", "progress", "load", "error"),

-       mimeType,

-       headers = map$1(),

-       xhr = new XMLHttpRequest,

-       user = null,

-       password = null,

-       response,

-       responseType,

-       timeout = 0;

- 

-   // If IE does not support CORS, use XDomainRequest.

-   if (typeof XDomainRequest !== "undefined"

-       && !("withCredentials" in xhr)

-       && /^(http(s)?:)?\/\//.test(url)) xhr = new XDomainRequest;

- 

-   "onload" in xhr

-       ? xhr.onload = xhr.onerror = xhr.ontimeout = respond

-       : xhr.onreadystatechange = function(o) { xhr.readyState > 3 && respond(o); };

- 

-   function respond(o) {

-     var status = xhr.status, result;

-     if (!status && hasResponse(xhr)

-         || status >= 200 && status < 300

-         || status === 304) {

-       if (response) {

-         try {

-           result = response.call(request, xhr);

-         } catch (e) {

-           event.call("error", request, e);

-           return;

-         }

-       } else {

-         result = xhr;

-       }

-       event.call("load", request, result);

-     } else {

-       event.call("error", request, o);

-     }

-   }

- 

-   xhr.onprogress = function(e) {

-     event.call("progress", request, e);

-   };

- 

-   request = {

-     header: function(name, value) {

-       name = (name + "").toLowerCase();

-       if (arguments.length < 2) return headers.get(name);

-       if (value == null) headers.remove(name);

-       else headers.set(name, value + "");

-       return request;

-     },

- 

-     // If mimeType is non-null and no Accept header is set, a default is used.

-     mimeType: function(value) {

-       if (!arguments.length) return mimeType;

-       mimeType = value == null ? null : value + "";

-       return request;

-     },

- 

-     // Specifies what type the response value should take;

-     // for instance, arraybuffer, blob, document, or text.

-     responseType: function(value) {

-       if (!arguments.length) return responseType;

-       responseType = value;

-       return request;

-     },

- 

-     timeout: function(value) {

-       if (!arguments.length) return timeout;

-       timeout = +value;

-       return request;

-     },

- 

-     user: function(value) {

-       return arguments.length < 1 ? user : (user = value == null ? null : value + "", request);

-     },

- 

-     password: function(value) {

-       return arguments.length < 1 ? password : (password = value == null ? null : value + "", request);

-     },

- 

-     // Specify how to convert the response content to a specific type;

-     // changes the callback value on "load" events.

-     response: function(value) {

-       response = value;

-       return request;

-     },

- 

-     // Alias for send("GET", …).

-     get: function(data, callback) {

-       return request.send("GET", data, callback);

-     },

- 

-     // Alias for send("POST", …).

-     post: function(data, callback) {

-       return request.send("POST", data, callback);

-     },

- 

-     // If callback is non-null, it will be used for error and load events.

-     send: function(method, data, callback) {

-       xhr.open(method, url, true, user, password);

-       if (mimeType != null && !headers.has("accept")) headers.set("accept", mimeType + ",*/*");

-       if (xhr.setRequestHeader) headers.each(function(value, name) { xhr.setRequestHeader(name, value); });

-       if (mimeType != null && xhr.overrideMimeType) xhr.overrideMimeType(mimeType);

-       if (responseType != null) xhr.responseType = responseType;

-       if (timeout > 0) xhr.timeout = timeout;

-       if (callback == null && typeof data === "function") callback = data, data = null;

-       if (callback != null && callback.length === 1) callback = fixCallback(callback);

-       if (callback != null) request.on("error", callback).on("load", function(xhr) { callback(null, xhr); });

-       event.call("beforesend", request, xhr);

-       xhr.send(data == null ? null : data);

-       return request;

-     },

- 

-     abort: function() {

-       xhr.abort();

-       return request;

-     },

- 

-     on: function() {

-       var value = event.on.apply(event, arguments);

-       return value === event ? request : value;

-     }

-   };

- 

-   if (callback != null) {

-     if (typeof callback !== "function") throw new Error("invalid callback: " + callback);

-     return request.get(callback);

-   }

- 

-   return request;

- };

- 

- function fixCallback(callback) {

-   return function(error, xhr) {

-     callback(error == null ? xhr : null);

-   };

- }

- 

- function hasResponse(xhr) {

-   var type = xhr.responseType;

-   return type && type !== "text"

-       ? xhr.response // null on error

-       : xhr.responseText; // "" on error

- }

- 

- var type$1 = function(defaultMimeType, response) {

-   return function(url, callback) {

-     var r = request(url).mimeType(defaultMimeType).response(response);

-     if (callback != null) {

-       if (typeof callback !== "function") throw new Error("invalid callback: " + callback);

-       return r.get(callback);

-     }

-     return r;

-   };

- };

- 

- var html = type$1("text/html", function(xhr) {

-   return document.createRange().createContextualFragment(xhr.responseText);

- });

- 

- var json = type$1("application/json", function(xhr) {

-   return JSON.parse(xhr.responseText);

- });

- 

- var text = type$1("text/plain", function(xhr) {

-   return xhr.responseText;

- });

- 

- var xml = type$1("application/xml", function(xhr) {

-   var xml = xhr.responseXML;

-   if (!xml) throw new Error("parse error");

-   return xml;

- });

- 

- var dsv$1 = function(defaultMimeType, parse) {

-   return function(url, row, callback) {

-     if (arguments.length < 3) callback = row, row = null;

-     var r = request(url).mimeType(defaultMimeType);

-     r.row = function(_) { return arguments.length ? r.response(responseOf(parse, row = _)) : row; };

-     r.row(row);

-     return callback ? r.get(callback) : r;

-   };

- };

- 

- function responseOf(parse, row) {

-   return function(request$$1) {

-     return parse(request$$1.responseText, row);

-   };

- }

- 

- var csv$1 = dsv$1("text/csv", csvParse);

- 

- var tsv$1 = dsv$1("text/tab-separated-values", tsvParse);

- 

- var array$2 = Array.prototype;

- 

- var map$3 = array$2.map;

- var slice$5 = array$2.slice;

- 

- var implicit = {name: "implicit"};

- 

- function ordinal(range) {

-   var index = map$1(),

-       domain = [],

-       unknown = implicit;

- 

-   range = range == null ? [] : slice$5.call(range);

- 

-   function scale(d) {

-     var key = d + "", i = index.get(key);

-     if (!i) {

-       if (unknown !== implicit) return unknown;

-       index.set(key, i = domain.push(d));

-     }

-     return range[(i - 1) % range.length];

-   }

- 

-   scale.domain = function(_) {

-     if (!arguments.length) return domain.slice();

-     domain = [], index = map$1();

-     var i = -1, n = _.length, d, key;

-     while (++i < n) if (!index.has(key = (d = _[i]) + "")) index.set(key, domain.push(d));

-     return scale;

-   };

- 

-   scale.range = function(_) {

-     return arguments.length ? (range = slice$5.call(_), scale) : range.slice();

-   };

- 

-   scale.unknown = function(_) {

-     return arguments.length ? (unknown = _, scale) : unknown;

-   };

- 

-   scale.copy = function() {

-     return ordinal()

-         .domain(domain)

-         .range(range)

-         .unknown(unknown);

-   };

- 

-   return scale;

- }

- 

- function band() {

-   var scale = ordinal().unknown(undefined),

-       domain = scale.domain,

-       ordinalRange = scale.range,

-       range$$1 = [0, 1],

-       step,

-       bandwidth,

-       round = false,

-       paddingInner = 0,

-       paddingOuter = 0,

-       align = 0.5;

- 

-   delete scale.unknown;

- 

-   function rescale() {

-     var n = domain().length,

-         reverse = range$$1[1] < range$$1[0],

-         start = range$$1[reverse - 0],

-         stop = range$$1[1 - reverse];

-     step = (stop - start) / Math.max(1, n - paddingInner + paddingOuter * 2);

-     if (round) step = Math.floor(step);

-     start += (stop - start - step * (n - paddingInner)) * align;

-     bandwidth = step * (1 - paddingInner);

-     if (round) start = Math.round(start), bandwidth = Math.round(bandwidth);

-     var values = sequence(n).map(function(i) { return start + step * i; });

-     return ordinalRange(reverse ? values.reverse() : values);

-   }

- 

-   scale.domain = function(_) {

-     return arguments.length ? (domain(_), rescale()) : domain();

-   };

- 

-   scale.range = function(_) {

-     return arguments.length ? (range$$1 = [+_[0], +_[1]], rescale()) : range$$1.slice();

-   };

- 

-   scale.rangeRound = function(_) {

-     return range$$1 = [+_[0], +_[1]], round = true, rescale();

-   };

- 

-   scale.bandwidth = function() {

-     return bandwidth;

-   };

- 

-   scale.step = function() {

-     return step;

-   };

- 

-   scale.round = function(_) {

-     return arguments.length ? (round = !!_, rescale()) : round;

-   };

- 

-   scale.padding = function(_) {

-     return arguments.length ? (paddingInner = paddingOuter = Math.max(0, Math.min(1, _)), rescale()) : paddingInner;

-   };

- 

-   scale.paddingInner = function(_) {

-     return arguments.length ? (paddingInner = Math.max(0, Math.min(1, _)), rescale()) : paddingInner;

-   };

- 

-   scale.paddingOuter = function(_) {

-     return arguments.length ? (paddingOuter = Math.max(0, Math.min(1, _)), rescale()) : paddingOuter;

-   };

- 

-   scale.align = function(_) {

-     return arguments.length ? (align = Math.max(0, Math.min(1, _)), rescale()) : align;

-   };

- 

-   scale.copy = function() {

-     return band()

-         .domain(domain())

-         .range(range$$1)

-         .round(round)

-         .paddingInner(paddingInner)

-         .paddingOuter(paddingOuter)

-         .align(align);

-   };

- 

-   return rescale();

- }

- 

- function pointish(scale) {

-   var copy = scale.copy;

- 

-   scale.padding = scale.paddingOuter;

-   delete scale.paddingInner;

-   delete scale.paddingOuter;

- 

-   scale.copy = function() {

-     return pointish(copy());

-   };

- 

-   return scale;

- }

- 

- function point$1() {

-   return pointish(band().paddingInner(1));

- }

- 

- var constant$9 = function(x) {

-   return function() {

-     return x;

-   };

- };

- 

- var number$2 = function(x) {

-   return +x;

- };

- 

- var unit = [0, 1];

- 

- function deinterpolateLinear(a, b) {

-   return (b -= (a = +a))

-       ? function(x) { return (x - a) / b; }

-       : constant$9(b);

- }

- 

- function deinterpolateClamp(deinterpolate) {

-   return function(a, b) {

-     var d = deinterpolate(a = +a, b = +b);

-     return function(x) { return x <= a ? 0 : x >= b ? 1 : d(x); };

-   };

- }

- 

- function reinterpolateClamp(reinterpolate) {

-   return function(a, b) {

-     var r = reinterpolate(a = +a, b = +b);

-     return function(t) { return t <= 0 ? a : t >= 1 ? b : r(t); };

-   };

- }

- 

- function bimap(domain, range, deinterpolate, reinterpolate) {

-   var d0 = domain[0], d1 = domain[1], r0 = range[0], r1 = range[1];

-   if (d1 < d0) d0 = deinterpolate(d1, d0), r0 = reinterpolate(r1, r0);

-   else d0 = deinterpolate(d0, d1), r0 = reinterpolate(r0, r1);

-   return function(x) { return r0(d0(x)); };

- }

- 

- function polymap(domain, range, deinterpolate, reinterpolate) {

-   var j = Math.min(domain.length, range.length) - 1,

-       d = new Array(j),

-       r = new Array(j),

-       i = -1;

- 

-   // Reverse descending domains.

-   if (domain[j] < domain[0]) {

-     domain = domain.slice().reverse();

-     range = range.slice().reverse();

-   }

- 

-   while (++i < j) {

-     d[i] = deinterpolate(domain[i], domain[i + 1]);

-     r[i] = reinterpolate(range[i], range[i + 1]);

-   }

- 

-   return function(x) {

-     var i = bisectRight(domain, x, 1, j) - 1;

-     return r[i](d[i](x));

-   };

- }

- 

- function copy(source, target) {

-   return target

-       .domain(source.domain())

-       .range(source.range())

-       .interpolate(source.interpolate())

-       .clamp(source.clamp());

- }

- 

- // deinterpolate(a, b)(x) takes a domain value x in [a,b] and returns the corresponding parameter t in [0,1].

- // reinterpolate(a, b)(t) takes a parameter t in [0,1] and returns the corresponding domain value x in [a,b].

- function continuous(deinterpolate, reinterpolate) {

-   var domain = unit,

-       range = unit,

-       interpolate$$1 = interpolateValue,

-       clamp = false,

-       piecewise,

-       output,

-       input;

- 

-   function rescale() {

-     piecewise = Math.min(domain.length, range.length) > 2 ? polymap : bimap;

-     output = input = null;

-     return scale;

-   }

- 

-   function scale(x) {

-     return (output || (output = piecewise(domain, range, clamp ? deinterpolateClamp(deinterpolate) : deinterpolate, interpolate$$1)))(+x);

-   }

- 

-   scale.invert = function(y) {

-     return (input || (input = piecewise(range, domain, deinterpolateLinear, clamp ? reinterpolateClamp(reinterpolate) : reinterpolate)))(+y);

-   };

- 

-   scale.domain = function(_) {

-     return arguments.length ? (domain = map$3.call(_, number$2), rescale()) : domain.slice();

-   };

- 

-   scale.range = function(_) {

-     return arguments.length ? (range = slice$5.call(_), rescale()) : range.slice();

-   };

- 

-   scale.rangeRound = function(_) {

-     return range = slice$5.call(_), interpolate$$1 = interpolateRound, rescale();

-   };

- 

-   scale.clamp = function(_) {

-     return arguments.length ? (clamp = !!_, rescale()) : clamp;

-   };

- 

-   scale.interpolate = function(_) {

-     return arguments.length ? (interpolate$$1 = _, rescale()) : interpolate$$1;

-   };

- 

-   return rescale();

- }

- 

- var tickFormat = function(domain, count, specifier) {

-   var start = domain[0],

-       stop = domain[domain.length - 1],

-       step = tickStep(start, stop, count == null ? 10 : count),

-       precision;

-   specifier = formatSpecifier(specifier == null ? ",f" : specifier);

-   switch (specifier.type) {

-     case "s": {

-       var value = Math.max(Math.abs(start), Math.abs(stop));

-       if (specifier.precision == null && !isNaN(precision = precisionPrefix(step, value))) specifier.precision = precision;

-       return exports.formatPrefix(specifier, value);

-     }

-     case "":

-     case "e":

-     case "g":

-     case "p":

-     case "r": {

-       if (specifier.precision == null && !isNaN(precision = precisionRound(step, Math.max(Math.abs(start), Math.abs(stop))))) specifier.precision = precision - (specifier.type === "e");

-       break;

-     }

-     case "f":

-     case "%": {

-       if (specifier.precision == null && !isNaN(precision = precisionFixed(step))) specifier.precision = precision - (specifier.type === "%") * 2;

-       break;

-     }

-   }

-   return exports.format(specifier);

- };

- 

- function linearish(scale) {

-   var domain = scale.domain;

- 

-   scale.ticks = function(count) {

-     var d = domain();

-     return ticks(d[0], d[d.length - 1], count == null ? 10 : count);

-   };

- 

-   scale.tickFormat = function(count, specifier) {

-     return tickFormat(domain(), count, specifier);

-   };

- 

-   scale.nice = function(count) {

-     if (count == null) count = 10;

- 

-     var d = domain(),

-         i0 = 0,

-         i1 = d.length - 1,

-         start = d[i0],

-         stop = d[i1],

-         step;

- 

-     if (stop < start) {

-       step = start, start = stop, stop = step;

-       step = i0, i0 = i1, i1 = step;

-     }

- 

-     step = tickIncrement(start, stop, count);

- 

-     if (step > 0) {

-       start = Math.floor(start / step) * step;

-       stop = Math.ceil(stop / step) * step;

-       step = tickIncrement(start, stop, count);

-     } else if (step < 0) {

-       start = Math.ceil(start * step) / step;

-       stop = Math.floor(stop * step) / step;

-       step = tickIncrement(start, stop, count);

-     }

- 

-     if (step > 0) {

-       d[i0] = Math.floor(start / step) * step;

-       d[i1] = Math.ceil(stop / step) * step;

-       domain(d);

-     } else if (step < 0) {

-       d[i0] = Math.ceil(start * step) / step;

-       d[i1] = Math.floor(stop * step) / step;

-       domain(d);

-     }

- 

-     return scale;

-   };

- 

-   return scale;

- }

- 

- function linear$2() {

-   var scale = continuous(deinterpolateLinear, reinterpolate);

- 

-   scale.copy = function() {

-     return copy(scale, linear$2());

-   };

- 

-   return linearish(scale);

- }

- 

- function identity$6() {

-   var domain = [0, 1];

- 

-   function scale(x) {

-     return +x;

-   }

- 

-   scale.invert = scale;

- 

-   scale.domain = scale.range = function(_) {

-     return arguments.length ? (domain = map$3.call(_, number$2), scale) : domain.slice();

-   };

- 

-   scale.copy = function() {

-     return identity$6().domain(domain);

-   };

- 

-   return linearish(scale);

- }

- 

- var nice = function(domain, interval) {

-   domain = domain.slice();

- 

-   var i0 = 0,

-       i1 = domain.length - 1,

-       x0 = domain[i0],

-       x1 = domain[i1],

-       t;

- 

-   if (x1 < x0) {

-     t = i0, i0 = i1, i1 = t;

-     t = x0, x0 = x1, x1 = t;

-   }

- 

-   domain[i0] = interval.floor(x0);

-   domain[i1] = interval.ceil(x1);

-   return domain;

- };

- 

- function deinterpolate(a, b) {

-   return (b = Math.log(b / a))

-       ? function(x) { return Math.log(x / a) / b; }

-       : constant$9(b);

- }

- 

- function reinterpolate$1(a, b) {

-   return a < 0

-       ? function(t) { return -Math.pow(-b, t) * Math.pow(-a, 1 - t); }

-       : function(t) { return Math.pow(b, t) * Math.pow(a, 1 - t); };

- }

- 

- function pow10(x) {

-   return isFinite(x) ? +("1e" + x) : x < 0 ? 0 : x;

- }

- 

- function powp(base) {

-   return base === 10 ? pow10

-       : base === Math.E ? Math.exp

-       : function(x) { return Math.pow(base, x); };

- }

- 

- function logp(base) {

-   return base === Math.E ? Math.log

-       : base === 10 && Math.log10

-       || base === 2 && Math.log2

-       || (base = Math.log(base), function(x) { return Math.log(x) / base; });

- }

- 

- function reflect(f) {

-   return function(x) {

-     return -f(-x);

-   };

- }

- 

- function log$1() {

-   var scale = continuous(deinterpolate, reinterpolate$1).domain([1, 10]),

-       domain = scale.domain,

-       base = 10,

-       logs = logp(10),

-       pows = powp(10);

- 

-   function rescale() {

-     logs = logp(base), pows = powp(base);

-     if (domain()[0] < 0) logs = reflect(logs), pows = reflect(pows);

-     return scale;

-   }

- 

-   scale.base = function(_) {

-     return arguments.length ? (base = +_, rescale()) : base;

-   };

- 

-   scale.domain = function(_) {

-     return arguments.length ? (domain(_), rescale()) : domain();

-   };

- 

-   scale.ticks = function(count) {

-     var d = domain(),

-         u = d[0],

-         v = d[d.length - 1],

-         r;

- 

-     if (r = v < u) i = u, u = v, v = i;

- 

-     var i = logs(u),

-         j = logs(v),

-         p,

-         k,

-         t,

-         n = count == null ? 10 : +count,

-         z = [];

- 

-     if (!(base % 1) && j - i < n) {

-       i = Math.round(i) - 1, j = Math.round(j) + 1;

-       if (u > 0) for (; i < j; ++i) {

-         for (k = 1, p = pows(i); k < base; ++k) {

-           t = p * k;

-           if (t < u) continue;

-           if (t > v) break;

-           z.push(t);

-         }

-       } else for (; i < j; ++i) {

-         for (k = base - 1, p = pows(i); k >= 1; --k) {

-           t = p * k;

-           if (t < u) continue;

-           if (t > v) break;

-           z.push(t);

-         }

-       }

-     } else {

-       z = ticks(i, j, Math.min(j - i, n)).map(pows);

-     }

- 

-     return r ? z.reverse() : z;

-   };

- 

-   scale.tickFormat = function(count, specifier) {

-     if (specifier == null) specifier = base === 10 ? ".0e" : ",";

-     if (typeof specifier !== "function") specifier = exports.format(specifier);

-     if (count === Infinity) return specifier;

-     if (count == null) count = 10;

-     var k = Math.max(1, base * count / scale.ticks().length); // TODO fast estimate?

-     return function(d) {

-       var i = d / pows(Math.round(logs(d)));

-       if (i * base < base - 0.5) i *= base;

-       return i <= k ? specifier(d) : "";

-     };

-   };

- 

-   scale.nice = function() {

-     return domain(nice(domain(), {

-       floor: function(x) { return pows(Math.floor(logs(x))); },

-       ceil: function(x) { return pows(Math.ceil(logs(x))); }

-     }));

-   };

- 

-   scale.copy = function() {

-     return copy(scale, log$1().base(base));

-   };

- 

-   return scale;

- }

- 

- function raise$1(x, exponent) {

-   return x < 0 ? -Math.pow(-x, exponent) : Math.pow(x, exponent);

- }

- 

- function pow$1() {

-   var exponent = 1,

-       scale = continuous(deinterpolate, reinterpolate),

-       domain = scale.domain;

- 

-   function deinterpolate(a, b) {

-     return (b = raise$1(b, exponent) - (a = raise$1(a, exponent)))

-         ? function(x) { return (raise$1(x, exponent) - a) / b; }

-         : constant$9(b);

-   }

- 

-   function reinterpolate(a, b) {

-     b = raise$1(b, exponent) - (a = raise$1(a, exponent));

-     return function(t) { return raise$1(a + b * t, 1 / exponent); };

-   }

- 

-   scale.exponent = function(_) {

-     return arguments.length ? (exponent = +_, domain(domain())) : exponent;

-   };

- 

-   scale.copy = function() {

-     return copy(scale, pow$1().exponent(exponent));

-   };

- 

-   return linearish(scale);

- }

- 

- function sqrt$1() {

-   return pow$1().exponent(0.5);

- }

- 

- function quantile$$1() {

-   var domain = [],

-       range = [],

-       thresholds = [];

- 

-   function rescale() {

-     var i = 0, n = Math.max(1, range.length);

-     thresholds = new Array(n - 1);

-     while (++i < n) thresholds[i - 1] = threshold(domain, i / n);

-     return scale;

-   }

- 

-   function scale(x) {

-     if (!isNaN(x = +x)) return range[bisectRight(thresholds, x)];

-   }

- 

-   scale.invertExtent = function(y) {

-     var i = range.indexOf(y);

-     return i < 0 ? [NaN, NaN] : [

-       i > 0 ? thresholds[i - 1] : domain[0],

-       i < thresholds.length ? thresholds[i] : domain[domain.length - 1]

-     ];

-   };

- 

-   scale.domain = function(_) {

-     if (!arguments.length) return domain.slice();

-     domain = [];

-     for (var i = 0, n = _.length, d; i < n; ++i) if (d = _[i], d != null && !isNaN(d = +d)) domain.push(d);

-     domain.sort(ascending);

-     return rescale();

-   };

- 

-   scale.range = function(_) {

-     return arguments.length ? (range = slice$5.call(_), rescale()) : range.slice();

-   };

- 

-   scale.quantiles = function() {

-     return thresholds.slice();

-   };

- 

-   scale.copy = function() {

-     return quantile$$1()

-         .domain(domain)

-         .range(range);

-   };

- 

-   return scale;

- }

- 

- function quantize$1() {

-   var x0 = 0,

-       x1 = 1,

-       n = 1,

-       domain = [0.5],

-       range = [0, 1];

- 

-   function scale(x) {

-     if (x <= x) return range[bisectRight(domain, x, 0, n)];

-   }

- 

-   function rescale() {

-     var i = -1;

-     domain = new Array(n);

-     while (++i < n) domain[i] = ((i + 1) * x1 - (i - n) * x0) / (n + 1);

-     return scale;

-   }

- 

-   scale.domain = function(_) {

-     return arguments.length ? (x0 = +_[0], x1 = +_[1], rescale()) : [x0, x1];

-   };

- 

-   scale.range = function(_) {

-     return arguments.length ? (n = (range = slice$5.call(_)).length - 1, rescale()) : range.slice();

-   };

- 

-   scale.invertExtent = function(y) {

-     var i = range.indexOf(y);

-     return i < 0 ? [NaN, NaN]

-         : i < 1 ? [x0, domain[0]]

-         : i >= n ? [domain[n - 1], x1]

-         : [domain[i - 1], domain[i]];

-   };

- 

-   scale.copy = function() {

-     return quantize$1()

-         .domain([x0, x1])

-         .range(range);

-   };

- 

-   return linearish(scale);

- }

- 

- function threshold$1() {

-   var domain = [0.5],

-       range = [0, 1],

-       n = 1;

- 

-   function scale(x) {

-     if (x <= x) return range[bisectRight(domain, x, 0, n)];

-   }

- 

-   scale.domain = function(_) {

-     return arguments.length ? (domain = slice$5.call(_), n = Math.min(domain.length, range.length - 1), scale) : domain.slice();

-   };

- 

-   scale.range = function(_) {

-     return arguments.length ? (range = slice$5.call(_), n = Math.min(domain.length, range.length - 1), scale) : range.slice();

-   };

- 

-   scale.invertExtent = function(y) {

-     var i = range.indexOf(y);

-     return [domain[i - 1], domain[i]];

-   };

- 

-   scale.copy = function() {

-     return threshold$1()

-         .domain(domain)

-         .range(range);

-   };

- 

-   return scale;

- }

- 

- var t0$1 = new Date;

- var t1$1 = new Date;

- 

- function newInterval(floori, offseti, count, field) {

- 

-   function interval(date) {

-     return floori(date = new Date(+date)), date;

-   }

- 

-   interval.floor = interval;

- 

-   interval.ceil = function(date) {

-     return floori(date = new Date(date - 1)), offseti(date, 1), floori(date), date;

-   };

- 

-   interval.round = function(date) {

-     var d0 = interval(date),

-         d1 = interval.ceil(date);

-     return date - d0 < d1 - date ? d0 : d1;

-   };

- 

-   interval.offset = function(date, step) {

-     return offseti(date = new Date(+date), step == null ? 1 : Math.floor(step)), date;

-   };

- 

-   interval.range = function(start, stop, step) {

-     var range = [];

-     start = interval.ceil(start);

-     step = step == null ? 1 : Math.floor(step);

-     if (!(start < stop) || !(step > 0)) return range; // also handles Invalid Date

-     do range.push(new Date(+start)); while (offseti(start, step), floori(start), start < stop)

-     return range;

-   };

- 

-   interval.filter = function(test) {

-     return newInterval(function(date) {

-       if (date >= date) while (floori(date), !test(date)) date.setTime(date - 1);

-     }, function(date, step) {

-       if (date >= date) {

-         if (step < 0) while (++step <= 0) {

-           while (offseti(date, -1), !test(date)) {} // eslint-disable-line no-empty

-         } else while (--step >= 0) {

-           while (offseti(date, +1), !test(date)) {} // eslint-disable-line no-empty

-         }

-       }

-     });

-   };

- 

-   if (count) {

-     interval.count = function(start, end) {

-       t0$1.setTime(+start), t1$1.setTime(+end);

-       floori(t0$1), floori(t1$1);

-       return Math.floor(count(t0$1, t1$1));

-     };

- 

-     interval.every = function(step) {

-       step = Math.floor(step);

-       return !isFinite(step) || !(step > 0) ? null

-           : !(step > 1) ? interval

-           : interval.filter(field

-               ? function(d) { return field(d) % step === 0; }

-               : function(d) { return interval.count(0, d) % step === 0; });

-     };

-   }

- 

-   return interval;

- }

- 

- var millisecond = newInterval(function() {

-   // noop

- }, function(date, step) {

-   date.setTime(+date + step);

- }, function(start, end) {

-   return end - start;

- });

- 

- // An optimized implementation for this simple case.

- millisecond.every = function(k) {

-   k = Math.floor(k);

-   if (!isFinite(k) || !(k > 0)) return null;

-   if (!(k > 1)) return millisecond;

-   return newInterval(function(date) {

-     date.setTime(Math.floor(date / k) * k);

-   }, function(date, step) {

-     date.setTime(+date + step * k);

-   }, function(start, end) {

-     return (end - start) / k;

-   });

- };

- 

- var milliseconds = millisecond.range;

- 

- var durationSecond$1 = 1e3;

- var durationMinute$1 = 6e4;

- var durationHour$1 = 36e5;

- var durationDay$1 = 864e5;

- var durationWeek$1 = 6048e5;

- 

- var second = newInterval(function(date) {

-   date.setTime(Math.floor(date / durationSecond$1) * durationSecond$1);

- }, function(date, step) {

-   date.setTime(+date + step * durationSecond$1);

- }, function(start, end) {

-   return (end - start) / durationSecond$1;

- }, function(date) {

-   return date.getUTCSeconds();

- });

- 

- var seconds = second.range;

- 

- var minute = newInterval(function(date) {

-   date.setTime(Math.floor(date / durationMinute$1) * durationMinute$1);

- }, function(date, step) {

-   date.setTime(+date + step * durationMinute$1);

- }, function(start, end) {

-   return (end - start) / durationMinute$1;

- }, function(date) {

-   return date.getMinutes();

- });

- 

- var minutes = minute.range;

- 

- var hour = newInterval(function(date) {

-   var offset = date.getTimezoneOffset() * durationMinute$1 % durationHour$1;

-   if (offset < 0) offset += durationHour$1;

-   date.setTime(Math.floor((+date - offset) / durationHour$1) * durationHour$1 + offset);

- }, function(date, step) {

-   date.setTime(+date + step * durationHour$1);

- }, function(start, end) {

-   return (end - start) / durationHour$1;

- }, function(date) {

-   return date.getHours();

- });

- 

- var hours = hour.range;

- 

- var day = newInterval(function(date) {

-   date.setHours(0, 0, 0, 0);

- }, function(date, step) {

-   date.setDate(date.getDate() + step);

- }, function(start, end) {

-   return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute$1) / durationDay$1;

- }, function(date) {

-   return date.getDate() - 1;

- });

- 

- var days = day.range;

- 

- function weekday(i) {

-   return newInterval(function(date) {

-     date.setDate(date.getDate() - (date.getDay() + 7 - i) % 7);

-     date.setHours(0, 0, 0, 0);

-   }, function(date, step) {

-     date.setDate(date.getDate() + step * 7);

-   }, function(start, end) {

-     return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute$1) / durationWeek$1;

-   });

- }

- 

- var sunday = weekday(0);

- var monday = weekday(1);

- var tuesday = weekday(2);

- var wednesday = weekday(3);

- var thursday = weekday(4);

- var friday = weekday(5);

- var saturday = weekday(6);

- 

- var sundays = sunday.range;

- var mondays = monday.range;

- var tuesdays = tuesday.range;

- var wednesdays = wednesday.range;

- var thursdays = thursday.range;

- var fridays = friday.range;

- var saturdays = saturday.range;

- 

- var month = newInterval(function(date) {

-   date.setDate(1);

-   date.setHours(0, 0, 0, 0);

- }, function(date, step) {

-   date.setMonth(date.getMonth() + step);

- }, function(start, end) {

-   return end.getMonth() - start.getMonth() + (end.getFullYear() - start.getFullYear()) * 12;

- }, function(date) {

-   return date.getMonth();

- });

- 

- var months = month.range;

- 

- var year = newInterval(function(date) {

-   date.setMonth(0, 1);

-   date.setHours(0, 0, 0, 0);

- }, function(date, step) {

-   date.setFullYear(date.getFullYear() + step);

- }, function(start, end) {

-   return end.getFullYear() - start.getFullYear();

- }, function(date) {

-   return date.getFullYear();

- });

- 

- // An optimized implementation for this simple case.

- year.every = function(k) {

-   return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : newInterval(function(date) {

-     date.setFullYear(Math.floor(date.getFullYear() / k) * k);

-     date.setMonth(0, 1);

-     date.setHours(0, 0, 0, 0);

-   }, function(date, step) {

-     date.setFullYear(date.getFullYear() + step * k);

-   });

- };

- 

- var years = year.range;

- 

- var utcMinute = newInterval(function(date) {

-   date.setUTCSeconds(0, 0);

- }, function(date, step) {

-   date.setTime(+date + step * durationMinute$1);

- }, function(start, end) {

-   return (end - start) / durationMinute$1;

- }, function(date) {

-   return date.getUTCMinutes();

- });

- 

- var utcMinutes = utcMinute.range;

- 

- var utcHour = newInterval(function(date) {

-   date.setUTCMinutes(0, 0, 0);

- }, function(date, step) {

-   date.setTime(+date + step * durationHour$1);

- }, function(start, end) {

-   return (end - start) / durationHour$1;

- }, function(date) {

-   return date.getUTCHours();

- });

- 

- var utcHours = utcHour.range;

- 

- var utcDay = newInterval(function(date) {

-   date.setUTCHours(0, 0, 0, 0);

- }, function(date, step) {

-   date.setUTCDate(date.getUTCDate() + step);

- }, function(start, end) {

-   return (end - start) / durationDay$1;

- }, function(date) {

-   return date.getUTCDate() - 1;

- });

- 

- var utcDays = utcDay.range;

- 

- function utcWeekday(i) {

-   return newInterval(function(date) {

-     date.setUTCDate(date.getUTCDate() - (date.getUTCDay() + 7 - i) % 7);

-     date.setUTCHours(0, 0, 0, 0);

-   }, function(date, step) {

-     date.setUTCDate(date.getUTCDate() + step * 7);

-   }, function(start, end) {

-     return (end - start) / durationWeek$1;

-   });

- }

- 

- var utcSunday = utcWeekday(0);

- var utcMonday = utcWeekday(1);

- var utcTuesday = utcWeekday(2);

- var utcWednesday = utcWeekday(3);

- var utcThursday = utcWeekday(4);

- var utcFriday = utcWeekday(5);

- var utcSaturday = utcWeekday(6);

- 

- var utcSundays = utcSunday.range;

- var utcMondays = utcMonday.range;

- var utcTuesdays = utcTuesday.range;

- var utcWednesdays = utcWednesday.range;

- var utcThursdays = utcThursday.range;

- var utcFridays = utcFriday.range;

- var utcSaturdays = utcSaturday.range;

- 

- var utcMonth = newInterval(function(date) {

-   date.setUTCDate(1);

-   date.setUTCHours(0, 0, 0, 0);

- }, function(date, step) {

-   date.setUTCMonth(date.getUTCMonth() + step);

- }, function(start, end) {

-   return end.getUTCMonth() - start.getUTCMonth() + (end.getUTCFullYear() - start.getUTCFullYear()) * 12;

- }, function(date) {

-   return date.getUTCMonth();

- });

- 

- var utcMonths = utcMonth.range;

- 

- var utcYear = newInterval(function(date) {

-   date.setUTCMonth(0, 1);

-   date.setUTCHours(0, 0, 0, 0);

- }, function(date, step) {

-   date.setUTCFullYear(date.getUTCFullYear() + step);

- }, function(start, end) {

-   return end.getUTCFullYear() - start.getUTCFullYear();

- }, function(date) {

-   return date.getUTCFullYear();

- });

- 

- // An optimized implementation for this simple case.

- utcYear.every = function(k) {

-   return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : newInterval(function(date) {

-     date.setUTCFullYear(Math.floor(date.getUTCFullYear() / k) * k);

-     date.setUTCMonth(0, 1);

-     date.setUTCHours(0, 0, 0, 0);

-   }, function(date, step) {

-     date.setUTCFullYear(date.getUTCFullYear() + step * k);

-   });

- };

- 

- var utcYears = utcYear.range;

- 

- function localDate(d) {

-   if (0 <= d.y && d.y < 100) {

-     var date = new Date(-1, d.m, d.d, d.H, d.M, d.S, d.L);

-     date.setFullYear(d.y);

-     return date;

-   }

-   return new Date(d.y, d.m, d.d, d.H, d.M, d.S, d.L);

- }

- 

- function utcDate(d) {

-   if (0 <= d.y && d.y < 100) {

-     var date = new Date(Date.UTC(-1, d.m, d.d, d.H, d.M, d.S, d.L));

-     date.setUTCFullYear(d.y);

-     return date;

-   }

-   return new Date(Date.UTC(d.y, d.m, d.d, d.H, d.M, d.S, d.L));

- }

- 

- function newYear(y) {

-   return {y: y, m: 0, d: 1, H: 0, M: 0, S: 0, L: 0};

- }

- 

- function formatLocale$1(locale) {

-   var locale_dateTime = locale.dateTime,

-       locale_date = locale.date,

-       locale_time = locale.time,

-       locale_periods = locale.periods,

-       locale_weekdays = locale.days,

-       locale_shortWeekdays = locale.shortDays,

-       locale_months = locale.months,

-       locale_shortMonths = locale.shortMonths;

- 

-   var periodRe = formatRe(locale_periods),

-       periodLookup = formatLookup(locale_periods),

-       weekdayRe = formatRe(locale_weekdays),

-       weekdayLookup = formatLookup(locale_weekdays),

-       shortWeekdayRe = formatRe(locale_shortWeekdays),

-       shortWeekdayLookup = formatLookup(locale_shortWeekdays),

-       monthRe = formatRe(locale_months),

-       monthLookup = formatLookup(locale_months),

-       shortMonthRe = formatRe(locale_shortMonths),

-       shortMonthLookup = formatLookup(locale_shortMonths);

- 

-   var formats = {

-     "a": formatShortWeekday,

-     "A": formatWeekday,

-     "b": formatShortMonth,

-     "B": formatMonth,

-     "c": null,

-     "d": formatDayOfMonth,

-     "e": formatDayOfMonth,

-     "H": formatHour24,

-     "I": formatHour12,

-     "j": formatDayOfYear,

-     "L": formatMilliseconds,

-     "m": formatMonthNumber,

-     "M": formatMinutes,

-     "p": formatPeriod,

-     "S": formatSeconds,

-     "U": formatWeekNumberSunday,

-     "w": formatWeekdayNumber,

-     "W": formatWeekNumberMonday,

-     "x": null,

-     "X": null,

-     "y": formatYear,

-     "Y": formatFullYear,

-     "Z": formatZone,

-     "%": formatLiteralPercent

-   };

- 

-   var utcFormats = {

-     "a": formatUTCShortWeekday,

-     "A": formatUTCWeekday,

-     "b": formatUTCShortMonth,

-     "B": formatUTCMonth,

-     "c": null,

-     "d": formatUTCDayOfMonth,

-     "e": formatUTCDayOfMonth,

-     "H": formatUTCHour24,

-     "I": formatUTCHour12,

-     "j": formatUTCDayOfYear,

-     "L": formatUTCMilliseconds,

-     "m": formatUTCMonthNumber,

-     "M": formatUTCMinutes,

-     "p": formatUTCPeriod,

-     "S": formatUTCSeconds,

-     "U": formatUTCWeekNumberSunday,

-     "w": formatUTCWeekdayNumber,

-     "W": formatUTCWeekNumberMonday,

-     "x": null,

-     "X": null,

-     "y": formatUTCYear,

-     "Y": formatUTCFullYear,

-     "Z": formatUTCZone,

-     "%": formatLiteralPercent

-   };

- 

-   var parses = {

-     "a": parseShortWeekday,

-     "A": parseWeekday,

-     "b": parseShortMonth,

-     "B": parseMonth,

-     "c": parseLocaleDateTime,

-     "d": parseDayOfMonth,

-     "e": parseDayOfMonth,

-     "H": parseHour24,

-     "I": parseHour24,

-     "j": parseDayOfYear,

-     "L": parseMilliseconds,

-     "m": parseMonthNumber,

-     "M": parseMinutes,

-     "p": parsePeriod,

-     "S": parseSeconds,

-     "U": parseWeekNumberSunday,

-     "w": parseWeekdayNumber,

-     "W": parseWeekNumberMonday,

-     "x": parseLocaleDate,

-     "X": parseLocaleTime,

-     "y": parseYear,

-     "Y": parseFullYear,

-     "Z": parseZone,

-     "%": parseLiteralPercent

-   };

- 

-   // These recursive directive definitions must be deferred.

-   formats.x = newFormat(locale_date, formats);

-   formats.X = newFormat(locale_time, formats);

-   formats.c = newFormat(locale_dateTime, formats);

-   utcFormats.x = newFormat(locale_date, utcFormats);

-   utcFormats.X = newFormat(locale_time, utcFormats);

-   utcFormats.c = newFormat(locale_dateTime, utcFormats);

- 

-   function newFormat(specifier, formats) {

-     return function(date) {

-       var string = [],

-           i = -1,

-           j = 0,

-           n = specifier.length,

-           c,

-           pad,

-           format;

- 

-       if (!(date instanceof Date)) date = new Date(+date);

- 

-       while (++i < n) {

-         if (specifier.charCodeAt(i) === 37) {

-           string.push(specifier.slice(j, i));

-           if ((pad = pads[c = specifier.charAt(++i)]) != null) c = specifier.charAt(++i);

-           else pad = c === "e" ? " " : "0";

-           if (format = formats[c]) c = format(date, pad);

-           string.push(c);

-           j = i + 1;

-         }

-       }

- 

-       string.push(specifier.slice(j, i));

-       return string.join("");

-     };

-   }

- 

-   function newParse(specifier, newDate) {

-     return function(string) {

-       var d = newYear(1900),

-           i = parseSpecifier(d, specifier, string += "", 0);

-       if (i != string.length) return null;

- 

-       // The am-pm flag is 0 for AM, and 1 for PM.

-       if ("p" in d) d.H = d.H % 12 + d.p * 12;

- 

-       // Convert day-of-week and week-of-year to day-of-year.

-       if ("W" in d || "U" in d) {

-         if (!("w" in d)) d.w = "W" in d ? 1 : 0;

-         var day$$1 = "Z" in d ? utcDate(newYear(d.y)).getUTCDay() : newDate(newYear(d.y)).getDay();

-         d.m = 0;

-         d.d = "W" in d ? (d.w + 6) % 7 + d.W * 7 - (day$$1 + 5) % 7 : d.w + d.U * 7 - (day$$1 + 6) % 7;

-       }

- 

-       // If a time zone is specified, all fields are interpreted as UTC and then

-       // offset according to the specified time zone.

-       if ("Z" in d) {

-         d.H += d.Z / 100 | 0;

-         d.M += d.Z % 100;

-         return utcDate(d);

-       }

- 

-       // Otherwise, all fields are in local time.

-       return newDate(d);

-     };

-   }

- 

-   function parseSpecifier(d, specifier, string, j) {

-     var i = 0,

-         n = specifier.length,

-         m = string.length,

-         c,

-         parse;

- 

-     while (i < n) {

-       if (j >= m) return -1;

-       c = specifier.charCodeAt(i++);

-       if (c === 37) {

-         c = specifier.charAt(i++);

-         parse = parses[c in pads ? specifier.charAt(i++) : c];

-         if (!parse || ((j = parse(d, string, j)) < 0)) return -1;

-       } else if (c != string.charCodeAt(j++)) {

-         return -1;

-       }

-     }

- 

-     return j;

-   }

- 

-   function parsePeriod(d, string, i) {

-     var n = periodRe.exec(string.slice(i));

-     return n ? (d.p = periodLookup[n[0].toLowerCase()], i + n[0].length) : -1;

-   }

- 

-   function parseShortWeekday(d, string, i) {

-     var n = shortWeekdayRe.exec(string.slice(i));

-     return n ? (d.w = shortWeekdayLookup[n[0].toLowerCase()], i + n[0].length) : -1;

-   }

- 

-   function parseWeekday(d, string, i) {

-     var n = weekdayRe.exec(string.slice(i));

-     return n ? (d.w = weekdayLookup[n[0].toLowerCase()], i + n[0].length) : -1;

-   }

- 

-   function parseShortMonth(d, string, i) {

-     var n = shortMonthRe.exec(string.slice(i));

-     return n ? (d.m = shortMonthLookup[n[0].toLowerCase()], i + n[0].length) : -1;

-   }

- 

-   function parseMonth(d, string, i) {

-     var n = monthRe.exec(string.slice(i));

-     return n ? (d.m = monthLookup[n[0].toLowerCase()], i + n[0].length) : -1;

-   }

- 

-   function parseLocaleDateTime(d, string, i) {

-     return parseSpecifier(d, locale_dateTime, string, i);

-   }

- 

-   function parseLocaleDate(d, string, i) {

-     return parseSpecifier(d, locale_date, string, i);

-   }

- 

-   function parseLocaleTime(d, string, i) {

-     return parseSpecifier(d, locale_time, string, i);

-   }

- 

-   function formatShortWeekday(d) {

-     return locale_shortWeekdays[d.getDay()];

-   }

- 

-   function formatWeekday(d) {

-     return locale_weekdays[d.getDay()];

-   }

- 

-   function formatShortMonth(d) {

-     return locale_shortMonths[d.getMonth()];

-   }

- 

-   function formatMonth(d) {

-     return locale_months[d.getMonth()];

-   }

- 

-   function formatPeriod(d) {

-     return locale_periods[+(d.getHours() >= 12)];

-   }

- 

-   function formatUTCShortWeekday(d) {

-     return locale_shortWeekdays[d.getUTCDay()];

-   }

- 

-   function formatUTCWeekday(d) {

-     return locale_weekdays[d.getUTCDay()];

-   }

- 

-   function formatUTCShortMonth(d) {

-     return locale_shortMonths[d.getUTCMonth()];

-   }

- 

-   function formatUTCMonth(d) {

-     return locale_months[d.getUTCMonth()];

-   }

- 

-   function formatUTCPeriod(d) {

-     return locale_periods[+(d.getUTCHours() >= 12)];

-   }

- 

-   return {

-     format: function(specifier) {

-       var f = newFormat(specifier += "", formats);

-       f.toString = function() { return specifier; };

-       return f;

-     },

-     parse: function(specifier) {

-       var p = newParse(specifier += "", localDate);

-       p.toString = function() { return specifier; };

-       return p;

-     },

-     utcFormat: function(specifier) {

-       var f = newFormat(specifier += "", utcFormats);

-       f.toString = function() { return specifier; };

-       return f;

-     },

-     utcParse: function(specifier) {

-       var p = newParse(specifier, utcDate);

-       p.toString = function() { return specifier; };

-       return p;

-     }

-   };

- }

- 

- var pads = {"-": "", "_": " ", "0": "0"};

- var numberRe = /^\s*\d+/;

- var percentRe = /^%/;

- var requoteRe = /[\\\^\$\*\+\?\|\[\]\(\)\.\{\}]/g;

- 

- function pad(value, fill, width) {

-   var sign = value < 0 ? "-" : "",

-       string = (sign ? -value : value) + "",

-       length = string.length;

-   return sign + (length < width ? new Array(width - length + 1).join(fill) + string : string);

- }

- 

- function requote(s) {

-   return s.replace(requoteRe, "\\$&");

- }

- 

- function formatRe(names) {

-   return new RegExp("^(?:" + names.map(requote).join("|") + ")", "i");

- }

- 

- function formatLookup(names) {

-   var map = {}, i = -1, n = names.length;

-   while (++i < n) map[names[i].toLowerCase()] = i;

-   return map;

- }

- 

- function parseWeekdayNumber(d, string, i) {

-   var n = numberRe.exec(string.slice(i, i + 1));

-   return n ? (d.w = +n[0], i + n[0].length) : -1;

- }

- 

- function parseWeekNumberSunday(d, string, i) {

-   var n = numberRe.exec(string.slice(i));

-   return n ? (d.U = +n[0], i + n[0].length) : -1;

- }

- 

- function parseWeekNumberMonday(d, string, i) {

-   var n = numberRe.exec(string.slice(i));

-   return n ? (d.W = +n[0], i + n[0].length) : -1;

- }

- 

- function parseFullYear(d, string, i) {

-   var n = numberRe.exec(string.slice(i, i + 4));

-   return n ? (d.y = +n[0], i + n[0].length) : -1;

- }

- 

- function parseYear(d, string, i) {

-   var n = numberRe.exec(string.slice(i, i + 2));

-   return n ? (d.y = +n[0] + (+n[0] > 68 ? 1900 : 2000), i + n[0].length) : -1;

- }

- 

- function parseZone(d, string, i) {

-   var n = /^(Z)|([+-]\d\d)(?:\:?(\d\d))?/.exec(string.slice(i, i + 6));

-   return n ? (d.Z = n[1] ? 0 : -(n[2] + (n[3] || "00")), i + n[0].length) : -1;

- }

- 

- function parseMonthNumber(d, string, i) {

-   var n = numberRe.exec(string.slice(i, i + 2));

-   return n ? (d.m = n[0] - 1, i + n[0].length) : -1;

- }

- 

- function parseDayOfMonth(d, string, i) {

-   var n = numberRe.exec(string.slice(i, i + 2));

-   return n ? (d.d = +n[0], i + n[0].length) : -1;

- }

- 

- function parseDayOfYear(d, string, i) {

-   var n = numberRe.exec(string.slice(i, i + 3));

-   return n ? (d.m = 0, d.d = +n[0], i + n[0].length) : -1;

- }

- 

- function parseHour24(d, string, i) {

-   var n = numberRe.exec(string.slice(i, i + 2));

-   return n ? (d.H = +n[0], i + n[0].length) : -1;

- }

- 

- function parseMinutes(d, string, i) {

-   var n = numberRe.exec(string.slice(i, i + 2));

-   return n ? (d.M = +n[0], i + n[0].length) : -1;

- }

- 

- function parseSeconds(d, string, i) {

-   var n = numberRe.exec(string.slice(i, i + 2));

-   return n ? (d.S = +n[0], i + n[0].length) : -1;

- }

- 

- function parseMilliseconds(d, string, i) {

-   var n = numberRe.exec(string.slice(i, i + 3));

-   return n ? (d.L = +n[0], i + n[0].length) : -1;

- }

- 

- function parseLiteralPercent(d, string, i) {

-   var n = percentRe.exec(string.slice(i, i + 1));

-   return n ? i + n[0].length : -1;

- }

- 

- function formatDayOfMonth(d, p) {

-   return pad(d.getDate(), p, 2);

- }

- 

- function formatHour24(d, p) {

-   return pad(d.getHours(), p, 2);

- }

- 

- function formatHour12(d, p) {

-   return pad(d.getHours() % 12 || 12, p, 2);

- }

- 

- function formatDayOfYear(d, p) {

-   return pad(1 + day.count(year(d), d), p, 3);

- }

- 

- function formatMilliseconds(d, p) {

-   return pad(d.getMilliseconds(), p, 3);

- }

- 

- function formatMonthNumber(d, p) {

-   return pad(d.getMonth() + 1, p, 2);

- }

- 

- function formatMinutes(d, p) {

-   return pad(d.getMinutes(), p, 2);

- }

- 

- function formatSeconds(d, p) {

-   return pad(d.getSeconds(), p, 2);

- }

- 

- function formatWeekNumberSunday(d, p) {

-   return pad(sunday.count(year(d), d), p, 2);

- }

- 

- function formatWeekdayNumber(d) {

-   return d.getDay();

- }

- 

- function formatWeekNumberMonday(d, p) {

-   return pad(monday.count(year(d), d), p, 2);

- }

- 

- function formatYear(d, p) {

-   return pad(d.getFullYear() % 100, p, 2);

- }

- 

- function formatFullYear(d, p) {

-   return pad(d.getFullYear() % 10000, p, 4);

- }

- 

- function formatZone(d) {

-   var z = d.getTimezoneOffset();

-   return (z > 0 ? "-" : (z *= -1, "+"))

-       + pad(z / 60 | 0, "0", 2)

-       + pad(z % 60, "0", 2);

- }

- 

- function formatUTCDayOfMonth(d, p) {

-   return pad(d.getUTCDate(), p, 2);

- }

- 

- function formatUTCHour24(d, p) {

-   return pad(d.getUTCHours(), p, 2);

- }

- 

- function formatUTCHour12(d, p) {

-   return pad(d.getUTCHours() % 12 || 12, p, 2);

- }

- 

- function formatUTCDayOfYear(d, p) {

-   return pad(1 + utcDay.count(utcYear(d), d), p, 3);

- }

- 

- function formatUTCMilliseconds(d, p) {

-   return pad(d.getUTCMilliseconds(), p, 3);

- }

- 

- function formatUTCMonthNumber(d, p) {

-   return pad(d.getUTCMonth() + 1, p, 2);

- }

- 

- function formatUTCMinutes(d, p) {

-   return pad(d.getUTCMinutes(), p, 2);

- }

- 

- function formatUTCSeconds(d, p) {

-   return pad(d.getUTCSeconds(), p, 2);

- }

- 

- function formatUTCWeekNumberSunday(d, p) {

-   return pad(utcSunday.count(utcYear(d), d), p, 2);

- }

- 

- function formatUTCWeekdayNumber(d) {

-   return d.getUTCDay();

- }

- 

- function formatUTCWeekNumberMonday(d, p) {

-   return pad(utcMonday.count(utcYear(d), d), p, 2);

- }

- 

- function formatUTCYear(d, p) {

-   return pad(d.getUTCFullYear() % 100, p, 2);

- }

- 

- function formatUTCFullYear(d, p) {

-   return pad(d.getUTCFullYear() % 10000, p, 4);

- }

- 

- function formatUTCZone() {

-   return "+0000";

- }

- 

- function formatLiteralPercent() {

-   return "%";

- }

- 

- var locale$1;

- 

- 

- 

- 

- 

- defaultLocale$1({

-   dateTime: "%x, %X",

-   date: "%-m/%-d/%Y",

-   time: "%-I:%M:%S %p",

-   periods: ["AM", "PM"],

-   days: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"],

-   shortDays: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],

-   months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"],

-   shortMonths: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]

- });

- 

- function defaultLocale$1(definition) {

-   locale$1 = formatLocale$1(definition);

-   exports.timeFormat = locale$1.format;

-   exports.timeParse = locale$1.parse;

-   exports.utcFormat = locale$1.utcFormat;

-   exports.utcParse = locale$1.utcParse;

-   return locale$1;

- }

- 

- var isoSpecifier = "%Y-%m-%dT%H:%M:%S.%LZ";

- 

- function formatIsoNative(date) {

-   return date.toISOString();

- }

- 

- var formatIso = Date.prototype.toISOString

-     ? formatIsoNative

-     : exports.utcFormat(isoSpecifier);

- 

- function parseIsoNative(string) {

-   var date = new Date(string);

-   return isNaN(date) ? null : date;

- }

- 

- var parseIso = +new Date("2000-01-01T00:00:00.000Z")

-     ? parseIsoNative

-     : exports.utcParse(isoSpecifier);

- 

- var durationSecond = 1000;

- var durationMinute = durationSecond * 60;

- var durationHour = durationMinute * 60;

- var durationDay = durationHour * 24;

- var durationWeek = durationDay * 7;

- var durationMonth = durationDay * 30;

- var durationYear = durationDay * 365;

- 

- function date$1(t) {

-   return new Date(t);

- }

- 

- function number$3(t) {

-   return t instanceof Date ? +t : +new Date(+t);

- }

- 

- function calendar(year$$1, month$$1, week, day$$1, hour$$1, minute$$1, second$$1, millisecond$$1, format) {

-   var scale = continuous(deinterpolateLinear, reinterpolate),

-       invert = scale.invert,

-       domain = scale.domain;

- 

-   var formatMillisecond = format(".%L"),

-       formatSecond = format(":%S"),

-       formatMinute = format("%I:%M"),

-       formatHour = format("%I %p"),

-       formatDay = format("%a %d"),

-       formatWeek = format("%b %d"),

-       formatMonth = format("%B"),

-       formatYear = format("%Y");

- 

-   var tickIntervals = [

-     [second$$1,  1,      durationSecond],

-     [second$$1,  5,  5 * durationSecond],

-     [second$$1, 15, 15 * durationSecond],

-     [second$$1, 30, 30 * durationSecond],

-     [minute$$1,  1,      durationMinute],

-     [minute$$1,  5,  5 * durationMinute],

-     [minute$$1, 15, 15 * durationMinute],

-     [minute$$1, 30, 30 * durationMinute],

-     [  hour$$1,  1,      durationHour  ],

-     [  hour$$1,  3,  3 * durationHour  ],

-     [  hour$$1,  6,  6 * durationHour  ],

-     [  hour$$1, 12, 12 * durationHour  ],

-     [   day$$1,  1,      durationDay   ],

-     [   day$$1,  2,  2 * durationDay   ],

-     [  week,  1,      durationWeek  ],

-     [ month$$1,  1,      durationMonth ],

-     [ month$$1,  3,  3 * durationMonth ],

-     [  year$$1,  1,      durationYear  ]

-   ];

- 

-   function tickFormat(date) {

-     return (second$$1(date) < date ? formatMillisecond

-         : minute$$1(date) < date ? formatSecond

-         : hour$$1(date) < date ? formatMinute

-         : day$$1(date) < date ? formatHour

-         : month$$1(date) < date ? (week(date) < date ? formatDay : formatWeek)

-         : year$$1(date) < date ? formatMonth

-         : formatYear)(date);

-   }

- 

-   function tickInterval(interval, start, stop, step) {

-     if (interval == null) interval = 10;

- 

-     // If a desired tick count is specified, pick a reasonable tick interval

-     // based on the extent of the domain and a rough estimate of tick size.

-     // Otherwise, assume interval is already a time interval and use it.

-     if (typeof interval === "number") {

-       var target = Math.abs(stop - start) / interval,

-           i = bisector(function(i) { return i[2]; }).right(tickIntervals, target);

-       if (i === tickIntervals.length) {

-         step = tickStep(start / durationYear, stop / durationYear, interval);

-         interval = year$$1;

-       } else if (i) {

-         i = tickIntervals[target / tickIntervals[i - 1][2] < tickIntervals[i][2] / target ? i - 1 : i];

-         step = i[1];

-         interval = i[0];

-       } else {

-         step = tickStep(start, stop, interval);

-         interval = millisecond$$1;

-       }

-     }

- 

-     return step == null ? interval : interval.every(step);

-   }

- 

-   scale.invert = function(y) {

-     return new Date(invert(y));

-   };

- 

-   scale.domain = function(_) {

-     return arguments.length ? domain(map$3.call(_, number$3)) : domain().map(date$1);

-   };

- 

-   scale.ticks = function(interval, step) {

-     var d = domain(),

-         t0 = d[0],

-         t1 = d[d.length - 1],

-         r = t1 < t0,

-         t;

-     if (r) t = t0, t0 = t1, t1 = t;

-     t = tickInterval(interval, t0, t1, step);

-     t = t ? t.range(t0, t1 + 1) : []; // inclusive stop

-     return r ? t.reverse() : t;

-   };

- 

-   scale.tickFormat = function(count, specifier) {

-     return specifier == null ? tickFormat : format(specifier);

-   };

- 

-   scale.nice = function(interval, step) {

-     var d = domain();

-     return (interval = tickInterval(interval, d[0], d[d.length - 1], step))

-         ? domain(nice(d, interval))

-         : scale;

-   };

- 

-   scale.copy = function() {

-     return copy(scale, calendar(year$$1, month$$1, week, day$$1, hour$$1, minute$$1, second$$1, millisecond$$1, format));

-   };

- 

-   return scale;

- }

- 

- var time = function() {

-   return calendar(year, month, sunday, day, hour, minute, second, millisecond, exports.timeFormat).domain([new Date(2000, 0, 1), new Date(2000, 0, 2)]);

- };

- 

- var utcTime = function() {

-   return calendar(utcYear, utcMonth, utcSunday, utcDay, utcHour, utcMinute, second, millisecond, exports.utcFormat).domain([Date.UTC(2000, 0, 1), Date.UTC(2000, 0, 2)]);

- };

- 

- var colors = function(s) {

-   return s.match(/.{6}/g).map(function(x) {

-     return "#" + x;

-   });

- };

- 

- var category10 = colors("1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf");

- 

- var category20b = colors("393b795254a36b6ecf9c9ede6379398ca252b5cf6bcedb9c8c6d31bd9e39e7ba52e7cb94843c39ad494ad6616be7969c7b4173a55194ce6dbdde9ed6");

- 

- var category20c = colors("3182bd6baed69ecae1c6dbefe6550dfd8d3cfdae6bfdd0a231a35474c476a1d99bc7e9c0756bb19e9ac8bcbddcdadaeb636363969696bdbdbdd9d9d9");

- 

- var category20 = colors("1f77b4aec7e8ff7f0effbb782ca02c98df8ad62728ff98969467bdc5b0d58c564bc49c94e377c2f7b6d27f7f7fc7c7c7bcbd22dbdb8d17becf9edae5");

- 

- var cubehelix$3 = cubehelixLong(cubehelix(300, 0.5, 0.0), cubehelix(-240, 0.5, 1.0));

- 

- var warm = cubehelixLong(cubehelix(-100, 0.75, 0.35), cubehelix(80, 1.50, 0.8));

- 

- var cool = cubehelixLong(cubehelix(260, 0.75, 0.35), cubehelix(80, 1.50, 0.8));

- 

- var rainbow = cubehelix();

- 

- var rainbow$1 = function(t) {

-   if (t < 0 || t > 1) t -= Math.floor(t);

-   var ts = Math.abs(t - 0.5);

-   rainbow.h = 360 * t - 100;

-   rainbow.s = 1.5 - 1.5 * ts;

-   rainbow.l = 0.8 - 0.9 * ts;

-   return rainbow + "";

- };

- 

- function ramp(range) {

-   var n = range.length;

-   return function(t) {

-     return range[Math.max(0, Math.min(n - 1, Math.floor(t * n)))];

-   };

- }

- 

- var viridis = ramp(colors("44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725"));

- 

- var magma = ramp(colors("00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf"));

- 

- var inferno = ramp(colors("00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4"));

- 

- var plasma = ramp(colors("0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921"));

- 

- function sequential(interpolator) {

-   var x0 = 0,

-       x1 = 1,

-       clamp = false;

- 

-   function scale(x) {

-     var t = (x - x0) / (x1 - x0);

-     return interpolator(clamp ? Math.max(0, Math.min(1, t)) : t);

-   }

- 

-   scale.domain = function(_) {

-     return arguments.length ? (x0 = +_[0], x1 = +_[1], scale) : [x0, x1];

-   };

- 

-   scale.clamp = function(_) {

-     return arguments.length ? (clamp = !!_, scale) : clamp;

-   };

- 

-   scale.interpolator = function(_) {

-     return arguments.length ? (interpolator = _, scale) : interpolator;

-   };

- 

-   scale.copy = function() {

-     return sequential(interpolator).domain([x0, x1]).clamp(clamp);

-   };

- 

-   return linearish(scale);

- }

- 

- var constant$10 = function(x) {

-   return function constant() {

-     return x;

-   };

- };

- 

- var abs$1 = Math.abs;

- var atan2$1 = Math.atan2;

- var cos$2 = Math.cos;

- var max$2 = Math.max;

- var min$1 = Math.min;

- var sin$2 = Math.sin;

- var sqrt$2 = Math.sqrt;

- 

- var epsilon$3 = 1e-12;

- var pi$4 = Math.PI;

- var halfPi$3 = pi$4 / 2;

- var tau$4 = 2 * pi$4;

- 

- function acos$1(x) {

-   return x > 1 ? 0 : x < -1 ? pi$4 : Math.acos(x);

- }

- 

- function asin$1(x) {

-   return x >= 1 ? halfPi$3 : x <= -1 ? -halfPi$3 : Math.asin(x);

- }

- 

- function arcInnerRadius(d) {

-   return d.innerRadius;

- }

- 

- function arcOuterRadius(d) {

-   return d.outerRadius;

- }

- 

- function arcStartAngle(d) {

-   return d.startAngle;

- }

- 

- function arcEndAngle(d) {

-   return d.endAngle;

- }

- 

- function arcPadAngle(d) {

-   return d && d.padAngle; // Note: optional!

- }

- 

- function intersect(x0, y0, x1, y1, x2, y2, x3, y3) {

-   var x10 = x1 - x0, y10 = y1 - y0,

-       x32 = x3 - x2, y32 = y3 - y2,

-       t = (x32 * (y0 - y2) - y32 * (x0 - x2)) / (y32 * x10 - x32 * y10);

-   return [x0 + t * x10, y0 + t * y10];

- }

- 

- // Compute perpendicular offset line of length rc.

- // http://mathworld.wolfram.com/Circle-LineIntersection.html

- function cornerTangents(x0, y0, x1, y1, r1, rc, cw) {

-   var x01 = x0 - x1,

-       y01 = y0 - y1,

-       lo = (cw ? rc : -rc) / sqrt$2(x01 * x01 + y01 * y01),

-       ox = lo * y01,

-       oy = -lo * x01,

-       x11 = x0 + ox,

-       y11 = y0 + oy,

-       x10 = x1 + ox,

-       y10 = y1 + oy,

-       x00 = (x11 + x10) / 2,

-       y00 = (y11 + y10) / 2,

-       dx = x10 - x11,

-       dy = y10 - y11,

-       d2 = dx * dx + dy * dy,

-       r = r1 - rc,

-       D = x11 * y10 - x10 * y11,

-       d = (dy < 0 ? -1 : 1) * sqrt$2(max$2(0, r * r * d2 - D * D)),

-       cx0 = (D * dy - dx * d) / d2,

-       cy0 = (-D * dx - dy * d) / d2,

-       cx1 = (D * dy + dx * d) / d2,

-       cy1 = (-D * dx + dy * d) / d2,

-       dx0 = cx0 - x00,

-       dy0 = cy0 - y00,

-       dx1 = cx1 - x00,

-       dy1 = cy1 - y00;

- 

-   // Pick the closer of the two intersection points.

-   // TODO Is there a faster way to determine which intersection to use?

-   if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1) cx0 = cx1, cy0 = cy1;

- 

-   return {

-     cx: cx0,

-     cy: cy0,

-     x01: -ox,

-     y01: -oy,

-     x11: cx0 * (r1 / r - 1),

-     y11: cy0 * (r1 / r - 1)

-   };

- }

- 

- var arc = function() {

-   var innerRadius = arcInnerRadius,

-       outerRadius = arcOuterRadius,

-       cornerRadius = constant$10(0),

-       padRadius = null,

-       startAngle = arcStartAngle,

-       endAngle = arcEndAngle,

-       padAngle = arcPadAngle,

-       context = null;

- 

-   function arc() {

-     var buffer,

-         r,

-         r0 = +innerRadius.apply(this, arguments),

-         r1 = +outerRadius.apply(this, arguments),

-         a0 = startAngle.apply(this, arguments) - halfPi$3,

-         a1 = endAngle.apply(this, arguments) - halfPi$3,

-         da = abs$1(a1 - a0),

-         cw = a1 > a0;

- 

-     if (!context) context = buffer = path();

- 

-     // Ensure that the outer radius is always larger than the inner radius.

-     if (r1 < r0) r = r1, r1 = r0, r0 = r;

- 

-     // Is it a point?

-     if (!(r1 > epsilon$3)) context.moveTo(0, 0);

- 

-     // Or is it a circle or annulus?

-     else if (da > tau$4 - epsilon$3) {

-       context.moveTo(r1 * cos$2(a0), r1 * sin$2(a0));

-       context.arc(0, 0, r1, a0, a1, !cw);

-       if (r0 > epsilon$3) {

-         context.moveTo(r0 * cos$2(a1), r0 * sin$2(a1));

-         context.arc(0, 0, r0, a1, a0, cw);

-       }

-     }

- 

-     // Or is it a circular or annular sector?

-     else {

-       var a01 = a0,

-           a11 = a1,

-           a00 = a0,

-           a10 = a1,

-           da0 = da,

-           da1 = da,

-           ap = padAngle.apply(this, arguments) / 2,

-           rp = (ap > epsilon$3) && (padRadius ? +padRadius.apply(this, arguments) : sqrt$2(r0 * r0 + r1 * r1)),

-           rc = min$1(abs$1(r1 - r0) / 2, +cornerRadius.apply(this, arguments)),

-           rc0 = rc,

-           rc1 = rc,

-           t0,

-           t1;

- 

-       // Apply padding? Note that since r1 ≥ r0, da1 ≥ da0.

-       if (rp > epsilon$3) {

-         var p0 = asin$1(rp / r0 * sin$2(ap)),

-             p1 = asin$1(rp / r1 * sin$2(ap));

-         if ((da0 -= p0 * 2) > epsilon$3) p0 *= (cw ? 1 : -1), a00 += p0, a10 -= p0;

-         else da0 = 0, a00 = a10 = (a0 + a1) / 2;

-         if ((da1 -= p1 * 2) > epsilon$3) p1 *= (cw ? 1 : -1), a01 += p1, a11 -= p1;

-         else da1 = 0, a01 = a11 = (a0 + a1) / 2;

-       }

- 

-       var x01 = r1 * cos$2(a01),

-           y01 = r1 * sin$2(a01),

-           x10 = r0 * cos$2(a10),

-           y10 = r0 * sin$2(a10);

- 

-       // Apply rounded corners?

-       if (rc > epsilon$3) {

-         var x11 = r1 * cos$2(a11),

-             y11 = r1 * sin$2(a11),

-             x00 = r0 * cos$2(a00),

-             y00 = r0 * sin$2(a00);

- 

-         // Restrict the corner radius according to the sector angle.

-         if (da < pi$4) {

-           var oc = da0 > epsilon$3 ? intersect(x01, y01, x00, y00, x11, y11, x10, y10) : [x10, y10],

-               ax = x01 - oc[0],

-               ay = y01 - oc[1],

-               bx = x11 - oc[0],

-               by = y11 - oc[1],

-               kc = 1 / sin$2(acos$1((ax * bx + ay * by) / (sqrt$2(ax * ax + ay * ay) * sqrt$2(bx * bx + by * by))) / 2),

-               lc = sqrt$2(oc[0] * oc[0] + oc[1] * oc[1]);

-           rc0 = min$1(rc, (r0 - lc) / (kc - 1));

-           rc1 = min$1(rc, (r1 - lc) / (kc + 1));

-         }

-       }

- 

-       // Is the sector collapsed to a line?

-       if (!(da1 > epsilon$3)) context.moveTo(x01, y01);

- 

-       // Does the sector’s outer ring have rounded corners?

-       else if (rc1 > epsilon$3) {

-         t0 = cornerTangents(x00, y00, x01, y01, r1, rc1, cw);

-         t1 = cornerTangents(x11, y11, x10, y10, r1, rc1, cw);

- 

-         context.moveTo(t0.cx + t0.x01, t0.cy + t0.y01);

- 

-         // Have the corners merged?

-         if (rc1 < rc) context.arc(t0.cx, t0.cy, rc1, atan2$1(t0.y01, t0.x01), atan2$1(t1.y01, t1.x01), !cw);

- 

-         // Otherwise, draw the two corners and the ring.

-         else {

-           context.arc(t0.cx, t0.cy, rc1, atan2$1(t0.y01, t0.x01), atan2$1(t0.y11, t0.x11), !cw);

-           context.arc(0, 0, r1, atan2$1(t0.cy + t0.y11, t0.cx + t0.x11), atan2$1(t1.cy + t1.y11, t1.cx + t1.x11), !cw);

-           context.arc(t1.cx, t1.cy, rc1, atan2$1(t1.y11, t1.x11), atan2$1(t1.y01, t1.x01), !cw);

-         }

-       }

- 

-       // Or is the outer ring just a circular arc?

-       else context.moveTo(x01, y01), context.arc(0, 0, r1, a01, a11, !cw);

- 

-       // Is there no inner ring, and it’s a circular sector?

-       // Or perhaps it’s an annular sector collapsed due to padding?

-       if (!(r0 > epsilon$3) || !(da0 > epsilon$3)) context.lineTo(x10, y10);

- 

-       // Does the sector’s inner ring (or point) have rounded corners?

-       else if (rc0 > epsilon$3) {

-         t0 = cornerTangents(x10, y10, x11, y11, r0, -rc0, cw);

-         t1 = cornerTangents(x01, y01, x00, y00, r0, -rc0, cw);

- 

-         context.lineTo(t0.cx + t0.x01, t0.cy + t0.y01);

- 

-         // Have the corners merged?

-         if (rc0 < rc) context.arc(t0.cx, t0.cy, rc0, atan2$1(t0.y01, t0.x01), atan2$1(t1.y01, t1.x01), !cw);

- 

-         // Otherwise, draw the two corners and the ring.

-         else {

-           context.arc(t0.cx, t0.cy, rc0, atan2$1(t0.y01, t0.x01), atan2$1(t0.y11, t0.x11), !cw);

-           context.arc(0, 0, r0, atan2$1(t0.cy + t0.y11, t0.cx + t0.x11), atan2$1(t1.cy + t1.y11, t1.cx + t1.x11), cw);

-           context.arc(t1.cx, t1.cy, rc0, atan2$1(t1.y11, t1.x11), atan2$1(t1.y01, t1.x01), !cw);

-         }

-       }

- 

-       // Or is the inner ring just a circular arc?

-       else context.arc(0, 0, r0, a10, a00, cw);

-     }

- 

-     context.closePath();

- 

-     if (buffer) return context = null, buffer + "" || null;

-   }

- 

-   arc.centroid = function() {

-     var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2,

-         a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - pi$4 / 2;

-     return [cos$2(a) * r, sin$2(a) * r];

-   };

- 

-   arc.innerRadius = function(_) {

-     return arguments.length ? (innerRadius = typeof _ === "function" ? _ : constant$10(+_), arc) : innerRadius;

-   };

- 

-   arc.outerRadius = function(_) {

-     return arguments.length ? (outerRadius = typeof _ === "function" ? _ : constant$10(+_), arc) : outerRadius;

-   };

- 

-   arc.cornerRadius = function(_) {

-     return arguments.length ? (cornerRadius = typeof _ === "function" ? _ : constant$10(+_), arc) : cornerRadius;

-   };

- 

-   arc.padRadius = function(_) {

-     return arguments.length ? (padRadius = _ == null ? null : typeof _ === "function" ? _ : constant$10(+_), arc) : padRadius;

-   };

- 

-   arc.startAngle = function(_) {

-     return arguments.length ? (startAngle = typeof _ === "function" ? _ : constant$10(+_), arc) : startAngle;

-   };

- 

-   arc.endAngle = function(_) {

-     return arguments.length ? (endAngle = typeof _ === "function" ? _ : constant$10(+_), arc) : endAngle;

-   };

- 

-   arc.padAngle = function(_) {

-     return arguments.length ? (padAngle = typeof _ === "function" ? _ : constant$10(+_), arc) : padAngle;

-   };

- 

-   arc.context = function(_) {

-     return arguments.length ? ((context = _ == null ? null : _), arc) : context;

-   };

- 

-   return arc;

- };

- 

- function Linear(context) {

-   this._context = context;

- }

- 

- Linear.prototype = {

-   areaStart: function() {

-     this._line = 0;

-   },

-   areaEnd: function() {

-     this._line = NaN;

-   },

-   lineStart: function() {

-     this._point = 0;

-   },

-   lineEnd: function() {

-     if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();

-     this._line = 1 - this._line;

-   },

-   point: function(x, y) {

-     x = +x, y = +y;

-     switch (this._point) {

-       case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;

-       case 1: this._point = 2; // proceed

-       default: this._context.lineTo(x, y); break;

-     }

-   }

- };

- 

- var curveLinear = function(context) {

-   return new Linear(context);

- };

- 

- function x$3(p) {

-   return p[0];

- }

- 

- function y$3(p) {

-   return p[1];

- }

- 

- var line = function() {

-   var x$$1 = x$3,

-       y$$1 = y$3,

-       defined = constant$10(true),

-       context = null,

-       curve = curveLinear,

-       output = null;

- 

-   function line(data) {

-     var i,

-         n = data.length,

-         d,

-         defined0 = false,

-         buffer;

- 

-     if (context == null) output = curve(buffer = path());

- 

-     for (i = 0; i <= n; ++i) {

-       if (!(i < n && defined(d = data[i], i, data)) === defined0) {

-         if (defined0 = !defined0) output.lineStart();

-         else output.lineEnd();

-       }

-       if (defined0) output.point(+x$$1(d, i, data), +y$$1(d, i, data));

-     }

- 

-     if (buffer) return output = null, buffer + "" || null;

-   }

- 

-   line.x = function(_) {

-     return arguments.length ? (x$$1 = typeof _ === "function" ? _ : constant$10(+_), line) : x$$1;

-   };

- 

-   line.y = function(_) {

-     return arguments.length ? (y$$1 = typeof _ === "function" ? _ : constant$10(+_), line) : y$$1;

-   };

- 

-   line.defined = function(_) {

-     return arguments.length ? (defined = typeof _ === "function" ? _ : constant$10(!!_), line) : defined;

-   };

- 

-   line.curve = function(_) {

-     return arguments.length ? (curve = _, context != null && (output = curve(context)), line) : curve;

-   };

- 

-   line.context = function(_) {

-     return arguments.length ? (_ == null ? context = output = null : output = curve(context = _), line) : context;

-   };

- 

-   return line;

- };

- 

- var area$2 = function() {

-   var x0 = x$3,

-       x1 = null,

-       y0 = constant$10(0),

-       y1 = y$3,

-       defined = constant$10(true),

-       context = null,

-       curve = curveLinear,

-       output = null;

- 

-   function area(data) {

-     var i,

-         j,

-         k,

-         n = data.length,

-         d,

-         defined0 = false,

-         buffer,

-         x0z = new Array(n),

-         y0z = new Array(n);

- 

-     if (context == null) output = curve(buffer = path());

- 

-     for (i = 0; i <= n; ++i) {

-       if (!(i < n && defined(d = data[i], i, data)) === defined0) {

-         if (defined0 = !defined0) {

-           j = i;

-           output.areaStart();

-           output.lineStart();

-         } else {

-           output.lineEnd();

-           output.lineStart();

-           for (k = i - 1; k >= j; --k) {

-             output.point(x0z[k], y0z[k]);

-           }

-           output.lineEnd();

-           output.areaEnd();

-         }

-       }

-       if (defined0) {

-         x0z[i] = +x0(d, i, data), y0z[i] = +y0(d, i, data);

-         output.point(x1 ? +x1(d, i, data) : x0z[i], y1 ? +y1(d, i, data) : y0z[i]);

-       }

-     }

- 

-     if (buffer) return output = null, buffer + "" || null;

-   }

- 

-   function arealine() {

-     return line().defined(defined).curve(curve).context(context);

-   }

- 

-   area.x = function(_) {

-     return arguments.length ? (x0 = typeof _ === "function" ? _ : constant$10(+_), x1 = null, area) : x0;

-   };

- 

-   area.x0 = function(_) {

-     return arguments.length ? (x0 = typeof _ === "function" ? _ : constant$10(+_), area) : x0;

-   };

- 

-   area.x1 = function(_) {

-     return arguments.length ? (x1 = _ == null ? null : typeof _ === "function" ? _ : constant$10(+_), area) : x1;

-   };

- 

-   area.y = function(_) {

-     return arguments.length ? (y0 = typeof _ === "function" ? _ : constant$10(+_), y1 = null, area) : y0;

-   };

- 

-   area.y0 = function(_) {

-     return arguments.length ? (y0 = typeof _ === "function" ? _ : constant$10(+_), area) : y0;

-   };

- 

-   area.y1 = function(_) {

-     return arguments.length ? (y1 = _ == null ? null : typeof _ === "function" ? _ : constant$10(+_), area) : y1;

-   };

- 

-   area.lineX0 =

-   area.lineY0 = function() {

-     return arealine().x(x0).y(y0);

-   };

- 

-   area.lineY1 = function() {

-     return arealine().x(x0).y(y1);

-   };

- 

-   area.lineX1 = function() {

-     return arealine().x(x1).y(y0);

-   };

- 

-   area.defined = function(_) {

-     return arguments.length ? (defined = typeof _ === "function" ? _ : constant$10(!!_), area) : defined;

-   };

- 

-   area.curve = function(_) {

-     return arguments.length ? (curve = _, context != null && (output = curve(context)), area) : curve;

-   };

- 

-   area.context = function(_) {

-     return arguments.length ? (_ == null ? context = output = null : output = curve(context = _), area) : context;

-   };

- 

-   return area;

- };

- 

- var descending$1 = function(a, b) {

-   return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;

- };

- 

- var identity$7 = function(d) {

-   return d;

- };

- 

- var pie = function() {

-   var value = identity$7,

-       sortValues = descending$1,

-       sort = null,

-       startAngle = constant$10(0),

-       endAngle = constant$10(tau$4),

-       padAngle = constant$10(0);

- 

-   function pie(data) {

-     var i,

-         n = data.length,

-         j,

-         k,

-         sum = 0,

-         index = new Array(n),

-         arcs = new Array(n),

-         a0 = +startAngle.apply(this, arguments),

-         da = Math.min(tau$4, Math.max(-tau$4, endAngle.apply(this, arguments) - a0)),

-         a1,

-         p = Math.min(Math.abs(da) / n, padAngle.apply(this, arguments)),

-         pa = p * (da < 0 ? -1 : 1),

-         v;

- 

-     for (i = 0; i < n; ++i) {

-       if ((v = arcs[index[i] = i] = +value(data[i], i, data)) > 0) {

-         sum += v;

-       }

-     }

- 

-     // Optionally sort the arcs by previously-computed values or by data.

-     if (sortValues != null) index.sort(function(i, j) { return sortValues(arcs[i], arcs[j]); });

-     else if (sort != null) index.sort(function(i, j) { return sort(data[i], data[j]); });

- 

-     // Compute the arcs! They are stored in the original data's order.

-     for (i = 0, k = sum ? (da - n * pa) / sum : 0; i < n; ++i, a0 = a1) {

-       j = index[i], v = arcs[j], a1 = a0 + (v > 0 ? v * k : 0) + pa, arcs[j] = {

-         data: data[j],

-         index: i,

-         value: v,

-         startAngle: a0,

-         endAngle: a1,

-         padAngle: p

-       };

-     }

- 

-     return arcs;

-   }

- 

-   pie.value = function(_) {

-     return arguments.length ? (value = typeof _ === "function" ? _ : constant$10(+_), pie) : value;

-   };

- 

-   pie.sortValues = function(_) {

-     return arguments.length ? (sortValues = _, sort = null, pie) : sortValues;

-   };

- 

-   pie.sort = function(_) {

-     return arguments.length ? (sort = _, sortValues = null, pie) : sort;

-   };

- 

-   pie.startAngle = function(_) {

-     return arguments.length ? (startAngle = typeof _ === "function" ? _ : constant$10(+_), pie) : startAngle;

-   };

- 

-   pie.endAngle = function(_) {

-     return arguments.length ? (endAngle = typeof _ === "function" ? _ : constant$10(+_), pie) : endAngle;

-   };

- 

-   pie.padAngle = function(_) {

-     return arguments.length ? (padAngle = typeof _ === "function" ? _ : constant$10(+_), pie) : padAngle;

-   };

- 

-   return pie;

- };

- 

- var curveRadialLinear = curveRadial(curveLinear);

- 

- function Radial(curve) {

-   this._curve = curve;

- }

- 

- Radial.prototype = {

-   areaStart: function() {

-     this._curve.areaStart();

-   },

-   areaEnd: function() {

-     this._curve.areaEnd();

-   },

-   lineStart: function() {

-     this._curve.lineStart();

-   },

-   lineEnd: function() {

-     this._curve.lineEnd();

-   },

-   point: function(a, r) {

-     this._curve.point(r * Math.sin(a), r * -Math.cos(a));

-   }

- };

- 

- function curveRadial(curve) {

- 

-   function radial(context) {

-     return new Radial(curve(context));

-   }

- 

-   radial._curve = curve;

- 

-   return radial;

- }

- 

- function lineRadial(l) {

-   var c = l.curve;

- 

-   l.angle = l.x, delete l.x;

-   l.radius = l.y, delete l.y;

- 

-   l.curve = function(_) {

-     return arguments.length ? c(curveRadial(_)) : c()._curve;

-   };

- 

-   return l;

- }

- 

- var lineRadial$1 = function() {

-   return lineRadial(line().curve(curveRadialLinear));

- };

- 

- var areaRadial = function() {

-   var a = area$2().curve(curveRadialLinear),

-       c = a.curve,

-       x0 = a.lineX0,

-       x1 = a.lineX1,

-       y0 = a.lineY0,

-       y1 = a.lineY1;

- 

-   a.angle = a.x, delete a.x;

-   a.startAngle = a.x0, delete a.x0;

-   a.endAngle = a.x1, delete a.x1;

-   a.radius = a.y, delete a.y;

-   a.innerRadius = a.y0, delete a.y0;

-   a.outerRadius = a.y1, delete a.y1;

-   a.lineStartAngle = function() { return lineRadial(x0()); }, delete a.lineX0;

-   a.lineEndAngle = function() { return lineRadial(x1()); }, delete a.lineX1;

-   a.lineInnerRadius = function() { return lineRadial(y0()); }, delete a.lineY0;

-   a.lineOuterRadius = function() { return lineRadial(y1()); }, delete a.lineY1;

- 

-   a.curve = function(_) {

-     return arguments.length ? c(curveRadial(_)) : c()._curve;

-   };

- 

-   return a;

- };

- 

- var pointRadial = function(x, y) {

-   return [(y = +y) * Math.cos(x -= Math.PI / 2), y * Math.sin(x)];

- };

- 

- var slice$6 = Array.prototype.slice;

- 

- function linkSource(d) {

-   return d.source;

- }

- 

- function linkTarget(d) {

-   return d.target;

- }

- 

- function link$2(curve) {

-   var source = linkSource,

-       target = linkTarget,

-       x$$1 = x$3,

-       y$$1 = y$3,

-       context = null;

- 

-   function link() {

-     var buffer, argv = slice$6.call(arguments), s = source.apply(this, argv), t = target.apply(this, argv);

-     if (!context) context = buffer = path();

-     curve(context, +x$$1.apply(this, (argv[0] = s, argv)), +y$$1.apply(this, argv), +x$$1.apply(this, (argv[0] = t, argv)), +y$$1.apply(this, argv));

-     if (buffer) return context = null, buffer + "" || null;

-   }

- 

-   link.source = function(_) {

-     return arguments.length ? (source = _, link) : source;

-   };

- 

-   link.target = function(_) {

-     return arguments.length ? (target = _, link) : target;

-   };

- 

-   link.x = function(_) {

-     return arguments.length ? (x$$1 = typeof _ === "function" ? _ : constant$10(+_), link) : x$$1;

-   };

- 

-   link.y = function(_) {

-     return arguments.length ? (y$$1 = typeof _ === "function" ? _ : constant$10(+_), link) : y$$1;

-   };

- 

-   link.context = function(_) {

-     return arguments.length ? ((context = _ == null ? null : _), link) : context;

-   };

- 

-   return link;

- }

- 

- function curveHorizontal(context, x0, y0, x1, y1) {

-   context.moveTo(x0, y0);

-   context.bezierCurveTo(x0 = (x0 + x1) / 2, y0, x0, y1, x1, y1);

- }

- 

- function curveVertical(context, x0, y0, x1, y1) {

-   context.moveTo(x0, y0);

-   context.bezierCurveTo(x0, y0 = (y0 + y1) / 2, x1, y0, x1, y1);

- }

- 

- function curveRadial$1(context, x0, y0, x1, y1) {

-   var p0 = pointRadial(x0, y0),

-       p1 = pointRadial(x0, y0 = (y0 + y1) / 2),

-       p2 = pointRadial(x1, y0),

-       p3 = pointRadial(x1, y1);

-   context.moveTo(p0[0], p0[1]);

-   context.bezierCurveTo(p1[0], p1[1], p2[0], p2[1], p3[0], p3[1]);

- }

- 

- function linkHorizontal() {

-   return link$2(curveHorizontal);

- }

- 

- function linkVertical() {

-   return link$2(curveVertical);

- }

- 

- function linkRadial() {

-   var l = link$2(curveRadial$1);

-   l.angle = l.x, delete l.x;

-   l.radius = l.y, delete l.y;

-   return l;

- }

- 

- var circle$2 = {

-   draw: function(context, size) {

-     var r = Math.sqrt(size / pi$4);

-     context.moveTo(r, 0);

-     context.arc(0, 0, r, 0, tau$4);

-   }

- };

- 

- var cross$2 = {

-   draw: function(context, size) {

-     var r = Math.sqrt(size / 5) / 2;

-     context.moveTo(-3 * r, -r);

-     context.lineTo(-r, -r);

-     context.lineTo(-r, -3 * r);

-     context.lineTo(r, -3 * r);

-     context.lineTo(r, -r);

-     context.lineTo(3 * r, -r);

-     context.lineTo(3 * r, r);

-     context.lineTo(r, r);

-     context.lineTo(r, 3 * r);

-     context.lineTo(-r, 3 * r);

-     context.lineTo(-r, r);

-     context.lineTo(-3 * r, r);

-     context.closePath();

-   }

- };

- 

- var tan30 = Math.sqrt(1 / 3);

- var tan30_2 = tan30 * 2;

- 

- var diamond = {

-   draw: function(context, size) {

-     var y = Math.sqrt(size / tan30_2),

-         x = y * tan30;

-     context.moveTo(0, -y);

-     context.lineTo(x, 0);

-     context.lineTo(0, y);

-     context.lineTo(-x, 0);

-     context.closePath();

-   }

- };

- 

- var ka = 0.89081309152928522810;

- var kr = Math.sin(pi$4 / 10) / Math.sin(7 * pi$4 / 10);

- var kx = Math.sin(tau$4 / 10) * kr;

- var ky = -Math.cos(tau$4 / 10) * kr;

- 

- var star = {

-   draw: function(context, size) {

-     var r = Math.sqrt(size * ka),

-         x = kx * r,

-         y = ky * r;

-     context.moveTo(0, -r);

-     context.lineTo(x, y);

-     for (var i = 1; i < 5; ++i) {

-       var a = tau$4 * i / 5,

-           c = Math.cos(a),

-           s = Math.sin(a);

-       context.lineTo(s * r, -c * r);

-       context.lineTo(c * x - s * y, s * x + c * y);

-     }

-     context.closePath();

-   }

- };

- 

- var square = {

-   draw: function(context, size) {

-     var w = Math.sqrt(size),

-         x = -w / 2;

-     context.rect(x, x, w, w);

-   }

- };

- 

- var sqrt3 = Math.sqrt(3);

- 

- var triangle = {

-   draw: function(context, size) {

-     var y = -Math.sqrt(size / (sqrt3 * 3));

-     context.moveTo(0, y * 2);

-     context.lineTo(-sqrt3 * y, -y);

-     context.lineTo(sqrt3 * y, -y);

-     context.closePath();

-   }

- };

- 

- var c = -0.5;

- var s = Math.sqrt(3) / 2;

- var k = 1 / Math.sqrt(12);

- var a = (k / 2 + 1) * 3;

- 

- var wye = {

-   draw: function(context, size) {

-     var r = Math.sqrt(size / a),

-         x0 = r / 2,

-         y0 = r * k,

-         x1 = x0,

-         y1 = r * k + r,

-         x2 = -x1,

-         y2 = y1;

-     context.moveTo(x0, y0);

-     context.lineTo(x1, y1);

-     context.lineTo(x2, y2);

-     context.lineTo(c * x0 - s * y0, s * x0 + c * y0);

-     context.lineTo(c * x1 - s * y1, s * x1 + c * y1);

-     context.lineTo(c * x2 - s * y2, s * x2 + c * y2);

-     context.lineTo(c * x0 + s * y0, c * y0 - s * x0);

-     context.lineTo(c * x1 + s * y1, c * y1 - s * x1);

-     context.lineTo(c * x2 + s * y2, c * y2 - s * x2);

-     context.closePath();

-   }

- };

- 

- var symbols = [

-   circle$2,

-   cross$2,

-   diamond,

-   square,

-   star,

-   triangle,

-   wye

- ];

- 

- var symbol = function() {

-   var type = constant$10(circle$2),

-       size = constant$10(64),

-       context = null;

- 

-   function symbol() {

-     var buffer;

-     if (!context) context = buffer = path();

-     type.apply(this, arguments).draw(context, +size.apply(this, arguments));

-     if (buffer) return context = null, buffer + "" || null;

-   }

- 

-   symbol.type = function(_) {

-     return arguments.length ? (type = typeof _ === "function" ? _ : constant$10(_), symbol) : type;

-   };

- 

-   symbol.size = function(_) {

-     return arguments.length ? (size = typeof _ === "function" ? _ : constant$10(+_), symbol) : size;

-   };

- 

-   symbol.context = function(_) {

-     return arguments.length ? (context = _ == null ? null : _, symbol) : context;

-   };

- 

-   return symbol;

- };

- 

- var noop$2 = function() {};

- 

- function point$2(that, x, y) {

-   that._context.bezierCurveTo(

-     (2 * that._x0 + that._x1) / 3,

-     (2 * that._y0 + that._y1) / 3,

-     (that._x0 + 2 * that._x1) / 3,

-     (that._y0 + 2 * that._y1) / 3,

-     (that._x0 + 4 * that._x1 + x) / 6,

-     (that._y0 + 4 * that._y1 + y) / 6

-   );

- }

- 

- function Basis(context) {

-   this._context = context;

- }

- 

- Basis.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: point$2(this, this._x1, this._y1); // proceed

-       case 2: this._context.lineTo(this._x1, this._y1); break;

-     }

-     if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();

-     this._line = 1 - this._line;

-   },

-   point: function(x, y) {

-     x = +x, y = +y;

-     switch (this._point) {

-       case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); 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); // proceed

-       default: point$2(this, x, y); break;

-     }

-     this._x0 = this._x1, this._x1 = x;

-     this._y0 = this._y1, this._y1 = y;

-   }

- };

- 

- var basis$2 = function(context) {

-   return new Basis(context);

- };

- 

- function BasisClosed(context) {

-   this._context = context;

- }

- 

- BasisClosed.prototype = {

-   areaStart: noop$2,

-   areaEnd: noop$2,

-   lineStart: function() {

-     this._x0 = this._x1 = this._x2 = this._x3 = this._x4 =

-     this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = NaN;

-     this._point = 0;

-   },

-   lineEnd: function() {

-     switch (this._point) {

-       case 1: {

-         this._context.moveTo(this._x2, this._y2);

-         this._context.closePath();

-         break;

-       }

-       case 2: {

-         this._context.moveTo((this._x2 + 2 * this._x3) / 3, (this._y2 + 2 * this._y3) / 3);

-         this._context.lineTo((this._x3 + 2 * this._x2) / 3, (this._y3 + 2 * this._y2) / 3);

-         this._context.closePath();

-         break;

-       }

-       case 3: {

-         this.point(this._x2, this._y2);

-         this.point(this._x3, this._y3);

-         this.point(this._x4, this._y4);

-         break;

-       }

-     }

-   },

-   point: function(x, y) {

-     x = +x, y = +y;

-     switch (this._point) {

-       case 0: this._point = 1; this._x2 = x, this._y2 = y; break;

-       case 1: this._point = 2; this._x3 = x, this._y3 = y; break;

-       case 2: this._point = 3; this._x4 = x, this._y4 = y; this._context.moveTo((this._x0 + 4 * this._x1 + x) / 6, (this._y0 + 4 * this._y1 + y) / 6); break;

-       default: point$2(this, x, y); break;

-     }

-     this._x0 = this._x1, this._x1 = x;

-     this._y0 = this._y1, this._y1 = y;

-   }

- };

- 

- var basisClosed$1 = function(context) {

-   return new BasisClosed(context);

- };

- 

- function BasisOpen(context) {

-   this._context = context;

- }

- 

- BasisOpen.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() {

-     if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();

-     this._line = 1 - this._line;

-   },

-   point: function(x, y) {

-     x = +x, y = +y;

-     switch (this._point) {

-       case 0: this._point = 1; break;

-       case 1: this._point = 2; break;

-       case 2: this._point = 3; var x0 = (this._x0 + 4 * this._x1 + x) / 6, y0 = (this._y0 + 4 * this._y1 + y) / 6; this._line ? this._context.lineTo(x0, y0) : this._context.moveTo(x0, y0); break;

-       case 3: this._point = 4; // proceed

-       default: point$2(this, x, y); break;

-     }

-     this._x0 = this._x1, this._x1 = x;

-     this._y0 = this._y1, this._y1 = y;

-   }

- };

- 

- var basisOpen = function(context) {

-   return new BasisOpen(context);

- };

- 

- function Bundle(context, beta) {

-   this._basis = new Basis(context);

-   this._beta = beta;

- }

- 

- Bundle.prototype = {

-   lineStart: function() {

-     this._x = [];

-     this._y = [];

-     this._basis.lineStart();

-   },

-   lineEnd: function() {

-     var x = this._x,

-         y = this._y,

-         j = x.length - 1;

- 

-     if (j > 0) {

-       var x0 = x[0],

-           y0 = y[0],

-           dx = x[j] - x0,

-           dy = y[j] - y0,

-           i = -1,

-           t;

- 

-       while (++i <= j) {

-         t = i / j;

-         this._basis.point(

-           this._beta * x[i] + (1 - this._beta) * (x0 + t * dx),

-           this._beta * y[i] + (1 - this._beta) * (y0 + t * dy)

-         );

-       }

-     }

- 

-     this._x = this._y = null;

-     this._basis.lineEnd();

-   },

-   point: function(x, y) {

-     this._x.push(+x);

-     this._y.push(+y);

-   }

- };

- 

- var bundle = (function custom(beta) {

- 

-   function bundle(context) {

-     return beta === 1 ? new Basis(context) : new Bundle(context, beta);

-   }

- 

-   bundle.beta = function(beta) {

-     return custom(+beta);

-   };

- 

-   return bundle;

- })(0.85);

- 

- function point$3(that, x, y) {

-   that._context.bezierCurveTo(

-     that._x1 + that._k * (that._x2 - that._x0),

-     that._y1 + that._k * (that._y2 - that._y0),

-     that._x2 + that._k * (that._x1 - x),

-     that._y2 + that._k * (that._y1 - y),

-     that._x2,

-     that._y2

-   );

- }

- 

- function Cardinal(context, tension) {

-   this._context = context;

-   this._k = (1 - tension) / 6;

- }

- 

- Cardinal.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: point$3(this, this._x1, this._y1); break;

-     }

-     if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();

-     this._line = 1 - this._line;

-   },

-   point: function(x, y) {

-     x = +x, y = +y;

-     switch (this._point) {

-       case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;

-       case 1: this._point = 2; this._x1 = x, this._y1 = y; break;

-       case 2: this._point = 3; // proceed

-       default: point$3(this, x, y); break;

-     }

-     this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;

-     this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;

-   }

- };

- 

- var cardinal = (function custom(tension) {

- 

-   function cardinal(context) {

-     return new Cardinal(context, tension);

-   }

- 

-   cardinal.tension = function(tension) {

-     return custom(+tension);

-   };

- 

-   return cardinal;

- })(0);

- 

- function CardinalClosed(context, tension) {

-   this._context = context;

-   this._k = (1 - tension) / 6;

- }

- 

- CardinalClosed.prototype = {

-   areaStart: noop$2,

-   areaEnd: noop$2,

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

-         break;

-       }

-     }

-   },

-   point: function(x, y) {

-     x = +x, y = +y;

-     switch (this._point) {

-       case 0: this._point = 1; this._x3 = x, this._y3 = y; break;

-       case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;

-       case 2: this._point = 3; this._x5 = x, this._y5 = y; break;

-       default: point$3(this, x, y); break;

-     }

-     this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;

-     this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;

-   }

- };

- 

- var cardinalClosed = (function custom(tension) {

- 

-   function cardinal$$1(context) {

-     return new CardinalClosed(context, tension);

-   }

- 

-   cardinal$$1.tension = function(tension) {

-     return custom(+tension);

-   };

- 

-   return cardinal$$1;

- })(0);

- 

- function CardinalOpen(context, tension) {

-   this._context = context;

-   this._k = (1 - tension) / 6;

- }

- 

- CardinalOpen.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() {

-     if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();

-     this._line = 1 - this._line;

-   },

-   point: function(x, y) {

-     x = +x, y = +y;

-     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; // proceed

-       default: point$3(this, x, y); break;

-     }

-     this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;

-     this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;

-   }

- };

- 

- var cardinalOpen = (function custom(tension) {

- 

-   function cardinal$$1(context) {

-     return new CardinalOpen(context, tension);

-   }

- 

-   cardinal$$1.tension = function(tension) {

-     return custom(+tension);

-   };

- 

-   return cardinal$$1;

- })(0);

- 

- function point$4(that, x, y) {

-   var x1 = that._x1,

-       y1 = that._y1,

-       x2 = that._x2,

-       y2 = that._y2;

- 

-   if (that._l01_a > epsilon$3) {

-     var a = 2 * that._l01_2a + 3 * that._l01_a * that._l12_a + that._l12_2a,

-         n = 3 * that._l01_a * (that._l01_a + that._l12_a);

-     x1 = (x1 * a - that._x0 * that._l12_2a + that._x2 * that._l01_2a) / n;

-     y1 = (y1 * a - that._y0 * that._l12_2a + that._y2 * that._l01_2a) / n;

-   }

- 

-   if (that._l23_a > epsilon$3) {

-     var b = 2 * that._l23_2a + 3 * that._l23_a * that._l12_a + that._l12_2a,

-         m = 3 * that._l23_a * (that._l23_a + that._l12_a);

-     x2 = (x2 * b + that._x1 * that._l23_2a - x * that._l12_2a) / m;

-     y2 = (y2 * b + that._y1 * that._l23_2a - y * that._l12_2a) / m;

-   }

- 

-   that._context.bezierCurveTo(x1, y1, x2, y2, that._x2, that._y2);

- }

- 

- function CatmullRom(context, alpha) {

-   this._context = context;

-   this._alpha = alpha;

- }

- 

- CatmullRom.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); break;

-     }

-     if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();

-     this._line = 1 - this._line;

-   },

-   point: function(x, y) {

-     x = +x, y = +y;

- 

-     if (this._point) {

-       var x23 = this._x2 - x,

-           y23 = this._y2 - y;

-       this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));

-     }

- 

-     switch (this._point) {

-       case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;

-       case 1: this._point = 2; break;

-       case 2: this._point = 3; // proceed

-       default: point$4(this, x, y); break;

-     }

- 

-     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 = x;

-     this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;

-   }

- };

- 

- var catmullRom = (function custom(alpha) {

- 

-   function catmullRom(context) {

-     return alpha ? new CatmullRom(context, alpha) : new Cardinal(context, 0);

-   }

- 

-   catmullRom.alpha = function(alpha) {

-     return custom(+alpha);

-   };

- 

-   return catmullRom;

- })(0.5);

- 

- function CatmullRomClosed(context, alpha) {

-   this._context = context;

-   this._alpha = alpha;

- }

- 

- CatmullRomClosed.prototype = {

-   areaStart: noop$2,

-   areaEnd: noop$2,

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

-         break;

-       }

-     }

-   },

-   point: function(x, y) {

-     x = +x, y = +y;

- 

-     if (this._point) {

-       var x23 = this._x2 - x,

-           y23 = this._y2 - y;

-       this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));

-     }

- 

-     switch (this._point) {

-       case 0: this._point = 1; this._x3 = x, this._y3 = y; break;

-       case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;

-       case 2: this._point = 3; this._x5 = x, this._y5 = y; break;

-       default: point$4(this, x, y); break;

-     }

- 

-     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 = x;

-     this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;

-   }

- };

- 

- var catmullRomClosed = (function custom(alpha) {

- 

-   function catmullRom$$1(context) {

-     return alpha ? new CatmullRomClosed(context, alpha) : new CardinalClosed(context, 0);

-   }

- 

-   catmullRom$$1.alpha = function(alpha) {

-     return custom(+alpha);

-   };

- 

-   return catmullRom$$1;

- })(0.5);

- 

- function CatmullRomOpen(context, alpha) {

-   this._context = context;

-   this._alpha = alpha;

- }

- 

- CatmullRomOpen.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() {

-     if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();

-     this._line = 1 - this._line;

-   },

-   point: function(x, y) {

-     x = +x, y = +y;

- 

-     if (this._point) {

-       var x23 = this._x2 - x,

-           y23 = this._y2 - y;

-       this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, 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; // proceed

-       default: point$4(this, x, y); break;

-     }

- 

-     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 = x;

-     this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;

-   }

- };

- 

- var catmullRomOpen = (function custom(alpha) {

- 

-   function catmullRom$$1(context) {

-     return alpha ? new CatmullRomOpen(context, alpha) : new CardinalOpen(context, 0);

-   }

- 

-   catmullRom$$1.alpha = function(alpha) {

-     return custom(+alpha);

-   };

- 

-   return catmullRom$$1;

- })(0.5);

- 

- function LinearClosed(context) {

-   this._context = context;

- }

- 

- LinearClosed.prototype = {

-   areaStart: noop$2,

-   areaEnd: noop$2,

-   lineStart: function() {

-     this._point = 0;

-   },

-   lineEnd: function() {

-     if (this._point) this._context.closePath();

-   },

-   point: function(x, y) {

-     x = +x, y = +y;

-     if (this._point) this._context.lineTo(x, y);

-     else this._point = 1, this._context.moveTo(x, y);

-   }

- };

- 

- var linearClosed = function(context) {

-   return new LinearClosed(context);

- };

- 

- function sign$1(x) {

-   return x < 0 ? -1 : 1;

- }

- 

- // Calculate the slopes of the tangents (Hermite-type interpolation) based on

- // the following paper: Steffen, M. 1990. A Simple Method for Monotonic

- // Interpolation in One Dimension. Astronomy and Astrophysics, Vol. 239, NO.

- // NOV(II), P. 443, 1990.

- function slope3(that, x2, y2) {

-   var h0 = that._x1 - that._x0,

-       h1 = x2 - that._x1,

-       s0 = (that._y1 - that._y0) / (h0 || h1 < 0 && -0),

-       s1 = (y2 - that._y1) / (h1 || h0 < 0 && -0),

-       p = (s0 * h1 + s1 * h0) / (h0 + h1);

-   return (sign$1(s0) + sign$1(s1)) * Math.min(Math.abs(s0), Math.abs(s1), 0.5 * Math.abs(p)) || 0;

- }

- 

- // Calculate a one-sided slope.

- function slope2(that, t) {

-   var h = that._x1 - that._x0;

-   return h ? (3 * (that._y1 - that._y0) / h - t) / 2 : t;

- }

- 

- // According to https://en.wikipedia.org/wiki/Cubic_Hermite_spline#Representations

- // "you can express cubic Hermite interpolation in terms of cubic Bézier curves

- // with respect to the four values p0, p0 + m0 / 3, p1 - m1 / 3, p1".

- function point$5(that, t0, t1) {

-   var x0 = that._x0,

-       y0 = that._y0,

-       x1 = that._x1,

-       y1 = that._y1,

-       dx = (x1 - x0) / 3;

-   that._context.bezierCurveTo(x0 + dx, y0 + dx * t0, x1 - dx, y1 - dx * t1, x1, y1);

- }

- 

- function MonotoneX(context) {

-   this._context = context;

- }

- 

- MonotoneX.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: point$5(this, this._t0, slope2(this, this._t0)); break;

-     }

-     if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();

-     this._line = 1 - this._line;

-   },

-   point: function(x, y) {

-     var t1 = NaN;

- 

-     x = +x, y = +y;

-     if (x === this._x1 && y === this._y1) return; // Ignore coincident points.

-     switch (this._point) {

-       case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;

-       case 1: this._point = 2; break;

-       case 2: this._point = 3; point$5(this, slope2(this, t1 = slope3(this, x, y)), t1); break;

-       default: point$5(this, this._t0, t1 = slope3(this, x, y)); break;

-     }

- 

-     this._x0 = this._x1, this._x1 = x;

-     this._y0 = this._y1, this._y1 = y;

-     this._t0 = t1;

-   }

- };

- 

- function MonotoneY(context) {

-   this._context = new ReflectContext(context);

- }

- 

- (MonotoneY.prototype = Object.create(MonotoneX.prototype)).point = function(x, y) {

-   MonotoneX.prototype.point.call(this, y, x);

- };

- 

- function ReflectContext(context) {

-   this._context = context;

- }

- 

- ReflectContext.prototype = {

-   moveTo: function(x, y) { this._context.moveTo(y, x); },

-   closePath: function() { this._context.closePath(); },

-   lineTo: function(x, y) { this._context.lineTo(y, x); },

-   bezierCurveTo: function(x1, y1, x2, y2, x, y) { this._context.bezierCurveTo(y1, x1, y2, x2, y, x); }

- };

- 

- function monotoneX(context) {

-   return new MonotoneX(context);

- }

- 

- function monotoneY(context) {

-   return new MonotoneY(context);

- }

- 

- function Natural(context) {

-   this._context = context;

- }

- 

- Natural.prototype = {

-   areaStart: function() {

-     this._line = 0;

-   },

-   areaEnd: function() {

-     this._line = NaN;

-   },

-   lineStart: function() {

-     this._x = [];

-     this._y = [];

-   },

-   lineEnd: function() {

-     var x = this._x,

-         y = this._y,

-         n = x.length;

- 

-     if (n) {

-       this._line ? this._context.lineTo(x[0], y[0]) : this._context.moveTo(x[0], y[0]);

-       if (n === 2) {

-         this._context.lineTo(x[1], y[1]);

-       } else {

-         var px = controlPoints(x),

-             py = controlPoints(y);

-         for (var i0 = 0, i1 = 1; i1 < n; ++i0, ++i1) {

-           this._context.bezierCurveTo(px[0][i0], py[0][i0], px[1][i0], py[1][i0], x[i1], y[i1]);

-         }

-       }

-     }

- 

-     if (this._line || (this._line !== 0 && n === 1)) this._context.closePath();

-     this._line = 1 - this._line;

-     this._x = this._y = null;

-   },

-   point: function(x, y) {

-     this._x.push(+x);

-     this._y.push(+y);

-   }

- };

- 

- // See https://www.particleincell.com/2012/bezier-splines/ for derivation.

- function controlPoints(x) {

-   var i,

-       n = x.length - 1,

-       m,

-       a = new Array(n),

-       b = new Array(n),

-       r = new Array(n);

-   a[0] = 0, b[0] = 2, r[0] = x[0] + 2 * x[1];

-   for (i = 1; i < n - 1; ++i) a[i] = 1, b[i] = 4, r[i] = 4 * x[i] + 2 * x[i + 1];

-   a[n - 1] = 2, b[n - 1] = 7, r[n - 1] = 8 * x[n - 1] + x[n];

-   for (i = 1; i < n; ++i) m = a[i] / b[i - 1], b[i] -= m, r[i] -= m * r[i - 1];

-   a[n - 1] = r[n - 1] / b[n - 1];

-   for (i = n - 2; i >= 0; --i) a[i] = (r[i] - a[i + 1]) / b[i];

-   b[n - 1] = (x[n] + a[n - 1]) / 2;

-   for (i = 0; i < n - 1; ++i) b[i] = 2 * x[i + 1] - a[i + 1];

-   return [a, b];

- }

- 

- var natural = function(context) {

-   return new Natural(context);

- };

- 

- function Step(context, t) {

-   this._context = context;

-   this._t = t;

- }

- 

- Step.prototype = {

-   areaStart: function() {

-     this._line = 0;

-   },

-   areaEnd: function() {

-     this._line = NaN;

-   },

-   lineStart: function() {

-     this._x = this._y = NaN;

-     this._point = 0;

-   },

-   lineEnd: function() {

-     if (0 < this._t && this._t < 1 && this._point === 2) this._context.lineTo(this._x, this._y);

-     if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();

-     if (this._line >= 0) this._t = 1 - this._t, this._line = 1 - this._line;

-   },

-   point: function(x, y) {

-     x = +x, y = +y;

-     switch (this._point) {

-       case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;

-       case 1: this._point = 2; // proceed

-       default: {

-         if (this._t <= 0) {

-           this._context.lineTo(this._x, y);

-           this._context.lineTo(x, y);

-         } else {

-           var x1 = this._x * (1 - this._t) + x * this._t;

-           this._context.lineTo(x1, this._y);

-           this._context.lineTo(x1, y);

-         }

-         break;

-       }

-     }

-     this._x = x, this._y = y;

-   }

- };

- 

- var step = function(context) {

-   return new Step(context, 0.5);

- };

- 

- function stepBefore(context) {

-   return new Step(context, 0);

- }

- 

- function stepAfter(context) {

-   return new Step(context, 1);

- }

- 

- var none$1 = function(series, order) {

-   if (!((n = series.length) > 1)) return;

-   for (var i = 1, j, s0, s1 = series[order[0]], n, m = s1.length; i < n; ++i) {

-     s0 = s1, s1 = series[order[i]];

-     for (j = 0; j < m; ++j) {

-       s1[j][1] += s1[j][0] = isNaN(s0[j][1]) ? s0[j][0] : s0[j][1];

-     }

-   }

- };

- 

- var none$2 = function(series) {

-   var n = series.length, o = new Array(n);

-   while (--n >= 0) o[n] = n;

-   return o;

- };

- 

- function stackValue(d, key) {

-   return d[key];

- }

- 

- var stack = function() {

-   var keys = constant$10([]),

-       order = none$2,

-       offset = none$1,

-       value = stackValue;

- 

-   function stack(data) {

-     var kz = keys.apply(this, arguments),

-         i,

-         m = data.length,

-         n = kz.length,

-         sz = new Array(n),

-         oz;

- 

-     for (i = 0; i < n; ++i) {

-       for (var ki = kz[i], si = sz[i] = new Array(m), j = 0, sij; j < m; ++j) {

-         si[j] = sij = [0, +value(data[j], ki, j, data)];

-         sij.data = data[j];

-       }

-       si.key = ki;

-     }

- 

-     for (i = 0, oz = order(sz); i < n; ++i) {

-       sz[oz[i]].index = i;

-     }

- 

-     offset(sz, oz);

-     return sz;

-   }

- 

-   stack.keys = function(_) {

-     return arguments.length ? (keys = typeof _ === "function" ? _ : constant$10(slice$6.call(_)), stack) : keys;

-   };

- 

-   stack.value = function(_) {

-     return arguments.length ? (value = typeof _ === "function" ? _ : constant$10(+_), stack) : value;

-   };

- 

-   stack.order = function(_) {

-     return arguments.length ? (order = _ == null ? none$2 : typeof _ === "function" ? _ : constant$10(slice$6.call(_)), stack) : order;

-   };

- 

-   stack.offset = function(_) {

-     return arguments.length ? (offset = _ == null ? none$1 : _, stack) : offset;

-   };

- 

-   return stack;

- };

- 

- var expand = function(series, order) {

-   if (!((n = series.length) > 0)) return;

-   for (var i, n, j = 0, m = series[0].length, y; j < m; ++j) {

-     for (y = i = 0; i < n; ++i) y += series[i][j][1] || 0;

-     if (y) for (i = 0; i < n; ++i) series[i][j][1] /= y;

-   }

-   none$1(series, order);

- };

- 

- var diverging = function(series, order) {

-   if (!((n = series.length) > 1)) return;

-   for (var i, j = 0, d, dy, yp, yn, n, m = series[order[0]].length; j < m; ++j) {

-     for (yp = yn = 0, i = 0; i < n; ++i) {

-       if ((dy = (d = series[order[i]][j])[1] - d[0]) >= 0) {

-         d[0] = yp, d[1] = yp += dy;

-       } else if (dy < 0) {

-         d[1] = yn, d[0] = yn += dy;

-       } else {

-         d[0] = yp;

-       }

-     }

-   }

- };

- 

- var silhouette = function(series, order) {

-   if (!((n = series.length) > 0)) return;

-   for (var j = 0, s0 = series[order[0]], n, m = s0.length; j < m; ++j) {

-     for (var i = 0, y = 0; i < n; ++i) y += series[i][j][1] || 0;

-     s0[j][1] += s0[j][0] = -y / 2;

-   }

-   none$1(series, order);

- };

- 

- var wiggle = function(series, order) {

-   if (!((n = series.length) > 0) || !((m = (s0 = series[order[0]]).length) > 0)) return;

-   for (var y = 0, j = 1, s0, m, n; j < m; ++j) {

-     for (var i = 0, s1 = 0, s2 = 0; i < n; ++i) {

-       var si = series[order[i]],

-           sij0 = si[j][1] || 0,

-           sij1 = si[j - 1][1] || 0,

-           s3 = (sij0 - sij1) / 2;

-       for (var k = 0; k < i; ++k) {

-         var sk = series[order[k]],

-             skj0 = sk[j][1] || 0,

-             skj1 = sk[j - 1][1] || 0;

-         s3 += skj0 - skj1;

-       }

-       s1 += sij0, s2 += s3 * sij0;

-     }

-     s0[j - 1][1] += s0[j - 1][0] = y;

-     if (s1) y -= s2 / s1;

-   }

-   s0[j - 1][1] += s0[j - 1][0] = y;

-   none$1(series, order);

- };

- 

- var ascending$2 = function(series) {

-   var sums = series.map(sum$2);

-   return none$2(series).sort(function(a, b) { return sums[a] - sums[b]; });

- };

- 

- function sum$2(series) {

-   var s = 0, i = -1, n = series.length, v;

-   while (++i < n) if (v = +series[i][1]) s += v;

-   return s;

- }

- 

- var descending$2 = function(series) {

-   return ascending$2(series).reverse();

- };

- 

- var insideOut = function(series) {

-   var n = series.length,

-       i,

-       j,

-       sums = series.map(sum$2),

-       order = none$2(series).sort(function(a, b) { return sums[b] - sums[a]; }),

-       top = 0,

-       bottom = 0,

-       tops = [],

-       bottoms = [];

- 

-   for (i = 0; i < n; ++i) {

-     j = order[i];

-     if (top < bottom) {

-       top += sums[j];

-       tops.push(j);

-     } else {

-       bottom += sums[j];

-       bottoms.push(j);

-     }

-   }

- 

-   return bottoms.reverse().concat(tops);

- };

- 

- var reverse = function(series) {

-   return none$2(series).reverse();

- };

- 

- var constant$11 = function(x) {

-   return function() {

-     return x;

-   };

- };

- 

- function x$4(d) {

-   return d[0];

- }

- 

- function y$4(d) {

-   return d[1];

- }

- 

- function RedBlackTree() {

-   this._ = null; // root node

- }

- 

- function RedBlackNode(node) {

-   node.U = // parent node

-   node.C = // color - true for red, false for black

-   node.L = // left node

-   node.R = // right node

-   node.P = // previous node

-   node.N = null; // next node

- }

- 

- RedBlackTree.prototype = {

-   constructor: RedBlackTree,

- 

-   insert: function(after, node) {

-     var parent, grandpa, uncle;

- 

-     if (after) {

-       node.P = after;

-       node.N = after.N;

-       if (after.N) after.N.P = node;

-       after.N = node;

-       if (after.R) {

-         after = after.R;

-         while (after.L) after = after.L;

-         after.L = node;

-       } else {

-         after.R = node;

-       }

-       parent = after;

-     } else if (this._) {

-       after = RedBlackFirst(this._);

-       node.P = null;

-       node.N = after;

-       after.P = after.L = node;

-       parent = after;

-     } else {

-       node.P = node.N = null;

-       this._ = node;

-       parent = null;

-     }

-     node.L = node.R = null;

-     node.U = parent;

-     node.C = true;

- 

-     after = node;

-     while (parent && parent.C) {

-       grandpa = parent.U;

-       if (parent === grandpa.L) {

-         uncle = grandpa.R;

-         if (uncle && uncle.C) {

-           parent.C = uncle.C = false;

-           grandpa.C = true;

-           after = grandpa;

-         } else {

-           if (after === parent.R) {

-             RedBlackRotateLeft(this, parent);

-             after = parent;

-             parent = after.U;

-           }

-           parent.C = false;

-           grandpa.C = true;

-           RedBlackRotateRight(this, grandpa);

-         }

-       } else {

-         uncle = grandpa.L;

-         if (uncle && uncle.C) {

-           parent.C = uncle.C = false;

-           grandpa.C = true;

-           after = grandpa;

-         } else {

-           if (after === parent.L) {

-             RedBlackRotateRight(this, parent);

-             after = parent;

-             parent = after.U;

-           }

-           parent.C = false;

-           grandpa.C = true;

-           RedBlackRotateLeft(this, grandpa);

-         }

-       }

-       parent = after.U;

-     }

-     this._.C = false;

-   },

- 

-   remove: function(node) {

-     if (node.N) node.N.P = node.P;

-     if (node.P) node.P.N = node.N;

-     node.N = node.P = null;

- 

-     var parent = node.U,

-         sibling,

-         left = node.L,

-         right = node.R,

-         next,

-         red;

- 

-     if (!left) next = right;

-     else if (!right) next = left;

-     else next = RedBlackFirst(right);

- 

-     if (parent) {

-       if (parent.L === node) parent.L = next;

-       else parent.R = next;

-     } else {

-       this._ = next;

-     }

- 

-     if (left && right) {

-       red = next.C;

-       next.C = node.C;

-       next.L = left;

-       left.U = next;

-       if (next !== right) {

-         parent = next.U;

-         next.U = node.U;

-         node = next.R;

-         parent.L = node;

-         next.R = right;

-         right.U = next;

-       } else {

-         next.U = parent;

-         parent = next;

-         node = next.R;

-       }

-     } else {

-       red = node.C;

-       node = next;

-     }

- 

-     if (node) node.U = parent;

-     if (red) return;

-     if (node && node.C) { node.C = false; return; }

- 

-     do {

-       if (node === this._) break;

-       if (node === parent.L) {

-         sibling = parent.R;

-         if (sibling.C) {

-           sibling.C = false;

-           parent.C = true;

-           RedBlackRotateLeft(this, parent);

-           sibling = parent.R;

-         }

-         if ((sibling.L && sibling.L.C)

-             || (sibling.R && sibling.R.C)) {

-           if (!sibling.R || !sibling.R.C) {

-             sibling.L.C = false;

-             sibling.C = true;

-             RedBlackRotateRight(this, sibling);

-             sibling = parent.R;

-           }

-           sibling.C = parent.C;

-           parent.C = sibling.R.C = false;

-           RedBlackRotateLeft(this, parent);

-           node = this._;

-           break;

-         }

-       } else {

-         sibling = parent.L;

-         if (sibling.C) {

-           sibling.C = false;

-           parent.C = true;

-           RedBlackRotateRight(this, parent);

-           sibling = parent.L;

-         }

-         if ((sibling.L && sibling.L.C)

-           || (sibling.R && sibling.R.C)) {

-           if (!sibling.L || !sibling.L.C) {

-             sibling.R.C = false;

-             sibling.C = true;

-             RedBlackRotateLeft(this, sibling);

-             sibling = parent.L;

-           }

-           sibling.C = parent.C;

-           parent.C = sibling.L.C = false;

-           RedBlackRotateRight(this, parent);

-           node = this._;

-           break;

-         }

-       }

-       sibling.C = true;

-       node = parent;

-       parent = parent.U;

-     } while (!node.C);

- 

-     if (node) node.C = false;

-   }

- };

- 

- function RedBlackRotateLeft(tree, node) {

-   var p = node,

-       q = node.R,

-       parent = p.U;

- 

-   if (parent) {

-     if (parent.L === p) parent.L = q;

-     else parent.R = q;

-   } else {

-     tree._ = q;

-   }

- 

-   q.U = parent;

-   p.U = q;

-   p.R = q.L;

-   if (p.R) p.R.U = p;

-   q.L = p;

- }

- 

- function RedBlackRotateRight(tree, node) {

-   var p = node,

-       q = node.L,

-       parent = p.U;

- 

-   if (parent) {

-     if (parent.L === p) parent.L = q;

-     else parent.R = q;

-   } else {

-     tree._ = q;

-   }

- 

-   q.U = parent;

-   p.U = q;

-   p.L = q.R;

-   if (p.L) p.L.U = p;

-   q.R = p;

- }

- 

- function RedBlackFirst(node) {

-   while (node.L) node = node.L;

-   return node;

- }

- 

- function createEdge(left, right, v0, v1) {

-   var edge = [null, null],

-       index = edges.push(edge) - 1;

-   edge.left = left;

-   edge.right = right;

-   if (v0) setEdgeEnd(edge, left, right, v0);

-   if (v1) setEdgeEnd(edge, right, left, v1);

-   cells[left.index].halfedges.push(index);

-   cells[right.index].halfedges.push(index);

-   return edge;

- }

- 

- function createBorderEdge(left, v0, v1) {

-   var edge = [v0, v1];

-   edge.left = left;

-   return edge;

- }

- 

- function setEdgeEnd(edge, left, right, vertex) {

-   if (!edge[0] && !edge[1]) {

-     edge[0] = vertex;

-     edge.left = left;

-     edge.right = right;

-   } else if (edge.left === right) {

-     edge[1] = vertex;

-   } else {

-     edge[0] = vertex;

-   }

- }

- 

- // Liang–Barsky line clipping.

- function clipEdge(edge, x0, y0, x1, y1) {

-   var a = edge[0],

-       b = edge[1],

-       ax = a[0],

-       ay = a[1],

-       bx = b[0],

-       by = b[1],

-       t0 = 0,

-       t1 = 1,

-       dx = bx - ax,

-       dy = by - ay,

-       r;

- 

-   r = x0 - ax;

-   if (!dx && r > 0) return;

-   r /= dx;

-   if (dx < 0) {

-     if (r < t0) return;

-     if (r < t1) t1 = r;

-   } else if (dx > 0) {

-     if (r > t1) return;

-     if (r > t0) t0 = r;

-   }

- 

-   r = x1 - ax;

-   if (!dx && r < 0) return;

-   r /= dx;

-   if (dx < 0) {

-     if (r > t1) return;

-     if (r > t0) t0 = r;

-   } else if (dx > 0) {

-     if (r < t0) return;

-     if (r < t1) t1 = r;

-   }

- 

-   r = y0 - ay;

-   if (!dy && r > 0) return;

-   r /= dy;

-   if (dy < 0) {

-     if (r < t0) return;

-     if (r < t1) t1 = r;

-   } else if (dy > 0) {

-     if (r > t1) return;

-     if (r > t0) t0 = r;

-   }

- 

-   r = y1 - ay;

-   if (!dy && r < 0) return;

-   r /= dy;

-   if (dy < 0) {

-     if (r > t1) return;

-     if (r > t0) t0 = r;

-   } else if (dy > 0) {

-     if (r < t0) return;

-     if (r < t1) t1 = r;

-   }

- 

-   if (!(t0 > 0) && !(t1 < 1)) return true; // TODO Better check?

- 

-   if (t0 > 0) edge[0] = [ax + t0 * dx, ay + t0 * dy];

-   if (t1 < 1) edge[1] = [ax + t1 * dx, ay + t1 * dy];

-   return true;

- }

- 

- function connectEdge(edge, x0, y0, x1, y1) {

-   var v1 = edge[1];

-   if (v1) return true;

- 

-   var v0 = edge[0],

-       left = edge.left,

-       right = edge.right,

-       lx = left[0],

-       ly = left[1],

-       rx = right[0],

-       ry = right[1],

-       fx = (lx + rx) / 2,

-       fy = (ly + ry) / 2,

-       fm,

-       fb;

- 

-   if (ry === ly) {

-     if (fx < x0 || fx >= x1) return;

-     if (lx > rx) {

-       if (!v0) v0 = [fx, y0];

-       else if (v0[1] >= y1) return;

-       v1 = [fx, y1];

-     } else {

-       if (!v0) v0 = [fx, y1];

-       else if (v0[1] < y0) return;

-       v1 = [fx, y0];

-     }

-   } else {

-     fm = (lx - rx) / (ry - ly);

-     fb = fy - fm * fx;

-     if (fm < -1 || fm > 1) {

-       if (lx > rx) {

-         if (!v0) v0 = [(y0 - fb) / fm, y0];

-         else if (v0[1] >= y1) return;

-         v1 = [(y1 - fb) / fm, y1];

-       } else {

-         if (!v0) v0 = [(y1 - fb) / fm, y1];

-         else if (v0[1] < y0) return;

-         v1 = [(y0 - fb) / fm, y0];

-       }

-     } else {

-       if (ly < ry) {

-         if (!v0) v0 = [x0, fm * x0 + fb];

-         else if (v0[0] >= x1) return;

-         v1 = [x1, fm * x1 + fb];

-       } else {

-         if (!v0) v0 = [x1, fm * x1 + fb];

-         else if (v0[0] < x0) return;

-         v1 = [x0, fm * x0 + fb];

-       }

-     }

-   }

- 

-   edge[0] = v0;

-   edge[1] = v1;

-   return true;

- }

- 

- function clipEdges(x0, y0, x1, y1) {

-   var i = edges.length,

-       edge;

- 

-   while (i--) {

-     if (!connectEdge(edge = edges[i], x0, y0, x1, y1)

-         || !clipEdge(edge, x0, y0, x1, y1)

-         || !(Math.abs(edge[0][0] - edge[1][0]) > epsilon$4

-             || Math.abs(edge[0][1] - edge[1][1]) > epsilon$4)) {

-       delete edges[i];

-     }

-   }

- }

- 

- function createCell(site) {

-   return cells[site.index] = {

-     site: site,

-     halfedges: []

-   };

- }

- 

- function cellHalfedgeAngle(cell, edge) {

-   var site = cell.site,

-       va = edge.left,

-       vb = edge.right;

-   if (site === vb) vb = va, va = site;

-   if (vb) return Math.atan2(vb[1] - va[1], vb[0] - va[0]);

-   if (site === va) va = edge[1], vb = edge[0];

-   else va = edge[0], vb = edge[1];

-   return Math.atan2(va[0] - vb[0], vb[1] - va[1]);

- }

- 

- function cellHalfedgeStart(cell, edge) {

-   return edge[+(edge.left !== cell.site)];

- }

- 

- function cellHalfedgeEnd(cell, edge) {

-   return edge[+(edge.left === cell.site)];

- }

- 

- function sortCellHalfedges() {

-   for (var i = 0, n = cells.length, cell, halfedges, j, m; i < n; ++i) {

-     if ((cell = cells[i]) && (m = (halfedges = cell.halfedges).length)) {

-       var index = new Array(m),

-           array = new Array(m);

-       for (j = 0; j < m; ++j) index[j] = j, array[j] = cellHalfedgeAngle(cell, edges[halfedges[j]]);

-       index.sort(function(i, j) { return array[j] - array[i]; });

-       for (j = 0; j < m; ++j) array[j] = halfedges[index[j]];

-       for (j = 0; j < m; ++j) halfedges[j] = array[j];

-     }

-   }

- }

- 

- function clipCells(x0, y0, x1, y1) {

-   var nCells = cells.length,

-       iCell,

-       cell,

-       site,

-       iHalfedge,

-       halfedges,

-       nHalfedges,

-       start,

-       startX,

-       startY,

-       end,

-       endX,

-       endY,

-       cover = true;

- 

-   for (iCell = 0; iCell < nCells; ++iCell) {

-     if (cell = cells[iCell]) {

-       site = cell.site;

-       halfedges = cell.halfedges;

-       iHalfedge = halfedges.length;

- 

-       // Remove any dangling clipped edges.

-       while (iHalfedge--) {

-         if (!edges[halfedges[iHalfedge]]) {

-           halfedges.splice(iHalfedge, 1);

-         }

-       }

- 

-       // Insert any border edges as necessary.

-       iHalfedge = 0, nHalfedges = halfedges.length;

-       while (iHalfedge < nHalfedges) {

-         end = cellHalfedgeEnd(cell, edges[halfedges[iHalfedge]]), endX = end[0], endY = end[1];

-         start = cellHalfedgeStart(cell, edges[halfedges[++iHalfedge % nHalfedges]]), startX = start[0], startY = start[1];

-         if (Math.abs(endX - startX) > epsilon$4 || Math.abs(endY - startY) > epsilon$4) {

-           halfedges.splice(iHalfedge, 0, edges.push(createBorderEdge(site, end,

-               Math.abs(endX - x0) < epsilon$4 && y1 - endY > epsilon$4 ? [x0, Math.abs(startX - x0) < epsilon$4 ? startY : y1]

-               : Math.abs(endY - y1) < epsilon$4 && x1 - endX > epsilon$4 ? [Math.abs(startY - y1) < epsilon$4 ? startX : x1, y1]

-               : Math.abs(endX - x1) < epsilon$4 && endY - y0 > epsilon$4 ? [x1, Math.abs(startX - x1) < epsilon$4 ? startY : y0]

-               : Math.abs(endY - y0) < epsilon$4 && endX - x0 > epsilon$4 ? [Math.abs(startY - y0) < epsilon$4 ? startX : x0, y0]

-               : null)) - 1);

-           ++nHalfedges;

-         }

-       }

- 

-       if (nHalfedges) cover = false;

-     }

-   }

- 

-   // If there weren’t any edges, have the closest site cover the extent.

-   // It doesn’t matter which corner of the extent we measure!

-   if (cover) {

-     var dx, dy, d2, dc = Infinity;

- 

-     for (iCell = 0, cover = null; iCell < nCells; ++iCell) {

-       if (cell = cells[iCell]) {

-         site = cell.site;

-         dx = site[0] - x0;

-         dy = site[1] - y0;

-         d2 = dx * dx + dy * dy;

-         if (d2 < dc) dc = d2, cover = cell;

-       }

-     }

- 

-     if (cover) {

-       var v00 = [x0, y0], v01 = [x0, y1], v11 = [x1, y1], v10 = [x1, y0];

-       cover.halfedges.push(

-         edges.push(createBorderEdge(site = cover.site, v00, v01)) - 1,

-         edges.push(createBorderEdge(site, v01, v11)) - 1,

-         edges.push(createBorderEdge(site, v11, v10)) - 1,

-         edges.push(createBorderEdge(site, v10, v00)) - 1

-       );

-     }

-   }

- 

-   // Lastly delete any cells with no edges; these were entirely clipped.

-   for (iCell = 0; iCell < nCells; ++iCell) {

-     if (cell = cells[iCell]) {

-       if (!cell.halfedges.length) {

-         delete cells[iCell];

-       }

-     }

-   }

- }

- 

- var circlePool = [];

- 

- var firstCircle;

- 

- function Circle() {

-   RedBlackNode(this);

-   this.x =

-   this.y =

-   this.arc =

-   this.site =

-   this.cy = null;

- }

- 

- function attachCircle(arc) {

-   var lArc = arc.P,

-       rArc = arc.N;

- 

-   if (!lArc || !rArc) return;

- 

-   var lSite = lArc.site,

-       cSite = arc.site,

-       rSite = rArc.site;

- 

-   if (lSite === rSite) return;

- 

-   var bx = cSite[0],

-       by = cSite[1],

-       ax = lSite[0] - bx,

-       ay = lSite[1] - by,

-       cx = rSite[0] - bx,

-       cy = rSite[1] - by;

- 

-   var d = 2 * (ax * cy - ay * cx);

-   if (d >= -epsilon2$2) return;

- 

-   var ha = ax * ax + ay * ay,

-       hc = cx * cx + cy * cy,

-       x = (cy * ha - ay * hc) / d,

-       y = (ax * hc - cx * ha) / d;

- 

-   var circle = circlePool.pop() || new Circle;

-   circle.arc = arc;

-   circle.site = cSite;

-   circle.x = x + bx;

-   circle.y = (circle.cy = y + by) + Math.sqrt(x * x + y * y); // y bottom

- 

-   arc.circle = circle;

- 

-   var before = null,

-       node = circles._;

- 

-   while (node) {

-     if (circle.y < node.y || (circle.y === node.y && circle.x <= node.x)) {

-       if (node.L) node = node.L;

-       else { before = node.P; break; }

-     } else {

-       if (node.R) node = node.R;

-       else { before = node; break; }

-     }

-   }

- 

-   circles.insert(before, circle);

-   if (!before) firstCircle = circle;

- }

- 

- function detachCircle(arc) {

-   var circle = arc.circle;

-   if (circle) {

-     if (!circle.P) firstCircle = circle.N;

-     circles.remove(circle);

-     circlePool.push(circle);

-     RedBlackNode(circle);

-     arc.circle = null;

-   }

- }

- 

- var beachPool = [];

- 

- function Beach() {

-   RedBlackNode(this);

-   this.edge =

-   this.site =

-   this.circle = null;

- }

- 

- function createBeach(site) {

-   var beach = beachPool.pop() || new Beach;

-   beach.site = site;

-   return beach;

- }

- 

- function detachBeach(beach) {

-   detachCircle(beach);

-   beaches.remove(beach);

-   beachPool.push(beach);

-   RedBlackNode(beach);

- }

- 

- function removeBeach(beach) {

-   var circle = beach.circle,

-       x = circle.x,

-       y = circle.cy,

-       vertex = [x, y],

-       previous = beach.P,

-       next = beach.N,

-       disappearing = [beach];

- 

-   detachBeach(beach);

- 

-   var lArc = previous;

-   while (lArc.circle

-       && Math.abs(x - lArc.circle.x) < epsilon$4

-       && Math.abs(y - lArc.circle.cy) < epsilon$4) {

-     previous = lArc.P;

-     disappearing.unshift(lArc);

-     detachBeach(lArc);

-     lArc = previous;

-   }

- 

-   disappearing.unshift(lArc);

-   detachCircle(lArc);

- 

-   var rArc = next;

-   while (rArc.circle

-       && Math.abs(x - rArc.circle.x) < epsilon$4

-       && Math.abs(y - rArc.circle.cy) < epsilon$4) {

-     next = rArc.N;

-     disappearing.push(rArc);

-     detachBeach(rArc);

-     rArc = next;

-   }

- 

-   disappearing.push(rArc);

-   detachCircle(rArc);

- 

-   var nArcs = disappearing.length,

-       iArc;

-   for (iArc = 1; iArc < nArcs; ++iArc) {

-     rArc = disappearing[iArc];

-     lArc = disappearing[iArc - 1];

-     setEdgeEnd(rArc.edge, lArc.site, rArc.site, vertex);

-   }

- 

-   lArc = disappearing[0];

-   rArc = disappearing[nArcs - 1];

-   rArc.edge = createEdge(lArc.site, rArc.site, null, vertex);

- 

-   attachCircle(lArc);

-   attachCircle(rArc);

- }

- 

- function addBeach(site) {

-   var x = site[0],

-       directrix = site[1],

-       lArc,

-       rArc,

-       dxl,

-       dxr,

-       node = beaches._;

- 

-   while (node) {

-     dxl = leftBreakPoint(node, directrix) - x;

-     if (dxl > epsilon$4) node = node.L; else {

-       dxr = x - rightBreakPoint(node, directrix);

-       if (dxr > epsilon$4) {

-         if (!node.R) {

-           lArc = node;

-           break;

-         }

-         node = node.R;

-       } else {

-         if (dxl > -epsilon$4) {

-           lArc = node.P;

-           rArc = node;

-         } else if (dxr > -epsilon$4) {

-           lArc = node;

-           rArc = node.N;

-         } else {

-           lArc = rArc = node;

-         }

-         break;

-       }

-     }

-   }

- 

-   createCell(site);

-   var newArc = createBeach(site);

-   beaches.insert(lArc, newArc);

- 

-   if (!lArc && !rArc) return;

- 

-   if (lArc === rArc) {

-     detachCircle(lArc);

-     rArc = createBeach(lArc.site);

-     beaches.insert(newArc, rArc);

-     newArc.edge = rArc.edge = createEdge(lArc.site, newArc.site);

-     attachCircle(lArc);

-     attachCircle(rArc);

-     return;

-   }

- 

-   if (!rArc) { // && lArc

-     newArc.edge = createEdge(lArc.site, newArc.site);

-     return;

-   }

- 

-   // else lArc !== rArc

-   detachCircle(lArc);

-   detachCircle(rArc);

- 

-   var lSite = lArc.site,

-       ax = lSite[0],

-       ay = lSite[1],

-       bx = site[0] - ax,

-       by = site[1] - ay,

-       rSite = rArc.site,

-       cx = rSite[0] - ax,

-       cy = rSite[1] - ay,

-       d = 2 * (bx * cy - by * cx),

-       hb = bx * bx + by * by,

-       hc = cx * cx + cy * cy,

-       vertex = [(cy * hb - by * hc) / d + ax, (bx * hc - cx * hb) / d + ay];

- 

-   setEdgeEnd(rArc.edge, lSite, rSite, vertex);

-   newArc.edge = createEdge(lSite, site, null, vertex);

-   rArc.edge = createEdge(site, rSite, null, vertex);

-   attachCircle(lArc);

-   attachCircle(rArc);

- }

- 

- function leftBreakPoint(arc, directrix) {

-   var site = arc.site,

-       rfocx = site[0],

-       rfocy = site[1],

-       pby2 = rfocy - directrix;

- 

-   if (!pby2) return rfocx;

- 

-   var lArc = arc.P;

-   if (!lArc) return -Infinity;

- 

-   site = lArc.site;

-   var lfocx = site[0],

-       lfocy = site[1],

-       plby2 = lfocy - directrix;

- 

-   if (!plby2) return lfocx;

- 

-   var hl = lfocx - rfocx,

-       aby2 = 1 / pby2 - 1 / plby2,

-       b = hl / plby2;

- 

-   if (aby2) return (-b + Math.sqrt(b * b - 2 * aby2 * (hl * hl / (-2 * plby2) - lfocy + plby2 / 2 + rfocy - pby2 / 2))) / aby2 + rfocx;

- 

-   return (rfocx + lfocx) / 2;

- }

- 

- function rightBreakPoint(arc, directrix) {

-   var rArc = arc.N;

-   if (rArc) return leftBreakPoint(rArc, directrix);

-   var site = arc.site;

-   return site[1] === directrix ? site[0] : Infinity;

- }

- 

- var epsilon$4 = 1e-6;

- var epsilon2$2 = 1e-12;

- var beaches;

- var cells;

- var circles;

- var edges;

- 

- function triangleArea(a, b, c) {

-   return (a[0] - c[0]) * (b[1] - a[1]) - (a[0] - b[0]) * (c[1] - a[1]);

- }

- 

- function lexicographic(a, b) {

-   return b[1] - a[1]

-       || b[0] - a[0];

- }

- 

- function Diagram(sites, extent) {

-   var site = sites.sort(lexicographic).pop(),

-       x,

-       y,

-       circle;

- 

-   edges = [];

-   cells = new Array(sites.length);

-   beaches = new RedBlackTree;

-   circles = new RedBlackTree;

- 

-   while (true) {

-     circle = firstCircle;

-     if (site && (!circle || site[1] < circle.y || (site[1] === circle.y && site[0] < circle.x))) {

-       if (site[0] !== x || site[1] !== y) {

-         addBeach(site);

-         x = site[0], y = site[1];

-       }

-       site = sites.pop();

-     } else if (circle) {

-       removeBeach(circle.arc);

-     } else {

-       break;

-     }

-   }

- 

-   sortCellHalfedges();

- 

-   if (extent) {

-     var x0 = +extent[0][0],

-         y0 = +extent[0][1],

-         x1 = +extent[1][0],

-         y1 = +extent[1][1];

-     clipEdges(x0, y0, x1, y1);

-     clipCells(x0, y0, x1, y1);

-   }

- 

-   this.edges = edges;

-   this.cells = cells;

- 

-   beaches =

-   circles =

-   edges =

-   cells = null;

- }

- 

- Diagram.prototype = {

-   constructor: Diagram,

- 

-   polygons: function() {

-     var edges = this.edges;

- 

-     return this.cells.map(function(cell) {

-       var polygon = cell.halfedges.map(function(i) { return cellHalfedgeStart(cell, edges[i]); });

-       polygon.data = cell.site.data;

-       return polygon;

-     });

-   },

- 

-   triangles: function() {

-     var triangles = [],

-         edges = this.edges;

- 

-     this.cells.forEach(function(cell, i) {

-       if (!(m = (halfedges = cell.halfedges).length)) return;

-       var site = cell.site,

-           halfedges,

-           j = -1,

-           m,

-           s0,

-           e1 = edges[halfedges[m - 1]],

-           s1 = e1.left === site ? e1.right : e1.left;

- 

-       while (++j < m) {

-         s0 = s1;

-         e1 = edges[halfedges[j]];

-         s1 = e1.left === site ? e1.right : e1.left;

-         if (s0 && s1 && i < s0.index && i < s1.index && triangleArea(site, s0, s1) < 0) {

-           triangles.push([site.data, s0.data, s1.data]);

-         }

-       }

-     });

- 

-     return triangles;

-   },

- 

-   links: function() {

-     return this.edges.filter(function(edge) {

-       return edge.right;

-     }).map(function(edge) {

-       return {

-         source: edge.left.data,

-         target: edge.right.data

-       };

-     });

-   },

- 

-   find: function(x, y, radius) {

-     var that = this, i0, i1 = that._found || 0, n = that.cells.length, cell;

- 

-     // Use the previously-found cell, or start with an arbitrary one.

-     while (!(cell = that.cells[i1])) if (++i1 >= n) return null;

-     var dx = x - cell.site[0], dy = y - cell.site[1], d2 = dx * dx + dy * dy;

- 

-     // Traverse the half-edges to find a closer cell, if any.

-     do {

-       cell = that.cells[i0 = i1], i1 = null;

-       cell.halfedges.forEach(function(e) {

-         var edge = that.edges[e], v = edge.left;

-         if ((v === cell.site || !v) && !(v = edge.right)) return;

-         var vx = x - v[0], vy = y - v[1], v2 = vx * vx + vy * vy;

-         if (v2 < d2) d2 = v2, i1 = v.index;

-       });

-     } while (i1 !== null);

- 

-     that._found = i0;

- 

-     return radius == null || d2 <= radius * radius ? cell.site : null;

-   }

- };

- 

- var voronoi = function() {

-   var x$$1 = x$4,

-       y$$1 = y$4,

-       extent = null;

- 

-   function voronoi(data) {

-     return new Diagram(data.map(function(d, i) {

-       var s = [Math.round(x$$1(d, i, data) / epsilon$4) * epsilon$4, Math.round(y$$1(d, i, data) / epsilon$4) * epsilon$4];

-       s.index = i;

-       s.data = d;

-       return s;

-     }), extent);

-   }

- 

-   voronoi.polygons = function(data) {

-     return voronoi(data).polygons();

-   };

- 

-   voronoi.links = function(data) {

-     return voronoi(data).links();

-   };

- 

-   voronoi.triangles = function(data) {

-     return voronoi(data).triangles();

-   };

- 

-   voronoi.x = function(_) {

-     return arguments.length ? (x$$1 = typeof _ === "function" ? _ : constant$11(+_), voronoi) : x$$1;

-   };

- 

-   voronoi.y = function(_) {

-     return arguments.length ? (y$$1 = typeof _ === "function" ? _ : constant$11(+_), voronoi) : y$$1;

-   };

- 

-   voronoi.extent = function(_) {

-     return arguments.length ? (extent = _ == null ? null : [[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]], voronoi) : extent && [[extent[0][0], extent[0][1]], [extent[1][0], extent[1][1]]];

-   };

- 

-   voronoi.size = function(_) {

-     return arguments.length ? (extent = _ == null ? null : [[0, 0], [+_[0], +_[1]]], voronoi) : extent && [extent[1][0] - extent[0][0], extent[1][1] - extent[0][1]];

-   };

- 

-   return voronoi;

- };

- 

- var constant$12 = function(x) {

-   return function() {

-     return x;

-   };

- };

- 

- function ZoomEvent(target, type, transform) {

-   this.target = target;

-   this.type = type;

-   this.transform = transform;

- }

- 

- function Transform(k, x, y) {

-   this.k = k;

-   this.x = x;

-   this.y = y;

- }

- 

- Transform.prototype = {

-   constructor: Transform,

-   scale: function(k) {

-     return k === 1 ? this : new Transform(this.k * k, this.x, this.y);

-   },

-   translate: function(x, y) {

-     return x === 0 & y === 0 ? this : new Transform(this.k, this.x + this.k * x, this.y + this.k * y);

-   },

-   apply: function(point) {

-     return [point[0] * this.k + this.x, point[1] * this.k + this.y];

-   },

-   applyX: function(x) {

-     return x * this.k + this.x;

-   },

-   applyY: function(y) {

-     return y * this.k + this.y;

-   },

-   invert: function(location) {

-     return [(location[0] - this.x) / this.k, (location[1] - this.y) / this.k];

-   },

-   invertX: function(x) {

-     return (x - this.x) / this.k;

-   },

-   invertY: function(y) {

-     return (y - this.y) / this.k;

-   },

-   rescaleX: function(x) {

-     return x.copy().domain(x.range().map(this.invertX, this).map(x.invert, x));

-   },

-   rescaleY: function(y) {

-     return y.copy().domain(y.range().map(this.invertY, this).map(y.invert, y));

-   },

-   toString: function() {

-     return "translate(" + this.x + "," + this.y + ") scale(" + this.k + ")";

-   }

- };

- 

- var identity$8 = new Transform(1, 0, 0);

- 

- transform$1.prototype = Transform.prototype;

- 

- function transform$1(node) {

-   return node.__zoom || identity$8;

- }

- 

- function nopropagation$2() {

-   exports.event.stopImmediatePropagation();

- }

- 

- var noevent$2 = function() {

-   exports.event.preventDefault();

-   exports.event.stopImmediatePropagation();

- };

- 

- // Ignore right-click, since that should open the context menu.

- function defaultFilter$2() {

-   return !exports.event.button;

- }

- 

- function defaultExtent$1() {

-   var e = this, w, h;

-   if (e instanceof SVGElement) {

-     e = e.ownerSVGElement || e;

-     w = e.width.baseVal.value;

-     h = e.height.baseVal.value;

-   } else {

-     w = e.clientWidth;

-     h = e.clientHeight;

-   }

-   return [[0, 0], [w, h]];

- }

- 

- function defaultTransform() {

-   return this.__zoom || identity$8;

- }

- 

- function defaultWheelDelta() {

-   return -exports.event.deltaY * (exports.event.deltaMode ? 120 : 1) / 500;

- }

- 

- function defaultTouchable$1() {

-   return "ontouchstart" in this;

- }

- 

- var zoom = function() {

-   var filter = defaultFilter$2,

-       extent = defaultExtent$1,

-       wheelDelta = defaultWheelDelta,

-       touchable = defaultTouchable$1,

-       k0 = 0,

-       k1 = Infinity,

-       x0 = -k1,

-       x1 = k1,

-       y0 = x0,

-       y1 = x1,

-       duration = 250,

-       interpolate = interpolateZoom,

-       gestures = [],

-       listeners = dispatch("start", "zoom", "end"),

-       touchstarting,

-       touchending,

-       touchDelay = 500,

-       wheelDelay = 150,

-       clickDistance2 = 0;

- 

-   function zoom(selection) {

-     selection

-         .property("__zoom", defaultTransform)

-         .on("wheel.zoom", wheeled)

-         .on("mousedown.zoom", mousedowned)

-         .on("dblclick.zoom", dblclicked)

-       .filter(touchable)

-         .on("touchstart.zoom", touchstarted)

-         .on("touchmove.zoom", touchmoved)

-         .on("touchend.zoom touchcancel.zoom", touchended)

-         .style("touch-action", "none")

-         .style("-webkit-tap-highlight-color", "rgba(0,0,0,0)");

-   }

- 

-   zoom.transform = function(collection, transform$$1) {

-     var selection = collection.selection ? collection.selection() : collection;

-     selection.property("__zoom", defaultTransform);

-     if (collection !== selection) {

-       schedule(collection, transform$$1);

-     } else {

-       selection.interrupt().each(function() {

-         gesture(this, arguments)

-             .start()

-             .zoom(null, typeof transform$$1 === "function" ? transform$$1.apply(this, arguments) : transform$$1)

-             .end();

-       });

-     }

-   };

- 

-   zoom.scaleBy = function(selection, k) {

-     zoom.scaleTo(selection, function() {

-       var k0 = this.__zoom.k,

-           k1 = typeof k === "function" ? k.apply(this, arguments) : k;

-       return k0 * k1;

-     });

-   };

- 

-   zoom.scaleTo = function(selection, k) {

-     zoom.transform(selection, function() {

-       var e = extent.apply(this, arguments),

-           t0 = this.__zoom,

-           p0 = centroid(e),

-           p1 = t0.invert(p0),

-           k1 = typeof k === "function" ? k.apply(this, arguments) : k;

-       return constrain(translate(scale(t0, k1), p0, p1), e);

-     });

-   };

- 

-   zoom.translateBy = function(selection, x, y) {

-     zoom.transform(selection, function() {

-       return constrain(this.__zoom.translate(

-         typeof x === "function" ? x.apply(this, arguments) : x,

-         typeof y === "function" ? y.apply(this, arguments) : y

-       ), extent.apply(this, arguments));

-     });

-   };

- 

-   zoom.translateTo = function(selection, x, y) {

-     zoom.transform(selection, function() {

-       var e = extent.apply(this, arguments),

-           t = this.__zoom,

-           p = centroid(e);

-       return constrain(identity$8.translate(p[0], p[1]).scale(t.k).translate(

-         typeof x === "function" ? -x.apply(this, arguments) : -x,

-         typeof y === "function" ? -y.apply(this, arguments) : -y

-       ), e);

-     });

-   };

- 

-   function scale(transform$$1, k) {

-     k = Math.max(k0, Math.min(k1, k));

-     return k === transform$$1.k ? transform$$1 : new Transform(k, transform$$1.x, transform$$1.y);

-   }

- 

-   function translate(transform$$1, p0, p1) {

-     var x = p0[0] - p1[0] * transform$$1.k, y = p0[1] - p1[1] * transform$$1.k;

-     return x === transform$$1.x && y === transform$$1.y ? transform$$1 : new Transform(transform$$1.k, x, y);

-   }

- 

-   function constrain(transform$$1, extent) {

-     var dx0 = transform$$1.invertX(extent[0][0]) - x0,

-         dx1 = transform$$1.invertX(extent[1][0]) - x1,

-         dy0 = transform$$1.invertY(extent[0][1]) - y0,

-         dy1 = transform$$1.invertY(extent[1][1]) - y1;

-     return transform$$1.translate(

-       dx1 > dx0 ? (dx0 + dx1) / 2 : Math.min(0, dx0) || Math.max(0, dx1),

-       dy1 > dy0 ? (dy0 + dy1) / 2 : Math.min(0, dy0) || Math.max(0, dy1)

-     );

-   }

- 

-   function centroid(extent) {

-     return [(+extent[0][0] + +extent[1][0]) / 2, (+extent[0][1] + +extent[1][1]) / 2];

-   }

- 

-   function schedule(transition, transform$$1, center) {

-     transition

-         .on("start.zoom", function() { gesture(this, arguments).start(); })

-         .on("interrupt.zoom end.zoom", function() { gesture(this, arguments).end(); })

-         .tween("zoom", function() {

-           var that = this,

-               args = arguments,

-               g = gesture(that, args),

-               e = extent.apply(that, args),

-               p = center || centroid(e),

-               w = Math.max(e[1][0] - e[0][0], e[1][1] - e[0][1]),

-               a = that.__zoom,

-               b = typeof transform$$1 === "function" ? transform$$1.apply(that, args) : transform$$1,

-               i = interpolate(a.invert(p).concat(w / a.k), b.invert(p).concat(w / b.k));

-           return function(t) {

-             if (t === 1) t = b; // Avoid rounding error on end.

-             else { var l = i(t), k = w / l[2]; t = new Transform(k, p[0] - l[0] * k, p[1] - l[1] * k); }

-             g.zoom(null, t);

-           };

-         });

-   }

- 

-   function gesture(that, args) {

-     for (var i = 0, n = gestures.length, g; i < n; ++i) {

-       if ((g = gestures[i]).that === that) {

-         return g;

-       }

-     }

-     return new Gesture(that, args);

-   }

- 

-   function Gesture(that, args) {

-     this.that = that;

-     this.args = args;

-     this.index = -1;

-     this.active = 0;

-     this.extent = extent.apply(that, args);

-   }

- 

-   Gesture.prototype = {

-     start: function() {

-       if (++this.active === 1) {

-         this.index = gestures.push(this) - 1;

-         this.emit("start");

-       }

-       return this;

-     },

-     zoom: function(key, transform$$1) {

-       if (this.mouse && key !== "mouse") this.mouse[1] = transform$$1.invert(this.mouse[0]);

-       if (this.touch0 && key !== "touch") this.touch0[1] = transform$$1.invert(this.touch0[0]);

-       if (this.touch1 && key !== "touch") this.touch1[1] = transform$$1.invert(this.touch1[0]);

-       this.that.__zoom = transform$$1;

-       this.emit("zoom");

-       return this;

-     },

-     end: function() {

-       if (--this.active === 0) {

-         gestures.splice(this.index, 1);

-         this.index = -1;

-         this.emit("end");

-       }

-       return this;

-     },

-     emit: function(type) {

-       customEvent(new ZoomEvent(zoom, type, this.that.__zoom), listeners.apply, listeners, [type, this.that, this.args]);

-     }

-   };

- 

-   function wheeled() {

-     if (!filter.apply(this, arguments)) return;

-     var g = gesture(this, arguments),

-         t = this.__zoom,

-         k = Math.max(k0, Math.min(k1, t.k * Math.pow(2, wheelDelta.apply(this, arguments)))),

-         p = mouse(this);

- 

-     // If the mouse is in the same location as before, reuse it.

-     // If there were recent wheel events, reset the wheel idle timeout.

-     if (g.wheel) {

-       if (g.mouse[0][0] !== p[0] || g.mouse[0][1] !== p[1]) {

-         g.mouse[1] = t.invert(g.mouse[0] = p);

-       }

-       clearTimeout(g.wheel);

-     }

- 

-     // If this wheel event won’t trigger a transform change, ignore it.

-     else if (t.k === k) return;

- 

-     // Otherwise, capture the mouse point and location at the start.

-     else {

-       g.mouse = [p, t.invert(p)];

-       interrupt(this);

-       g.start();

-     }

- 

-     noevent$2();

-     g.wheel = setTimeout(wheelidled, wheelDelay);

-     g.zoom("mouse", constrain(translate(scale(t, k), g.mouse[0], g.mouse[1]), g.extent));

- 

-     function wheelidled() {

-       g.wheel = null;

-       g.end();

-     }

-   }

- 

-   function mousedowned() {

-     if (touchending || !filter.apply(this, arguments)) return;

-     var g = gesture(this, arguments),

-         v = select(exports.event.view).on("mousemove.zoom", mousemoved, true).on("mouseup.zoom", mouseupped, true),

-         p = mouse(this),

-         x0 = exports.event.clientX,

-         y0 = exports.event.clientY;

- 

-     dragDisable(exports.event.view);

-     nopropagation$2();

-     g.mouse = [p, this.__zoom.invert(p)];

-     interrupt(this);

-     g.start();

- 

-     function mousemoved() {

-       noevent$2();

-       if (!g.moved) {

-         var dx = exports.event.clientX - x0, dy = exports.event.clientY - y0;

-         g.moved = dx * dx + dy * dy > clickDistance2;

-       }

-       g.zoom("mouse", constrain(translate(g.that.__zoom, g.mouse[0] = mouse(g.that), g.mouse[1]), g.extent));

-     }

- 

-     function mouseupped() {

-       v.on("mousemove.zoom mouseup.zoom", null);

-       yesdrag(exports.event.view, g.moved);

-       noevent$2();

-       g.end();

-     }

-   }

- 

-   function dblclicked() {

-     if (!filter.apply(this, arguments)) return;

-     var t0 = this.__zoom,

-         p0 = mouse(this),

-         p1 = t0.invert(p0),

-         k1 = t0.k * (exports.event.shiftKey ? 0.5 : 2),

-         t1 = constrain(translate(scale(t0, k1), p0, p1), extent.apply(this, arguments));

- 

-     noevent$2();

-     if (duration > 0) select(this).transition().duration(duration).call(schedule, t1, p0);

-     else select(this).call(zoom.transform, t1);

-   }

- 

-   function touchstarted() {

-     if (!filter.apply(this, arguments)) return;

-     var g = gesture(this, arguments),

-         touches = exports.event.changedTouches,

-         started,

-         n = touches.length, i, t, p;

- 

-     nopropagation$2();

-     for (i = 0; i < n; ++i) {

-       t = touches[i], p = touch(this, touches, t.identifier);

-       p = [p, this.__zoom.invert(p), t.identifier];

-       if (!g.touch0) g.touch0 = p, started = true;

-       else if (!g.touch1) g.touch1 = p;

-     }

- 

-     // If this is a dbltap, reroute to the (optional) dblclick.zoom handler.

-     if (touchstarting) {

-       touchstarting = clearTimeout(touchstarting);

-       if (!g.touch1) {

-         g.end();

-         p = select(this).on("dblclick.zoom");

-         if (p) p.apply(this, arguments);

-         return;

-       }

-     }

- 

-     if (started) {

-       touchstarting = setTimeout(function() { touchstarting = null; }, touchDelay);

-       interrupt(this);

-       g.start();

-     }

-   }

- 

-   function touchmoved() {

-     var g = gesture(this, arguments),

-         touches = exports.event.changedTouches,

-         n = touches.length, i, t, p, l;

- 

-     noevent$2();

-     if (touchstarting) touchstarting = clearTimeout(touchstarting);

-     for (i = 0; i < n; ++i) {

-       t = touches[i], p = touch(this, touches, t.identifier);

-       if (g.touch0 && g.touch0[2] === t.identifier) g.touch0[0] = p;

-       else if (g.touch1 && g.touch1[2] === t.identifier) g.touch1[0] = p;

-     }

-     t = g.that.__zoom;

-     if (g.touch1) {

-       var p0 = g.touch0[0], l0 = g.touch0[1],

-           p1 = g.touch1[0], l1 = g.touch1[1],

-           dp = (dp = p1[0] - p0[0]) * dp + (dp = p1[1] - p0[1]) * dp,

-           dl = (dl = l1[0] - l0[0]) * dl + (dl = l1[1] - l0[1]) * dl;

-       t = scale(t, Math.sqrt(dp / dl));

-       p = [(p0[0] + p1[0]) / 2, (p0[1] + p1[1]) / 2];

-       l = [(l0[0] + l1[0]) / 2, (l0[1] + l1[1]) / 2];

-     }

-     else if (g.touch0) p = g.touch0[0], l = g.touch0[1];

-     else return;

-     g.zoom("touch", constrain(translate(t, p, l), g.extent));

-   }

- 

-   function touchended() {

-     var g = gesture(this, arguments),

-         touches = exports.event.changedTouches,

-         n = touches.length, i, t;

- 

-     nopropagation$2();

-     if (touchending) clearTimeout(touchending);

-     touchending = setTimeout(function() { touchending = null; }, touchDelay);

-     for (i = 0; i < n; ++i) {

-       t = touches[i];

-       if (g.touch0 && g.touch0[2] === t.identifier) delete g.touch0;

-       else if (g.touch1 && g.touch1[2] === t.identifier) delete g.touch1;

-     }

-     if (g.touch1 && !g.touch0) g.touch0 = g.touch1, delete g.touch1;

-     if (g.touch0) g.touch0[1] = this.__zoom.invert(g.touch0[0]);

-     else g.end();

-   }

- 

-   zoom.wheelDelta = function(_) {

-     return arguments.length ? (wheelDelta = typeof _ === "function" ? _ : constant$12(+_), zoom) : wheelDelta;

-   };

- 

-   zoom.filter = function(_) {

-     return arguments.length ? (filter = typeof _ === "function" ? _ : constant$12(!!_), zoom) : filter;

-   };

- 

-   zoom.touchable = function(_) {

-     return arguments.length ? (touchable = typeof _ === "function" ? _ : constant$12(!!_), zoom) : touchable;

-   };

- 

-   zoom.extent = function(_) {

-     return arguments.length ? (extent = typeof _ === "function" ? _ : constant$12([[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]]), zoom) : extent;

-   };

- 

-   zoom.scaleExtent = function(_) {

-     return arguments.length ? (k0 = +_[0], k1 = +_[1], zoom) : [k0, k1];

-   };

- 

-   zoom.translateExtent = function(_) {

-     return arguments.length ? (x0 = +_[0][0], x1 = +_[1][0], y0 = +_[0][1], y1 = +_[1][1], zoom) : [[x0, y0], [x1, y1]];

-   };

- 

-   zoom.duration = function(_) {

-     return arguments.length ? (duration = +_, zoom) : duration;

-   };

- 

-   zoom.interpolate = function(_) {

-     return arguments.length ? (interpolate = _, zoom) : interpolate;

-   };

- 

-   zoom.on = function() {

-     var value = listeners.on.apply(listeners, arguments);

-     return value === listeners ? zoom : value;

-   };

- 

-   zoom.clickDistance = function(_) {

-     return arguments.length ? (clickDistance2 = (_ = +_) * _, zoom) : Math.sqrt(clickDistance2);

-   };

- 

-   return zoom;

- };

- 

- exports.version = version;

- exports.bisect = bisectRight;

- exports.bisectRight = bisectRight;

- exports.bisectLeft = bisectLeft;

- exports.ascending = ascending;

- exports.bisector = bisector;

- exports.cross = cross;

- exports.descending = descending;

- exports.deviation = deviation;

- exports.extent = extent;

- exports.histogram = histogram;

- exports.thresholdFreedmanDiaconis = freedmanDiaconis;

- exports.thresholdScott = scott;

- exports.thresholdSturges = sturges;

- exports.max = max;

- exports.mean = mean;

- exports.median = median;

- exports.merge = merge;

- exports.min = min;

- exports.pairs = pairs;

- exports.permute = permute;

- exports.quantile = threshold;

- exports.range = sequence;

- exports.scan = scan;

- exports.shuffle = shuffle;

- exports.sum = sum;

- exports.ticks = ticks;

- exports.tickIncrement = tickIncrement;

- exports.tickStep = tickStep;

- exports.transpose = transpose;

- exports.variance = variance;

- exports.zip = zip;

- exports.axisTop = axisTop;

- exports.axisRight = axisRight;

- exports.axisBottom = axisBottom;

- exports.axisLeft = axisLeft;

- exports.brush = brush;

- exports.brushX = brushX;

- exports.brushY = brushY;

- exports.brushSelection = brushSelection;

- exports.chord = chord;

- exports.ribbon = ribbon;

- exports.nest = nest;

- exports.set = set$2;

- exports.map = map$1;

- exports.keys = keys;

- exports.values = values;

- exports.entries = entries;

- exports.color = color;

- exports.rgb = rgb;

- exports.hsl = hsl;

- exports.lab = lab;

- exports.hcl = hcl;

- exports.cubehelix = cubehelix;

- exports.dispatch = dispatch;

- exports.drag = drag;

- exports.dragDisable = dragDisable;

- exports.dragEnable = yesdrag;

- exports.dsvFormat = dsv;

- exports.csvParse = csvParse;

- exports.csvParseRows = csvParseRows;

- exports.csvFormat = csvFormat;

- exports.csvFormatRows = csvFormatRows;

- exports.tsvParse = tsvParse;

- exports.tsvParseRows = tsvParseRows;

- exports.tsvFormat = tsvFormat;

- exports.tsvFormatRows = tsvFormatRows;

- exports.easeLinear = linear$1;

- exports.easeQuad = quadInOut;

- exports.easeQuadIn = quadIn;

- exports.easeQuadOut = quadOut;

- exports.easeQuadInOut = quadInOut;

- exports.easeCubic = cubicInOut;

- exports.easeCubicIn = cubicIn;

- exports.easeCubicOut = cubicOut;

- exports.easeCubicInOut = cubicInOut;

- exports.easePoly = polyInOut;

- exports.easePolyIn = polyIn;

- exports.easePolyOut = polyOut;

- exports.easePolyInOut = polyInOut;

- exports.easeSin = sinInOut;

- exports.easeSinIn = sinIn;

- exports.easeSinOut = sinOut;

- exports.easeSinInOut = sinInOut;

- exports.easeExp = expInOut;

- exports.easeExpIn = expIn;

- exports.easeExpOut = expOut;

- exports.easeExpInOut = expInOut;

- exports.easeCircle = circleInOut;

- exports.easeCircleIn = circleIn;

- exports.easeCircleOut = circleOut;

- exports.easeCircleInOut = circleInOut;

- exports.easeBounce = bounceOut;

- exports.easeBounceIn = bounceIn;

- exports.easeBounceOut = bounceOut;

- exports.easeBounceInOut = bounceInOut;

- exports.easeBack = backInOut;

- exports.easeBackIn = backIn;

- exports.easeBackOut = backOut;

- exports.easeBackInOut = backInOut;

- exports.easeElastic = elasticOut;

- exports.easeElasticIn = elasticIn;

- exports.easeElasticOut = elasticOut;

- exports.easeElasticInOut = elasticInOut;

- exports.forceCenter = center$1;

- exports.forceCollide = collide;

- exports.forceLink = link;

- exports.forceManyBody = manyBody;

- exports.forceRadial = radial;

- exports.forceSimulation = simulation;

- exports.forceX = x$2;

- exports.forceY = y$2;

- exports.formatDefaultLocale = defaultLocale;

- exports.formatLocale = formatLocale;

- exports.formatSpecifier = formatSpecifier;

- exports.precisionFixed = precisionFixed;

- exports.precisionPrefix = precisionPrefix;

- exports.precisionRound = precisionRound;

- exports.geoArea = area;

- exports.geoBounds = bounds;

- exports.geoCentroid = centroid;

- exports.geoCircle = circle;

- exports.geoClipAntimeridian = clipAntimeridian;

- exports.geoClipCircle = clipCircle;

- exports.geoClipExtent = extent$1;

- exports.geoClipRectangle = clipRectangle;

- exports.geoContains = contains;

- exports.geoDistance = distance;

- exports.geoGraticule = graticule;

- exports.geoGraticule10 = graticule10;

- exports.geoInterpolate = interpolate$1;

- exports.geoLength = length$1;

- exports.geoPath = index$1;

- exports.geoAlbers = albers;

- exports.geoAlbersUsa = albersUsa;

- exports.geoAzimuthalEqualArea = azimuthalEqualArea;

- exports.geoAzimuthalEqualAreaRaw = azimuthalEqualAreaRaw;

- exports.geoAzimuthalEquidistant = azimuthalEquidistant;

- exports.geoAzimuthalEquidistantRaw = azimuthalEquidistantRaw;

- exports.geoConicConformal = conicConformal;

- exports.geoConicConformalRaw = conicConformalRaw;

- exports.geoConicEqualArea = conicEqualArea;

- exports.geoConicEqualAreaRaw = conicEqualAreaRaw;

- exports.geoConicEquidistant = conicEquidistant;

- exports.geoConicEquidistantRaw = conicEquidistantRaw;

- exports.geoEquirectangular = equirectangular;

- exports.geoEquirectangularRaw = equirectangularRaw;

- exports.geoGnomonic = gnomonic;

- exports.geoGnomonicRaw = gnomonicRaw;

- exports.geoIdentity = identity$5;

- exports.geoProjection = projection;

- exports.geoProjectionMutator = projectionMutator;

- exports.geoMercator = mercator;

- exports.geoMercatorRaw = mercatorRaw;

- exports.geoNaturalEarth1 = naturalEarth1;

- exports.geoNaturalEarth1Raw = naturalEarth1Raw;

- exports.geoOrthographic = orthographic;

- exports.geoOrthographicRaw = orthographicRaw;

- exports.geoStereographic = stereographic;

- exports.geoStereographicRaw = stereographicRaw;

- exports.geoTransverseMercator = transverseMercator;

- exports.geoTransverseMercatorRaw = transverseMercatorRaw;

- exports.geoRotation = rotation;

- exports.geoStream = geoStream;

- exports.geoTransform = transform;

- exports.cluster = cluster;

- exports.hierarchy = hierarchy;

- exports.pack = index$2;

- exports.packSiblings = siblings;

- exports.packEnclose = enclose;

- exports.partition = partition;

- exports.stratify = stratify;

- exports.tree = tree;

- exports.treemap = index$3;

- exports.treemapBinary = binary;

- exports.treemapDice = treemapDice;

- exports.treemapSlice = treemapSlice;

- exports.treemapSliceDice = sliceDice;

- exports.treemapSquarify = squarify;

- exports.treemapResquarify = resquarify;

- exports.interpolate = interpolateValue;

- exports.interpolateArray = array$1;

- exports.interpolateBasis = basis$1;

- exports.interpolateBasisClosed = basisClosed;

- exports.interpolateDate = date;

- exports.interpolateNumber = reinterpolate;

- exports.interpolateObject = object;

- exports.interpolateRound = interpolateRound;

- exports.interpolateString = interpolateString;

- exports.interpolateTransformCss = interpolateTransformCss;

- exports.interpolateTransformSvg = interpolateTransformSvg;

- exports.interpolateZoom = interpolateZoom;

- exports.interpolateRgb = interpolateRgb;

- exports.interpolateRgbBasis = rgbBasis;

- exports.interpolateRgbBasisClosed = rgbBasisClosed;

- exports.interpolateHsl = hsl$2;

- exports.interpolateHslLong = hslLong;

- exports.interpolateLab = lab$1;

- exports.interpolateHcl = hcl$2;

- exports.interpolateHclLong = hclLong;

- exports.interpolateCubehelix = cubehelix$2;

- exports.interpolateCubehelixLong = cubehelixLong;

- exports.quantize = quantize;

- exports.path = path;

- exports.polygonArea = area$1;

- exports.polygonCentroid = centroid$1;

- exports.polygonHull = hull;

- exports.polygonContains = contains$1;

- exports.polygonLength = length$2;

- exports.quadtree = quadtree;

- exports.queue = queue;

- exports.randomUniform = uniform;

- exports.randomNormal = normal;

- exports.randomLogNormal = logNormal;

- exports.randomBates = bates;

- exports.randomIrwinHall = irwinHall;

- exports.randomExponential = exponential$1;

- exports.request = request;

- exports.html = html;

- exports.json = json;

- exports.text = text;

- exports.xml = xml;

- exports.csv = csv$1;

- exports.tsv = tsv$1;

- exports.scaleBand = band;

- exports.scalePoint = point$1;

- exports.scaleIdentity = identity$6;

- exports.scaleLinear = linear$2;

- exports.scaleLog = log$1;

- exports.scaleOrdinal = ordinal;

- exports.scaleImplicit = implicit;

- exports.scalePow = pow$1;

- exports.scaleSqrt = sqrt$1;

- exports.scaleQuantile = quantile$$1;

- exports.scaleQuantize = quantize$1;

- exports.scaleThreshold = threshold$1;

- exports.scaleTime = time;

- exports.scaleUtc = utcTime;

- exports.schemeCategory10 = category10;

- exports.schemeCategory20b = category20b;

- exports.schemeCategory20c = category20c;

- exports.schemeCategory20 = category20;

- exports.interpolateCubehelixDefault = cubehelix$3;

- exports.interpolateRainbow = rainbow$1;

- exports.interpolateWarm = warm;

- exports.interpolateCool = cool;

- exports.interpolateViridis = viridis;

- exports.interpolateMagma = magma;

- exports.interpolateInferno = inferno;

- exports.interpolatePlasma = plasma;

- exports.scaleSequential = sequential;

- exports.creator = creator;

- exports.local = local$1;

- exports.matcher = matcher$1;

- exports.mouse = mouse;

- exports.namespace = namespace;

- exports.namespaces = namespaces;

- exports.select = select;

- exports.selectAll = selectAll;

- exports.selection = selection;

- exports.selector = selector;

- exports.selectorAll = selectorAll;

- exports.style = styleValue;

- exports.touch = touch;

- exports.touches = touches;

- exports.window = defaultView;

- exports.customEvent = customEvent;

- exports.arc = arc;

- exports.area = area$2;

- exports.line = line;

- exports.pie = pie;

- exports.areaRadial = areaRadial;

- exports.radialArea = areaRadial;

- exports.lineRadial = lineRadial$1;

- exports.radialLine = lineRadial$1;

- exports.pointRadial = pointRadial;

- exports.linkHorizontal = linkHorizontal;

- exports.linkVertical = linkVertical;

- exports.linkRadial = linkRadial;

- exports.symbol = symbol;

- exports.symbols = symbols;

- exports.symbolCircle = circle$2;

- exports.symbolCross = cross$2;

- exports.symbolDiamond = diamond;

- exports.symbolSquare = square;

- exports.symbolStar = star;

- exports.symbolTriangle = triangle;

- exports.symbolWye = wye;

- exports.curveBasisClosed = basisClosed$1;

- exports.curveBasisOpen = basisOpen;

- exports.curveBasis = basis$2;

- exports.curveBundle = bundle;

- exports.curveCardinalClosed = cardinalClosed;

- exports.curveCardinalOpen = cardinalOpen;

- exports.curveCardinal = cardinal;

- exports.curveCatmullRomClosed = catmullRomClosed;

- exports.curveCatmullRomOpen = catmullRomOpen;

- exports.curveCatmullRom = catmullRom;

- exports.curveLinearClosed = linearClosed;

- exports.curveLinear = curveLinear;

- exports.curveMonotoneX = monotoneX;

- exports.curveMonotoneY = monotoneY;

- exports.curveNatural = natural;

- exports.curveStep = step;

- exports.curveStepAfter = stepAfter;

- exports.curveStepBefore = stepBefore;

- exports.stack = stack;

- exports.stackOffsetExpand = expand;

- exports.stackOffsetDiverging = diverging;

- exports.stackOffsetNone = none$1;

- exports.stackOffsetSilhouette = silhouette;

- exports.stackOffsetWiggle = wiggle;

- exports.stackOrderAscending = ascending$2;

- exports.stackOrderDescending = descending$2;

- exports.stackOrderInsideOut = insideOut;

- exports.stackOrderNone = none$2;

- exports.stackOrderReverse = reverse;

- exports.timeInterval = newInterval;

- exports.timeMillisecond = millisecond;

- exports.timeMilliseconds = milliseconds;

- exports.utcMillisecond = millisecond;

- exports.utcMilliseconds = milliseconds;

- exports.timeSecond = second;

- exports.timeSeconds = seconds;

- exports.utcSecond = second;

- exports.utcSeconds = seconds;

- exports.timeMinute = minute;

- exports.timeMinutes = minutes;

- exports.timeHour = hour;

- exports.timeHours = hours;

- exports.timeDay = day;

- exports.timeDays = days;

- exports.timeWeek = sunday;

- exports.timeWeeks = sundays;

- exports.timeSunday = sunday;

- exports.timeSundays = sundays;

- exports.timeMonday = monday;

- exports.timeMondays = mondays;

- exports.timeTuesday = tuesday;

- exports.timeTuesdays = tuesdays;

- exports.timeWednesday = wednesday;

- exports.timeWednesdays = wednesdays;

- exports.timeThursday = thursday;

- exports.timeThursdays = thursdays;

- exports.timeFriday = friday;

- exports.timeFridays = fridays;

- exports.timeSaturday = saturday;

- exports.timeSaturdays = saturdays;

- exports.timeMonth = month;

- exports.timeMonths = months;

- exports.timeYear = year;

- exports.timeYears = years;

- exports.utcMinute = utcMinute;

- exports.utcMinutes = utcMinutes;

- exports.utcHour = utcHour;

- exports.utcHours = utcHours;

- exports.utcDay = utcDay;

- exports.utcDays = utcDays;

- exports.utcWeek = utcSunday;

- exports.utcWeeks = utcSundays;

- exports.utcSunday = utcSunday;

- exports.utcSundays = utcSundays;

- exports.utcMonday = utcMonday;

- exports.utcMondays = utcMondays;

- exports.utcTuesday = utcTuesday;

- exports.utcTuesdays = utcTuesdays;

- exports.utcWednesday = utcWednesday;

- exports.utcWednesdays = utcWednesdays;

- exports.utcThursday = utcThursday;

- exports.utcThursdays = utcThursdays;

- exports.utcFriday = utcFriday;

- exports.utcFridays = utcFridays;

- exports.utcSaturday = utcSaturday;

- exports.utcSaturdays = utcSaturdays;

- exports.utcMonth = utcMonth;

- exports.utcMonths = utcMonths;

- exports.utcYear = utcYear;

- exports.utcYears = utcYears;

- exports.timeFormatDefaultLocale = defaultLocale$1;

- exports.timeFormatLocale = formatLocale$1;

- exports.isoFormat = formatIso;

- exports.isoParse = parseIso;

- exports.now = now;

- exports.timer = timer;

- exports.timerFlush = timerFlush;

- exports.timeout = timeout$1;

- exports.interval = interval$1;

- exports.transition = transition;

- exports.active = active;

- exports.interrupt = interrupt;

- exports.voronoi = voronoi;

- exports.zoom = zoom;

- exports.zoomTransform = transform$1;

- exports.zoomIdentity = identity$8;

- 

- Object.defineProperty(exports, '__esModule', { value: true });

- 

- })));

@@ -1,2 +0,0 @@ 

- // https://d3js.org Version 4.11.0. Copyright 2017 Mike Bostock.

- (function(t,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports):"function"==typeof define&&define.amd?define(["exports"],n):n(t.d3=t.d3||{})})(this,function(t){"use strict";function n(t){return function(n,e){return ls(t(n),e)}}function e(t,n){return[t,n]}function r(t,n,e){var r=(n-t)/Math.max(0,e),i=Math.floor(Math.log(r)/Math.LN10),o=r/Math.pow(10,i);return i>=0?(o>=ks?10:o>=Ss?5:o>=Es?2:1)*Math.pow(10,i):-Math.pow(10,-i)/(o>=ks?10:o>=Ss?5:o>=Es?2:1)}function i(t,n,e){var r=Math.abs(n-t)/Math.max(0,e),i=Math.pow(10,Math.floor(Math.log(r)/Math.LN10)),o=r/i;return o>=ks?i*=10:o>=Ss?i*=5:o>=Es&&(i*=2),n<t?-i:i}function o(t){return t.length}function u(t){return"translate("+(t+.5)+",0)"}function a(t){return"translate(0,"+(t+.5)+")"}function c(t){return function(n){return+t(n)}}function s(t){var n=Math.max(0,t.bandwidth()-1)/2;return t.round()&&(n=Math.round(n)),function(e){return+t(e)+n}}function f(){return!this.__axis}function l(t,n){function e(e){var u=null==i?n.ticks?n.ticks.apply(n,r):n.domain():i,a=null==o?n.tickFormat?n.tickFormat.apply(n,r):Us:o,g=Math.max(l,0)+p,y=n.range(),m=+y[0]+.5,x=+y[y.length-1]+.5,b=(n.bandwidth?s:c)(n.copy()),w=e.selection?e.selection():e,M=w.selectAll(".domain").data([null]),T=w.selectAll(".tick").data(u,n).order(),N=T.exit(),k=T.enter().append("g").attr("class","tick"),S=T.select("line"),E=T.select("text");M=M.merge(M.enter().insert("path",".tick").attr("class","domain").attr("stroke","#000")),T=T.merge(k),S=S.merge(k.append("line").attr("stroke","#000").attr(v+"2",d*l)),E=E.merge(k.append("text").attr("fill","#000").attr(v,d*g).attr("dy",t===Ds?"0em":t===Fs?"0.71em":"0.32em")),e!==w&&(M=M.transition(e),T=T.transition(e),S=S.transition(e),E=E.transition(e),N=N.transition(e).attr("opacity",Ys).attr("transform",function(t){return isFinite(t=b(t))?_(t):this.getAttribute("transform")}),k.attr("opacity",Ys).attr("transform",function(t){var n=this.parentNode.__axis;return _(n&&isFinite(n=n(t))?n:b(t))})),N.remove(),M.attr("d",t===Is||t==Os?"M"+d*h+","+m+"H0.5V"+x+"H"+d*h:"M"+m+","+d*h+"V0.5H"+x+"V"+d*h),T.attr("opacity",1).attr("transform",function(t){return _(b(t))}),S.attr(v+"2",d*l),E.attr(v,d*g).text(a),w.filter(f).attr("fill","none").attr("font-size",10).attr("font-family","sans-serif").attr("text-anchor",t===Os?"start":t===Is?"end":"middle"),w.each(function(){this.__axis=b})}var r=[],i=null,o=null,l=6,h=6,p=3,d=t===Ds||t===Is?-1:1,v=t===Is||t===Os?"x":"y",_=t===Ds||t===Fs?u:a;return e.scale=function(t){return arguments.length?(n=t,e):n},e.ticks=function(){return r=qs.call(arguments),e},e.tickArguments=function(t){return arguments.length?(r=null==t?[]:qs.call(t),e):r.slice()},e.tickValues=function(t){return arguments.length?(i=null==t?null:qs.call(t),e):i&&i.slice()},e.tickFormat=function(t){return arguments.length?(o=t,e):o},e.tickSize=function(t){return arguments.length?(l=h=+t,e):l},e.tickSizeInner=function(t){return arguments.length?(l=+t,e):l},e.tickSizeOuter=function(t){return arguments.length?(h=+t,e):h},e.tickPadding=function(t){return arguments.length?(p=+t,e):p},e}function h(){for(var t,n=0,e=arguments.length,r={};n<e;++n){if(!(t=arguments[n]+"")||t in r)throw new Error("illegal type: "+t);r[t]=[]}return new p(r)}function p(t){this._=t}function d(t,n){return t.trim().split(/^|\s+/).map(function(t){var e="",r=t.indexOf(".");if(r>=0&&(e=t.slice(r+1),t=t.slice(0,r)),t&&!n.hasOwnProperty(t))throw new Error("unknown type: "+t);return{type:t,name:e}})}function v(t,n){for(var e,r=0,i=t.length;r<i;++r)if((e=t[r]).name===n)return e.value}function _(t,n,e){for(var r=0,i=t.length;r<i;++r)if(t[r].name===n){t[r]=Bs,t=t.slice(0,r).concat(t.slice(r+1));break}return null!=e&&t.push({name:n,value:e}),t}function g(t){return function(){var n=this.ownerDocument,e=this.namespaceURI;return e===js&&n.documentElement.namespaceURI===js?n.createElement(t):n.createElementNS(e,t)}}function y(t){return function(){return this.ownerDocument.createElementNS(t.space,t.local)}}function m(){return new x}function x(){this._="@"+(++Vs).toString(36)}function b(t,n,e){return t=w(t,n,e),function(n){var e=n.relatedTarget;e&&(e===this||8&e.compareDocumentPosition(this))||t.call(this,n)}}function w(n,e,r){return function(i){var o=t.event;t.event=i;try{n.call(this,this.__data__,e,r)}finally{t.event=o}}}function M(t){return t.trim().split(/^|\s+/).map(function(t){var n="",e=t.indexOf(".");return e>=0&&(n=t.slice(e+1),t=t.slice(0,e)),{type:t,name:n}})}function T(t){return function(){var n=this.__on;if(n){for(var e,r=0,i=-1,o=n.length;r<o;++r)e=n[r],t.type&&e.type!==t.type||e.name!==t.name?n[++i]=e:this.removeEventListener(e.type,e.listener,e.capture);++i?n.length=i:delete this.__on}}}function N(t,n,e){var r=Qs.hasOwnProperty(t.type)?b:w;return function(i,o,u){var a,c=this.__on,s=r(n,o,u);if(c)for(var f=0,l=c.length;f<l;++f)if((a=c[f]).type===t.type&&a.name===t.name)return this.removeEventListener(a.type,a.listener,a.capture),this.addEventListener(a.type,a.listener=s,a.capture=e),void(a.value=n);this.addEventListener(t.type,s,e),a={type:t.type,name:t.name,value:n,listener:s,capture:e},c?c.push(a):this.__on=[a]}}function k(n,e,r,i){var o=t.event;n.sourceEvent=t.event,t.event=n;try{return e.apply(r,i)}finally{t.event=o}}function S(){}function E(){return[]}function A(t,n){this.ownerDocument=t.ownerDocument,this.namespaceURI=t.namespaceURI,this._next=null,this._parent=t,this.__data__=n}function C(t,n,e,r,i,o){for(var u,a=0,c=n.length,s=o.length;a<s;++a)(u=n[a])?(u.__data__=o[a],r[a]=u):e[a]=new A(t,o[a]);for(;a<c;++a)(u=n[a])&&(i[a]=u)}function z(t,n,e,r,i,o,u){var a,c,s,f={},l=n.length,h=o.length,p=new Array(l);for(a=0;a<l;++a)(c=n[a])&&(p[a]=s=af+u.call(c,c.__data__,a,n),s in f?i[a]=c:f[s]=c);for(a=0;a<h;++a)(c=f[s=af+u.call(t,o[a],a,o)])?(r[a]=c,c.__data__=o[a],f[s]=null):e[a]=new A(t,o[a]);for(a=0;a<l;++a)(c=n[a])&&f[p[a]]===c&&(i[a]=c)}function P(t,n){return t<n?-1:t>n?1:t>=n?0:NaN}function R(t){return function(){this.removeAttribute(t)}}function L(t){return function(){this.removeAttributeNS(t.space,t.local)}}function q(t,n){return function(){this.setAttribute(t,n)}}function U(t,n){return function(){this.setAttributeNS(t.space,t.local,n)}}function D(t,n){return function(){var e=n.apply(this,arguments);null==e?this.removeAttribute(t):this.setAttribute(t,e)}}function O(t,n){return function(){var e=n.apply(this,arguments);null==e?this.removeAttributeNS(t.space,t.local):this.setAttributeNS(t.space,t.local,e)}}function F(t){return function(){this.style.removeProperty(t)}}function I(t,n,e){return function(){this.style.setProperty(t,n,e)}}function Y(t,n,e){return function(){var r=n.apply(this,arguments);null==r?this.style.removeProperty(t):this.style.setProperty(t,r,e)}}function B(t,n){return t.style.getPropertyValue(n)||cf(t).getComputedStyle(t,null).getPropertyValue(n)}function j(t){return function(){delete this[t]}}function H(t,n){return function(){this[t]=n}}function X(t,n){return function(){var e=n.apply(this,arguments);null==e?delete this[t]:this[t]=e}}function $(t){return t.trim().split(/^|\s+/)}function V(t){return t.classList||new W(t)}function W(t){this._node=t,this._names=$(t.getAttribute("class")||"")}function Z(t,n){for(var e=V(t),r=-1,i=n.length;++r<i;)e.add(n[r])}function G(t,n){for(var e=V(t),r=-1,i=n.length;++r<i;)e.remove(n[r])}function J(t){return function(){Z(this,t)}}function Q(t){return function(){G(this,t)}}function K(t,n){return function(){(n.apply(this,arguments)?Z:G)(this,t)}}function tt(){this.textContent=""}function nt(t){return function(){this.textContent=t}}function et(t){return function(){var n=t.apply(this,arguments);this.textContent=null==n?"":n}}function rt(){this.innerHTML=""}function it(t){return function(){this.innerHTML=t}}function ot(t){return function(){var n=t.apply(this,arguments);this.innerHTML=null==n?"":n}}function ut(){this.nextSibling&&this.parentNode.appendChild(this)}function at(){this.previousSibling&&this.parentNode.insertBefore(this,this.parentNode.firstChild)}function ct(){return null}function st(){var t=this.parentNode;t&&t.removeChild(this)}function ft(t,n,e){var r=cf(t),i=r.CustomEvent;"function"==typeof i?i=new i(n,e):(i=r.document.createEvent("Event"),e?(i.initEvent(n,e.bubbles,e.cancelable),i.detail=e.detail):i.initEvent(n,!1,!1)),t.dispatchEvent(i)}function lt(t,n){return function(){return ft(this,t,n)}}function ht(t,n){return function(){return ft(this,t,n.apply(this,arguments))}}function pt(t,n){this._groups=t,this._parents=n}function dt(){return new pt([[document.documentElement]],sf)}function vt(){t.event.stopImmediatePropagation()}function _t(t,n){var e=t.document.documentElement,r=ff(t).on("dragstart.drag",null);n&&(r.on("click.drag",hf,!0),setTimeout(function(){r.on("click.drag",null)},0)),"onselectstart"in e?r.on("selectstart.drag",null):(e.style.MozUserSelect=e.__noselect,delete e.__noselect)}function gt(t,n,e,r,i,o,u,a,c,s){this.target=t,this.type=n,this.subject=e,this.identifier=r,this.active=i,this.x=o,this.y=u,this.dx=a,this.dy=c,this._=s}function yt(){return!t.event.button}function mt(){return this.parentNode}function xt(n){return null==n?{x:t.event.x,y:t.event.y}:n}function bt(){return"ontouchstart"in this}function wt(t,n){var e=Object.create(t.prototype);for(var r in n)e[r]=n[r];return e}function Mt(){}function Tt(t){var n;return t=(t+"").trim().toLowerCase(),(n=mf.exec(t))?(n=parseInt(n[1],16),new At(n>>8&15|n>>4&240,n>>4&15|240&n,(15&n)<<4|15&n,1)):(n=xf.exec(t))?Nt(parseInt(n[1],16)):(n=bf.exec(t))?new At(n[1],n[2],n[3],1):(n=wf.exec(t))?new At(255*n[1]/100,255*n[2]/100,255*n[3]/100,1):(n=Mf.exec(t))?kt(n[1],n[2],n[3],n[4]):(n=Tf.exec(t))?kt(255*n[1]/100,255*n[2]/100,255*n[3]/100,n[4]):(n=Nf.exec(t))?Ct(n[1],n[2]/100,n[3]/100,1):(n=kf.exec(t))?Ct(n[1],n[2]/100,n[3]/100,n[4]):Sf.hasOwnProperty(t)?Nt(Sf[t]):"transparent"===t?new At(NaN,NaN,NaN,0):null}function Nt(t){return new At(t>>16&255,t>>8&255,255&t,1)}function kt(t,n,e,r){return r<=0&&(t=n=e=NaN),new At(t,n,e,r)}function St(t){return t instanceof Mt||(t=Tt(t)),t?(t=t.rgb(),new At(t.r,t.g,t.b,t.opacity)):new At}function Et(t,n,e,r){return 1===arguments.length?St(t):new At(t,n,e,null==r?1:r)}function At(t,n,e,r){this.r=+t,this.g=+n,this.b=+e,this.opacity=+r}function Ct(t,n,e,r){return r<=0?t=n=e=NaN:e<=0||e>=1?t=n=NaN:n<=0&&(t=NaN),new Rt(t,n,e,r)}function zt(t){if(t instanceof Rt)return new Rt(t.h,t.s,t.l,t.opacity);if(t instanceof Mt||(t=Tt(t)),!t)return new Rt;if(t instanceof Rt)return t;var n=(t=t.rgb()).r/255,e=t.g/255,r=t.b/255,i=Math.min(n,e,r),o=Math.max(n,e,r),u=NaN,a=o-i,c=(o+i)/2;return a?(u=n===o?(e-r)/a+6*(e<r):e===o?(r-n)/a+2:(n-e)/a+4,a/=c<.5?o+i:2-o-i,u*=60):a=c>0&&c<1?0:u,new Rt(u,a,c,t.opacity)}function Pt(t,n,e,r){return 1===arguments.length?zt(t):new Rt(t,n,e,null==r?1:r)}function Rt(t,n,e,r){this.h=+t,this.s=+n,this.l=+e,this.opacity=+r}function Lt(t,n,e){return 255*(t<60?n+(e-n)*t/60:t<180?e:t<240?n+(e-n)*(240-t)/60:n)}function qt(t){if(t instanceof Dt)return new Dt(t.l,t.a,t.b,t.opacity);if(t instanceof Ht){var n=t.h*Ef;return new Dt(t.l,Math.cos(n)*t.c,Math.sin(n)*t.c,t.opacity)}t instanceof At||(t=St(t));var e=Yt(t.r),r=Yt(t.g),i=Yt(t.b),o=Ot((.4124564*e+.3575761*r+.1804375*i)/Cf),u=Ot((.2126729*e+.7151522*r+.072175*i)/zf);return new Dt(116*u-16,500*(o-u),200*(u-Ot((.0193339*e+.119192*r+.9503041*i)/Pf)),t.opacity)}function Ut(t,n,e,r){return 1===arguments.length?qt(t):new Dt(t,n,e,null==r?1:r)}function Dt(t,n,e,r){this.l=+t,this.a=+n,this.b=+e,this.opacity=+r}function Ot(t){return t>Uf?Math.pow(t,1/3):t/qf+Rf}function Ft(t){return t>Lf?t*t*t:qf*(t-Rf)}function It(t){return 255*(t<=.0031308?12.92*t:1.055*Math.pow(t,1/2.4)-.055)}function Yt(t){return(t/=255)<=.04045?t/12.92:Math.pow((t+.055)/1.055,2.4)}function Bt(t){if(t instanceof Ht)return new Ht(t.h,t.c,t.l,t.opacity);t instanceof Dt||(t=qt(t));var n=Math.atan2(t.b,t.a)*Af;return new Ht(n<0?n+360:n,Math.sqrt(t.a*t.a+t.b*t.b),t.l,t.opacity)}function jt(t,n,e,r){return 1===arguments.length?Bt(t):new Ht(t,n,e,null==r?1:r)}function Ht(t,n,e,r){this.h=+t,this.c=+n,this.l=+e,this.opacity=+r}function Xt(t){if(t instanceof Vt)return new Vt(t.h,t.s,t.l,t.opacity);t instanceof At||(t=St(t));var n=t.r/255,e=t.g/255,r=t.b/255,i=(Hf*r+Bf*n-jf*e)/(Hf+Bf-jf),o=r-i,u=(Yf*(e-i)-Ff*o)/If,a=Math.sqrt(u*u+o*o)/(Yf*i*(1-i)),c=a?Math.atan2(u,o)*Af-120:NaN;return new Vt(c<0?c+360:c,a,i,t.opacity)}function $t(t,n,e,r){return 1===arguments.length?Xt(t):new Vt(t,n,e,null==r?1:r)}function Vt(t,n,e,r){this.h=+t,this.s=+n,this.l=+e,this.opacity=+r}function Wt(t,n,e,r,i){var o=t*t,u=o*t;return((1-3*t+3*o-u)*n+(4-6*o+3*u)*e+(1+3*t+3*o-3*u)*r+u*i)/6}function Zt(t,n){return function(e){return t+e*n}}function Gt(t,n,e){return t=Math.pow(t,e),n=Math.pow(n,e)-t,e=1/e,function(r){return Math.pow(t+r*n,e)}}function Jt(t,n){var e=n-t;return e?Zt(t,e>180||e<-180?e-360*Math.round(e/360):e):Kf(isNaN(t)?n:t)}function Qt(t){return 1==(t=+t)?Kt:function(n,e){return e-n?Gt(n,e,t):Kf(isNaN(n)?e:n)}}function Kt(t,n){var e=n-t;return e?Zt(t,e):Kf(isNaN(t)?n:t)}function tn(t){return function(n){var e,r,i=n.length,o=new Array(i),u=new Array(i),a=new Array(i);for(e=0;e<i;++e)r=Et(n[e]),o[e]=r.r||0,u[e]=r.g||0,a[e]=r.b||0;return o=t(o),u=t(u),a=t(a),r.opacity=1,function(t){return r.r=o(t),r.g=u(t),r.b=a(t),r+""}}}function nn(t){return function(){return t}}function en(t){return function(n){return t(n)+""}}function rn(t,n,e,r){function i(t){return t.length?t.pop()+" ":""}function o(t,r,i,o,u,a){if(t!==i||r!==o){var c=u.push("translate(",null,n,null,e);a.push({i:c-4,x:ol(t,i)},{i:c-2,x:ol(r,o)})}else(i||o)&&u.push("translate("+i+n+o+e)}function u(t,n,e,o){t!==n?(t-n>180?n+=360:n-t>180&&(t+=360),o.push({i:e.push(i(e)+"rotate(",null,r)-2,x:ol(t,n)})):n&&e.push(i(e)+"rotate("+n+r)}function a(t,n,e,o){t!==n?o.push({i:e.push(i(e)+"skewX(",null,r)-2,x:ol(t,n)}):n&&e.push(i(e)+"skewX("+n+r)}function c(t,n,e,r,o,u){if(t!==e||n!==r){var a=o.push(i(o)+"scale(",null,",",null,")");u.push({i:a-4,x:ol(t,e)},{i:a-2,x:ol(n,r)})}else 1===e&&1===r||o.push(i(o)+"scale("+e+","+r+")")}return function(n,e){var r=[],i=[];return n=t(n),e=t(e),o(n.translateX,n.translateY,e.translateX,e.translateY,r,i),u(n.rotate,e.rotate,r,i),a(n.skewX,e.skewX,r,i),c(n.scaleX,n.scaleY,e.scaleX,e.scaleY,r,i),n=e=null,function(t){for(var n,e=-1,o=i.length;++e<o;)r[(n=i[e]).i]=n.x(t);return r.join("")}}}function on(t){return((t=Math.exp(t))+1/t)/2}function un(t){return((t=Math.exp(t))-1/t)/2}function an(t){return((t=Math.exp(2*t))-1)/(t+1)}function cn(t){return function(n,e){var r=t((n=Pt(n)).h,(e=Pt(e)).h),i=Kt(n.s,e.s),o=Kt(n.l,e.l),u=Kt(n.opacity,e.opacity);return function(t){return n.h=r(t),n.s=i(t),n.l=o(t),n.opacity=u(t),n+""}}}function sn(t){return function(n,e){var r=t((n=jt(n)).h,(e=jt(e)).h),i=Kt(n.c,e.c),o=Kt(n.l,e.l),u=Kt(n.opacity,e.opacity);return function(t){return n.h=r(t),n.c=i(t),n.l=o(t),n.opacity=u(t),n+""}}}function fn(t){return function n(e){function r(n,r){var i=t((n=$t(n)).h,(r=$t(r)).h),o=Kt(n.s,r.s),u=Kt(n.l,r.l),a=Kt(n.opacity,r.opacity);return function(t){return n.h=i(t),n.s=o(t),n.l=u(Math.pow(t,e)),n.opacity=a(t),n+""}}return e=+e,r.gamma=n,r}(1)}function ln(){return Cl||(Rl(hn),Cl=Pl.now()+zl)}function hn(){Cl=0}function pn(){this._call=this._time=this._next=null}function dn(t,n,e){var r=new pn;return r.restart(t,n,e),r}function vn(){ln(),++Nl;for(var t,n=Zf;n;)(t=Cl-n._time)>=0&&n._call.call(null,t),n=n._next;--Nl}function _n(){Cl=(Al=Pl.now())+zl,Nl=kl=0;try{vn()}finally{Nl=0,yn(),Cl=0}}function gn(){var t=Pl.now(),n=t-Al;n>El&&(zl-=n,Al=t)}function yn(){for(var t,n,e=Zf,r=1/0;e;)e._call?(r>e._time&&(r=e._time),t=e,e=e._next):(n=e._next,e._next=null,e=t?t._next=n:Zf=n);Gf=t,mn(r)}function mn(t){Nl||(kl&&(kl=clearTimeout(kl)),t-Cl>24?(t<1/0&&(kl=setTimeout(_n,t-Pl.now()-zl)),Sl&&(Sl=clearInterval(Sl))):(Sl||(Al=Pl.now(),Sl=setInterval(gn,El)),Nl=1,Rl(_n)))}function xn(t,n){var e=t.__transition;if(!e||!(e=e[n])||e.state>Dl)throw new Error("too late");return e}function bn(t,n){var e=t.__transition;if(!e||!(e=e[n])||e.state>Fl)throw new Error("too late");return e}function wn(t,n){var e=t.__transition;if(!e||!(e=e[n]))throw new Error("too late");return e}function Mn(t,n,e){function r(c){var s,f,l,h;if(e.state!==Ol)return o();for(s in a)if((h=a[s]).name===e.name){if(h.state===Il)return Ll(r);h.state===Yl?(h.state=jl,h.timer.stop(),h.on.call("interrupt",t,t.__data__,h.index,h.group),delete a[s]):+s<n&&(h.state=jl,h.timer.stop(),delete a[s])}if(Ll(function(){e.state===Il&&(e.state=Yl,e.timer.restart(i,e.delay,e.time),i(c))}),e.state=Fl,e.on.call("start",t,t.__data__,e.index,e.group),e.state===Fl){for(e.state=Il,u=new Array(l=e.tween.length),s=0,f=-1;s<l;++s)(h=e.tween[s].value.call(t,t.__data__,e.index,e.group))&&(u[++f]=h);u.length=f+1}}function i(n){for(var r=n<e.duration?e.ease.call(null,n/e.duration):(e.timer.restart(o),e.state=Bl,1),i=-1,a=u.length;++i<a;)u[i].call(null,r);e.state===Bl&&(e.on.call("end",t,t.__data__,e.index,e.group),o())}function o(){e.state=jl,e.timer.stop(),delete a[n];for(var r in a)return;delete t.__transition}var u,a=t.__transition;a[n]=e,e.timer=dn(function(t){e.state=Ol,e.timer.restart(r,e.delay,e.time),e.delay<=t&&r(t-e.delay)},0,e.time)}function Tn(t,n){var e,r;return function(){var i=bn(this,t),o=i.tween;if(o!==e)for(var u=0,a=(r=e=o).length;u<a;++u)if(r[u].name===n){(r=r.slice()).splice(u,1);break}i.tween=r}}function Nn(t,n,e){var r,i;if("function"!=typeof e)throw new Error;return function(){var o=bn(this,t),u=o.tween;if(u!==r){i=(r=u).slice();for(var a={name:n,value:e},c=0,s=i.length;c<s;++c)if(i[c].name===n){i[c]=a;break}c===s&&i.push(a)}o.tween=i}}function kn(t,n,e){var r=t._id;return t.each(function(){var t=bn(this,r);(t.value||(t.value={}))[n]=e.apply(this,arguments)}),function(t){return wn(t,r).value[n]}}function Sn(t){return function(){this.removeAttribute(t)}}function En(t){return function(){this.removeAttributeNS(t.space,t.local)}}function An(t,n,e){var r,i;return function(){var o=this.getAttribute(t);return o===e?null:o===r?i:i=n(r=o,e)}}function Cn(t,n,e){var r,i;return function(){var o=this.getAttributeNS(t.space,t.local);return o===e?null:o===r?i:i=n(r=o,e)}}function zn(t,n,e){var r,i,o;return function(){var u,a=e(this);{if(null!=a)return(u=this.getAttribute(t))===a?null:u===r&&a===i?o:o=n(r=u,i=a);this.removeAttribute(t)}}}function Pn(t,n,e){var r,i,o;return function(){var u,a=e(this);{if(null!=a)return(u=this.getAttributeNS(t.space,t.local))===a?null:u===r&&a===i?o:o=n(r=u,i=a);this.removeAttributeNS(t.space,t.local)}}}function Rn(t,n){function e(){var e=this,r=n.apply(e,arguments);return r&&function(n){e.setAttributeNS(t.space,t.local,r(n))}}return e._value=n,e}function Ln(t,n){function e(){var e=this,r=n.apply(e,arguments);return r&&function(n){e.setAttribute(t,r(n))}}return e._value=n,e}function qn(t,n){return function(){xn(this,t).delay=+n.apply(this,arguments)}}function Un(t,n){return n=+n,function(){xn(this,t).delay=n}}function Dn(t,n){return function(){bn(this,t).duration=+n.apply(this,arguments)}}function On(t,n){return n=+n,function(){bn(this,t).duration=n}}function Fn(t,n){if("function"!=typeof n)throw new Error;return function(){bn(this,t).ease=n}}function In(t){return(t+"").trim().split(/^|\s+/).every(function(t){var n=t.indexOf(".");return n>=0&&(t=t.slice(0,n)),!t||"start"===t})}function Yn(t,n,e){var r,i,o=In(n)?xn:bn;return function(){var u=o(this,t),a=u.on;a!==r&&(i=(r=a).copy()).on(n,e),u.on=i}}function Bn(t){return function(){var n=this.parentNode;for(var e in this.__transition)if(+e!==t)return;n&&n.removeChild(this)}}function jn(t,n){var e,r,i;return function(){var o=B(this,t),u=(this.style.removeProperty(t),B(this,t));return o===u?null:o===e&&u===r?i:i=n(e=o,r=u)}}function Hn(t){return function(){this.style.removeProperty(t)}}function Xn(t,n,e){var r,i;return function(){var o=B(this,t);return o===e?null:o===r?i:i=n(r=o,e)}}function $n(t,n,e){var r,i,o;return function(){var u=B(this,t),a=e(this);return null==a&&(this.style.removeProperty(t),a=B(this,t)),u===a?null:u===r&&a===i?o:o=n(r=u,i=a)}}function Vn(t,n,e){function r(){var r=this,i=n.apply(r,arguments);return i&&function(n){r.style.setProperty(t,i(n),e)}}return r._value=n,r}function Wn(t){return function(){this.textContent=t}}function Zn(t){return function(){var n=t(this);this.textContent=null==n?"":n}}function Gn(t,n,e,r){this._groups=t,this._parents=n,this._name=e,this._id=r}function Jn(t){return dt().transition(t)}function Qn(){return++Wl}function Kn(t){return((t*=2)<=1?t*t:--t*(2-t)+1)/2}function te(t){return((t*=2)<=1?t*t*t:(t-=2)*t*t+2)/2}function ne(t){return(1-Math.cos(Kl*t))/2}function ee(t){return((t*=2)<=1?Math.pow(2,10*t-10):2-Math.pow(2,10-10*t))/2}function re(t){return((t*=2)<=1?1-Math.sqrt(1-t*t):Math.sqrt(1-(t-=2)*t)+1)/2}function ie(t){return(t=+t)<nh?fh*t*t:t<rh?fh*(t-=eh)*t+ih:t<uh?fh*(t-=oh)*t+ah:fh*(t-=ch)*t+sh}function oe(t,n){for(var e;!(e=t.__transition)||!(e=e[n]);)if(!(t=t.parentNode))return yh.time=ln(),yh;return e}function ue(){t.event.stopImmediatePropagation()}function ae(t){return{type:t}}function ce(){return!t.event.button}function se(){var t=this.ownerSVGElement||this;return[[0,0],[t.width.baseVal.value,t.height.baseVal.value]]}function fe(t){for(;!t.__brush;)if(!(t=t.parentNode))return;return t.__brush}function le(t){return t[0][0]===t[1][0]||t[0][1]===t[1][1]}function he(n){function e(t){var e=t.property("__brush",a).selectAll(".overlay").data([ae("overlay")]);e.enter().append("rect").attr("class","overlay").attr("pointer-events","all").attr("cursor",Ch.overlay).merge(e).each(function(){var t=fe(this).extent;ff(this).attr("x",t[0][0]).attr("y",t[0][1]).attr("width",t[1][0]-t[0][0]).attr("height",t[1][1]-t[0][1])}),t.selectAll(".selection").data([ae("selection")]).enter().append("rect").attr("class","selection").attr("cursor",Ch.selection).attr("fill","#777").attr("fill-opacity",.3).attr("stroke","#fff").attr("shape-rendering","crispEdges");var i=t.selectAll(".handle").data(n.handles,function(t){return t.type});i.exit().remove(),i.enter().append("rect").attr("class",function(t){return"handle handle--"+t.type}).attr("cursor",function(t){return Ch[t.type]}),t.each(r).attr("fill","none").attr("pointer-events","all").style("-webkit-tap-highlight-color","rgba(0,0,0,0)").on("mousedown.brush touchstart.brush",u)}function r(){var t=ff(this),n=fe(this).selection;n?(t.selectAll(".selection").style("display",null).attr("x",n[0][0]).attr("y",n[0][1]).attr("width",n[1][0]-n[0][0]).attr("height",n[1][1]-n[0][1]),t.selectAll(".handle").style("display",null).attr("x",function(t){return"e"===t.type[t.type.length-1]?n[1][0]-p/2:n[0][0]-p/2}).attr("y",function(t){return"s"===t.type[0]?n[1][1]-p/2:n[0][1]-p/2}).attr("width",function(t){return"n"===t.type||"s"===t.type?n[1][0]-n[0][0]+p:p}).attr("height",function(t){return"e"===t.type||"w"===t.type?n[1][1]-n[0][1]+p:p})):t.selectAll(".selection,.handle").style("display","none").attr("x",null).attr("y",null).attr("width",null).attr("height",null)}function i(t,n){return t.__brush.emitter||new o(t,n)}function o(t,n){this.that=t,this.args=n,this.state=t.__brush,this.active=0}function u(){function e(){var t=nf(w);!L||x||b||(Math.abs(t[0]-U[0])>Math.abs(t[1]-U[1])?b=!0:x=!0),U=t,m=!0,wh(),o()}function o(){var t;switch(g=U[0]-q[0],y=U[1]-q[1],T){case Th:case Mh:N&&(g=Math.max(C-a,Math.min(P-p,g)),s=a+g,d=p+g),k&&(y=Math.max(z-l,Math.min(R-v,y)),h=l+y,_=v+y);break;case Nh:N<0?(g=Math.max(C-a,Math.min(P-a,g)),s=a+g,d=p):N>0&&(g=Math.max(C-p,Math.min(P-p,g)),s=a,d=p+g),k<0?(y=Math.max(z-l,Math.min(R-l,y)),h=l+y,_=v):k>0&&(y=Math.max(z-v,Math.min(R-v,y)),h=l,_=v+y);break;case kh:N&&(s=Math.max(C,Math.min(P,a-g*N)),d=Math.max(C,Math.min(P,p+g*N))),k&&(h=Math.max(z,Math.min(R,l-y*k)),_=Math.max(z,Math.min(R,v+y*k)))}d<s&&(N*=-1,t=a,a=p,p=t,t=s,s=d,d=t,M in zh&&F.attr("cursor",Ch[M=zh[M]])),_<h&&(k*=-1,t=l,l=v,v=t,t=h,h=_,_=t,M in Ph&&F.attr("cursor",Ch[M=Ph[M]])),S.selection&&(A=S.selection),x&&(s=A[0][0],d=A[1][0]),b&&(h=A[0][1],_=A[1][1]),A[0][0]===s&&A[0][1]===h&&A[1][0]===d&&A[1][1]===_||(S.selection=[[s,h],[d,_]],r.call(w),D.brush())}function u(){if(ue(),t.event.touches){if(t.event.touches.length)return;c&&clearTimeout(c),c=setTimeout(function(){c=null},500),O.on("touchmove.brush touchend.brush touchcancel.brush",null)}else _t(t.event.view,m),I.on("keydown.brush keyup.brush mousemove.brush mouseup.brush",null);O.attr("pointer-events","all"),F.attr("cursor",Ch.overlay),S.selection&&(A=S.selection),le(A)&&(S.selection=null,r.call(w)),D.end()}if(t.event.touches){if(t.event.changedTouches.length<t.event.touches.length)return wh()}else if(c)return;if(f.apply(this,arguments)){var a,s,l,h,p,d,v,_,g,y,m,x,b,w=this,M=t.event.target.__data__.type,T="selection"===(t.event.metaKey?M="overlay":M)?Mh:t.event.altKey?kh:Nh,N=n===Eh?null:Rh[M],k=n===Sh?null:Lh[M],S=fe(w),E=S.extent,A=S.selection,C=E[0][0],z=E[0][1],P=E[1][0],R=E[1][1],L=N&&k&&t.event.shiftKey,q=nf(w),U=q,D=i(w,arguments).beforestart();"overlay"===M?S.selection=A=[[a=n===Eh?C:q[0],l=n===Sh?z:q[1]],[p=n===Eh?P:a,v=n===Sh?R:l]]:(a=A[0][0],l=A[0][1],p=A[1][0],v=A[1][1]),s=a,h=l,d=p,_=v;var O=ff(w).attr("pointer-events","none"),F=O.selectAll(".overlay").attr("cursor",Ch[M]);if(t.event.touches)O.on("touchmove.brush",e,!0).on("touchend.brush touchcancel.brush",u,!0);else{var I=ff(t.event.view).on("keydown.brush",function(){switch(t.event.keyCode){case 16:L=N&&k;break;case 18:T===Nh&&(N&&(p=d-g*N,a=s+g*N),k&&(v=_-y*k,l=h+y*k),T=kh,o());break;case 32:T!==Nh&&T!==kh||(N<0?p=d-g:N>0&&(a=s-g),k<0?v=_-y:k>0&&(l=h-y),T=Th,F.attr("cursor",Ch.selection),o());break;default:return}wh()},!0).on("keyup.brush",function(){switch(t.event.keyCode){case 16:L&&(x=b=L=!1,o());break;case 18:T===kh&&(N<0?p=d:N>0&&(a=s),k<0?v=_:k>0&&(l=h),T=Nh,o());break;case 32:T===Th&&(t.event.altKey?(N&&(p=d-g*N,a=s+g*N),k&&(v=_-y*k,l=h+y*k),T=kh):(N<0?p=d:N>0&&(a=s),k<0?v=_:k>0&&(l=h),T=Nh),F.attr("cursor",Ch[M]),o());break;default:return}wh()},!0).on("mousemove.brush",e,!0).on("mouseup.brush",u,!0);pf(t.event.view)}ue(),Xl(w),r.call(w),D.start()}}function a(){var t=this.__brush||{selection:null};return t.extent=s.apply(this,arguments),t.dim=n,t}var c,s=se,f=ce,l=h(e,"start","brush","end"),p=6;return e.move=function(t,e){t.selection?t.on("start.brush",function(){i(this,arguments).beforestart().start()}).on("interrupt.brush end.brush",function(){i(this,arguments).end()}).tween("brush",function(){function t(t){u.selection=1===t&&le(s)?null:f(t),r.call(o),a.brush()}var o=this,u=o.__brush,a=i(o,arguments),c=u.selection,s=n.input("function"==typeof e?e.apply(this,arguments):e,u.extent),f=fl(c,s);return c&&s?t:t(1)}):t.each(function(){var t=this,o=arguments,u=t.__brush,a=n.input("function"==typeof e?e.apply(t,o):e,u.extent),c=i(t,o).beforestart();Xl(t),u.selection=null==a||le(a)?null:a,r.call(t),c.start().brush().end()})},o.prototype={beforestart:function(){return 1==++this.active&&(this.state.emitter=this,this.starting=!0),this},start:function(){return this.starting&&(this.starting=!1,this.emit("start")),this},brush:function(){return this.emit("brush"),this},end:function(){return 0==--this.active&&(delete this.state.emitter,this.emit("end")),this},emit:function(t){k(new bh(e,t,n.output(this.state.selection)),l.apply,l,[t,this.that,this.args])}},e.extent=function(t){return arguments.length?(s="function"==typeof t?t:xh([[+t[0][0],+t[0][1]],[+t[1][0],+t[1][1]]]),e):s},e.filter=function(t){return arguments.length?(f="function"==typeof t?t:xh(!!t),e):f},e.handleSize=function(t){return arguments.length?(p=+t,e):p},e.on=function(){var t=l.on.apply(l,arguments);return t===l?e:t},e}function pe(t){return function(n,e){return t(n.source.value+n.target.value,e.source.value+e.target.value)}}function de(){this._x0=this._y0=this._x1=this._y1=null,this._=""}function ve(){return new de}function _e(t){return t.source}function ge(t){return t.target}function ye(t){return t.radius}function me(t){return t.startAngle}function xe(t){return t.endAngle}function be(){}function we(t,n){var e=new be;if(t instanceof be)t.each(function(t,n){e.set(n,t)});else if(Array.isArray(t)){var r,i=-1,o=t.length;if(null==n)for(;++i<o;)e.set(i,t[i]);else for(;++i<o;)e.set(n(r=t[i],i,t),r)}else if(t)for(var u in t)e.set(u,t[u]);return e}function Me(){return{}}function Te(t,n,e){t[n]=e}function Ne(){return we()}function ke(t,n,e){t.set(n,e)}function Se(){}function Ee(t,n){var e=new Se;if(t instanceof Se)t.each(function(t){e.add(t)});else if(t){var r=-1,i=t.length;if(null==n)for(;++r<i;)e.add(t[r]);else for(;++r<i;)e.add(n(t[r],r,t))}return e}function Ae(t){return new Function("d","return {"+t.map(function(t,n){return JSON.stringify(t)+": d["+n+"]"}).join(",")+"}")}function Ce(t,n){var e=Ae(t);return function(r,i){return n(e(r),i,t)}}function ze(t){var n=Object.create(null),e=[];return t.forEach(function(t){for(var r in t)r in n||e.push(n[r]=r)}),e}function Pe(t,n,e,r){if(isNaN(n)||isNaN(e))return t;var i,o,u,a,c,s,f,l,h,p=t._root,d={data:r},v=t._x0,_=t._y0,g=t._x1,y=t._y1;if(!p)return t._root=d,t;for(;p.length;)if((s=n>=(o=(v+g)/2))?v=o:g=o,(f=e>=(u=(_+y)/2))?_=u:y=u,i=p,!(p=p[l=f<<1|s]))return i[l]=d,t;if(a=+t._x.call(null,p.data),c=+t._y.call(null,p.data),n===a&&e===c)return d.next=p,i?i[l]=d:t._root=d,t;do{i=i?i[l]=new Array(4):t._root=new Array(4),(s=n>=(o=(v+g)/2))?v=o:g=o,(f=e>=(u=(_+y)/2))?_=u:y=u}while((l=f<<1|s)==(h=(c>=u)<<1|a>=o));return i[h]=p,i[l]=d,t}function Re(t){return t[0]}function Le(t){return t[1]}function qe(t,n,e){var r=new Ue(null==n?Re:n,null==e?Le:e,NaN,NaN,NaN,NaN);return null==t?r:r.addAll(t)}function Ue(t,n,e,r,i,o){this._x=t,this._y=n,this._x0=e,this._y0=r,this._x1=i,this._y1=o,this._root=void 0}function De(t){for(var n={data:t.data},e=n;t=t.next;)e=e.next={data:t.data};return n}function Oe(t){return t.x+t.vx}function Fe(t){return t.y+t.vy}function Ie(t){return t.index}function Ye(t,n){var e=t.get(n);if(!e)throw new Error("missing: "+n);return e}function Be(t){return t.x}function je(t){return t.y}function He(t){return new Xe(t)}function Xe(t){if(!(n=wp.exec(t)))throw new Error("invalid format: "+t);var n,e=n[1]||" ",r=n[2]||">",i=n[3]||"-",o=n[4]||"",u=!!n[5],a=n[6]&&+n[6],c=!!n[7],s=n[8]&&+n[8].slice(1),f=n[9]||"";"n"===f?(c=!0,f="g"):bp[f]||(f=""),(u||"0"===e&&"="===r)&&(u=!0,e="0",r="="),this.fill=e,this.align=r,this.sign=i,this.symbol=o,this.zero=u,this.width=a,this.comma=c,this.precision=s,this.type=f}function $e(n){return Mp=kp(n),t.format=Mp.format,t.formatPrefix=Mp.formatPrefix,Mp}function Ve(){this.reset()}function We(t,n,e){var r=t.s=n+e,i=r-n,o=r-i;t.t=n-o+(e-i)}function Ze(t){return t>1?0:t<-1?fd:Math.acos(t)}function Ge(t){return t>1?ld:t<-1?-ld:Math.asin(t)}function Je(t){return(t=Td(t/2))*t}function Qe(){}function Ke(t,n){t&&Ad.hasOwnProperty(t.type)&&Ad[t.type](t,n)}function tr(t,n,e){var r,i=-1,o=t.length-e;for(n.lineStart();++i<o;)r=t[i],n.point(r[0],r[1],r[2]);n.lineEnd()}function nr(t,n){var e=-1,r=t.length;for(n.polygonStart();++e<r;)tr(t[e],n,1);n.polygonEnd()}function er(){Rd.point=ir}function rr(){or(zp,Pp)}function ir(t,n){Rd.point=or,zp=t,Pp=n,Rp=t*=vd,Lp=md(n=(n*=vd)/2+hd),qp=Td(n)}function or(t,n){n=(n*=vd)/2+hd;var e=(t*=vd)-Rp,r=e>=0?1:-1,i=r*e,o=md(n),u=Td(n),a=qp*u,c=Lp*o+a*md(i),s=a*r*Td(i);zd.add(yd(s,c)),Rp=t,Lp=o,qp=u}function ur(t){return[yd(t[1],t[0]),Ge(t[2])]}function ar(t){var n=t[0],e=t[1],r=md(e);return[r*md(n),r*Td(n),Td(e)]}function cr(t,n){return t[0]*n[0]+t[1]*n[1]+t[2]*n[2]}function sr(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 fr(t,n){t[0]+=n[0],t[1]+=n[1],t[2]+=n[2]}function lr(t,n){return[t[0]*n,t[1]*n,t[2]*n]}function hr(t){var n=kd(t[0]*t[0]+t[1]*t[1]+t[2]*t[2]);t[0]/=n,t[1]/=n,t[2]/=n}function pr(t,n){Hp.push(Xp=[Up=t,Op=t]),n<Dp&&(Dp=n),n>Fp&&(Fp=n)}function dr(t,n){var e=ar([t*vd,n*vd]);if(jp){var r=sr(jp,e),i=sr([r[1],-r[0],0],r);hr(i),i=ur(i);var o,u=t-Ip,a=u>0?1:-1,c=i[0]*dd*a,s=_d(u)>180;s^(a*Ip<c&&c<a*t)?(o=i[1]*dd)>Fp&&(Fp=o):(c=(c+360)%360-180,s^(a*Ip<c&&c<a*t)?(o=-i[1]*dd)<Dp&&(Dp=o):(n<Dp&&(Dp=n),n>Fp&&(Fp=n))),s?t<Ip?xr(Up,t)>xr(Up,Op)&&(Op=t):xr(t,Op)>xr(Up,Op)&&(Up=t):Op>=Up?(t<Up&&(Up=t),t>Op&&(Op=t)):t>Ip?xr(Up,t)>xr(Up,Op)&&(Op=t):xr(t,Op)>xr(Up,Op)&&(Up=t)}else Hp.push(Xp=[Up=t,Op=t]);n<Dp&&(Dp=n),n>Fp&&(Fp=n),jp=e,Ip=t}function vr(){qd.point=dr}function _r(){Xp[0]=Up,Xp[1]=Op,qd.point=pr,jp=null}function gr(t,n){if(jp){var e=t-Ip;Ld.add(_d(e)>180?e+(e>0?360:-360):e)}else Yp=t,Bp=n;Rd.point(t,n),dr(t,n)}function yr(){Rd.lineStart()}function mr(){gr(Yp,Bp),Rd.lineEnd(),_d(Ld)>sd&&(Up=-(Op=180)),Xp[0]=Up,Xp[1]=Op,jp=null}function xr(t,n){return(n-=t)<0?n+360:n}function br(t,n){return t[0]-n[0]}function wr(t,n){return t[0]<=t[1]?t[0]<=n&&n<=t[1]:n<t[0]||t[1]<n}function Mr(t,n){t*=vd;var e=md(n*=vd);Tr(e*md(t),e*Td(t),Td(n))}function Tr(t,n,e){Wp+=(t-Wp)/++$p,Zp+=(n-Zp)/$p,Gp+=(e-Gp)/$p}function Nr(){Ud.point=kr}function kr(t,n){t*=vd;var e=md(n*=vd);od=e*md(t),ud=e*Td(t),ad=Td(n),Ud.point=Sr,Tr(od,ud,ad)}function Sr(t,n){t*=vd;var e=md(n*=vd),r=e*md(t),i=e*Td(t),o=Td(n),u=yd(kd((u=ud*o-ad*i)*u+(u=ad*r-od*o)*u+(u=od*i-ud*r)*u),od*r+ud*i+ad*o);Vp+=u,Jp+=u*(od+(od=r)),Qp+=u*(ud+(ud=i)),Kp+=u*(ad+(ad=o)),Tr(od,ud,ad)}function Er(){Ud.point=Mr}function Ar(){Ud.point=zr}function Cr(){Pr(rd,id),Ud.point=Mr}function zr(t,n){rd=t,id=n,t*=vd,n*=vd,Ud.point=Pr;var e=md(n);od=e*md(t),ud=e*Td(t),ad=Td(n),Tr(od,ud,ad)}function Pr(t,n){t*=vd;var e=md(n*=vd),r=e*md(t),i=e*Td(t),o=Td(n),u=ud*o-ad*i,a=ad*r-od*o,c=od*i-ud*r,s=kd(u*u+a*a+c*c),f=Ge(s),l=s&&-f/s;td+=l*u,nd+=l*a,ed+=l*c,Vp+=f,Jp+=f*(od+(od=r)),Qp+=f*(ud+(ud=i)),Kp+=f*(ad+(ad=o)),Tr(od,ud,ad)}function Rr(t,n){return[t>fd?t-pd:t<-fd?t+pd:t,n]}function Lr(t,n,e){return(t%=pd)?n||e?Od(Ur(t),Dr(n,e)):Ur(t):n||e?Dr(n,e):Rr}function qr(t){return function(n,e){return n+=t,[n>fd?n-pd:n<-fd?n+pd:n,e]}}function Ur(t){var n=qr(t);return n.invert=qr(-t),n}function Dr(t,n){function e(t,n){var e=md(n),a=md(t)*e,c=Td(t)*e,s=Td(n),f=s*r+a*i;return[yd(c*o-f*u,a*r-s*i),Ge(f*o+c*u)]}var r=md(t),i=Td(t),o=md(n),u=Td(n);return e.invert=function(t,n){var e=md(n),a=md(t)*e,c=Td(t)*e,s=Td(n),f=s*o-c*u;return[yd(c*o+s*u,a*r+f*i),Ge(f*r-a*i)]},e}function Or(t,n,e,r,i,o){if(e){var u=md(n),a=Td(n),c=r*e;null==i?(i=n+r*pd,o=n-c/2):(i=Fr(u,i),o=Fr(u,o),(r>0?i<o:i>o)&&(i+=r*pd));for(var s,f=i;r>0?f>o:f<o;f-=c)s=ur([u,-a*md(f),-a*Td(f)]),t.point(s[0],s[1])}}function Fr(t,n){(n=ar(n))[0]-=t,hr(n);var e=Ze(-n[1]);return((-n[2]<0?-e:e)+pd-sd)%pd}function Ir(t,n,e,r){this.x=t,this.z=n,this.o=e,this.e=r,this.v=!1,this.n=this.p=null}function Yr(t){if(n=t.length){for(var n,e,r=0,i=t[0];++r<n;)i.n=e=t[r],e.p=i,i=e;i.n=e=t[0],e.p=i}}function Br(t){return t.length>1}function jr(t,n){return((t=t.x)[0]<0?t[1]-ld-sd:ld-t[1])-((n=n.x)[0]<0?n[1]-ld-sd:ld-n[1])}function Hr(t,n,e,r){var i,o,u=Td(t-e);return _d(u)>sd?gd((Td(n)*(o=md(r))*Td(e)-Td(r)*(i=md(n))*Td(t))/(i*o*u)):(n+r)/2}function Xr(t,n,e,r){function i(i,o){return t<=i&&i<=e&&n<=o&&o<=r}function o(i,o,a,s){var f=0,l=0;if(null==i||(f=u(i,a))!==(l=u(o,a))||c(i,o)<0^a>0)do{s.point(0===f||3===f?t:e,f>1?r:n)}while((f=(f+a+4)%4)!==l);else s.point(o[0],o[1])}function u(r,i){return _d(r[0]-t)<sd?i>0?0:3:_d(r[0]-e)<sd?i>0?2:1:_d(r[1]-n)<sd?i>0?1:0:i>0?3:2}function a(t,n){return c(t.x,n.x)}function c(t,n){var e=u(t,1),r=u(n,1);return e!==r?e-r:0===e?n[1]-t[1]:1===e?t[0]-n[0]:2===e?t[1]-n[1]:n[0]-t[0]}return function(u){function c(t,n){i(t,n)&&w.point(t,n)}function s(){for(var n=0,e=0,i=h.length;e<i;++e)for(var o,u,a=h[e],c=1,s=a.length,f=a[0],l=f[0],p=f[1];c<s;++c)o=l,u=p,l=(f=a[c])[0],p=f[1],u<=r?p>r&&(l-o)*(r-u)>(p-u)*(t-o)&&++n:p<=r&&(l-o)*(r-u)<(p-u)*(t-o)&&--n;return n}function f(o,u){var a=i(o,u);if(h&&p.push([o,u]),x)d=o,v=u,_=a,x=!1,a&&(w.lineStart(),w.point(o,u));else if(a&&m)w.point(o,u);else{var c=[g=Math.max(av,Math.min(uv,g)),y=Math.max(av,Math.min(uv,y))],s=[o=Math.max(av,Math.min(uv,o)),u=Math.max(av,Math.min(uv,u))];ov(c,s,t,n,e,r)?(m||(w.lineStart(),w.point(c[0],c[1])),w.point(s[0],s[1]),a||w.lineEnd(),b=!1):a&&(w.lineStart(),w.point(o,u),b=!1)}g=o,y=u,m=a}var l,h,p,d,v,_,g,y,m,x,b,w=u,M=Jd(),T={point:c,lineStart:function(){T.point=f,h&&h.push(p=[]),x=!0,m=!1,g=y=NaN},lineEnd:function(){l&&(f(d,v),_&&m&&M.rejoin(),l.push(M.result())),T.point=c,m&&w.lineEnd()},polygonStart:function(){w=M,l=[],h=[],b=!0},polygonEnd:function(){var t=s(),n=b&&t,e=(l=Ps(l)).length;(n||e)&&(u.polygonStart(),n&&(u.lineStart(),o(null,null,1,u),u.lineEnd()),e&&Kd(l,a,t,o,u),u.polygonEnd()),w=u,l=h=p=null}};return T}}function $r(){sv.point=sv.lineEnd=Qe}function Vr(t,n){Fd=t*=vd,Id=Td(n*=vd),Yd=md(n),sv.point=Wr}function Wr(t,n){t*=vd;var e=Td(n*=vd),r=md(n),i=_d(t-Fd),o=md(i),u=r*Td(i),a=Yd*e-Id*r*o,c=Id*e+Yd*r*o;cv.add(yd(kd(u*u+a*a),c)),Fd=t,Id=e,Yd=r}function Zr(t,n){return!(!t||!vv.hasOwnProperty(t.type))&&vv[t.type](t,n)}function Gr(t,n){return 0===pv(t,n)}function Jr(t,n){var e=pv(t[0],t[1]);return pv(t[0],n)+pv(n,t[1])<=e+sd}function Qr(t,n){return!!nv(t.map(Kr),ti(n))}function Kr(t){return(t=t.map(ti)).pop(),t}function ti(t){return[t[0]*vd,t[1]*vd]}function ni(t,n,e){var r=Ns(t,n-sd,e).concat(n);return function(t){return r.map(function(n){return[t,n]})}}function ei(t,n,e){var r=Ns(t,n-sd,e).concat(n);return function(t){return r.map(function(n){return[n,t]})}}function ri(){function t(){return{type:"MultiLineString",coordinates:n()}}function n(){return Ns(xd(o/_)*_,i,_).map(h).concat(Ns(xd(s/g)*g,c,g).map(p)).concat(Ns(xd(r/d)*d,e,d).filter(function(t){return _d(t%_)>sd}).map(f)).concat(Ns(xd(a/v)*v,u,v).filter(function(t){return _d(t%g)>sd}).map(l))}var e,r,i,o,u,a,c,s,f,l,h,p,d=10,v=d,_=90,g=360,y=2.5;return t.lines=function(){return n().map(function(t){return{type:"LineString",coordinates:t}})},t.outline=function(){return{type:"Polygon",coordinates:[h(o).concat(p(c).slice(1),h(i).reverse().slice(1),p(s).reverse().slice(1))]}},t.extent=function(n){return arguments.length?t.extentMajor(n).extentMinor(n):t.extentMinor()},t.extentMajor=function(n){return arguments.length?(o=+n[0][0],i=+n[1][0],s=+n[0][1],c=+n[1][1],o>i&&(n=o,o=i,i=n),s>c&&(n=s,s=c,c=n),t.precision(y)):[[o,s],[i,c]]},t.extentMinor=function(n){return arguments.length?(r=+n[0][0],e=+n[1][0],a=+n[0][1],u=+n[1][1],r>e&&(n=r,r=e,e=n),a>u&&(n=a,a=u,u=n),t.precision(y)):[[r,a],[e,u]]},t.step=function(n){return arguments.length?t.stepMajor(n).stepMinor(n):t.stepMinor()},t.stepMajor=function(n){return arguments.length?(_=+n[0],g=+n[1],t):[_,g]},t.stepMinor=function(n){return arguments.length?(d=+n[0],v=+n[1],t):[d,v]},t.precision=function(n){return arguments.length?(y=+n,f=ni(a,u,90),l=ei(r,e,y),h=ni(s,c,90),p=ei(o,i,y),t):y},t.extentMajor([[-180,-90+sd],[180,90-sd]]).extentMinor([[-180,-80-sd],[180,80+sd]])}function ii(){mv.point=oi}function oi(t,n){mv.point=ui,Bd=Hd=t,jd=Xd=n}function ui(t,n){yv.add(Xd*t-Hd*n),Hd=t,Xd=n}function ai(){ui(Bd,jd)}function ci(t,n){Nv+=t,kv+=n,++Sv}function si(){Lv.point=fi}function fi(t,n){Lv.point=li,ci(Wd=t,Zd=n)}function li(t,n){var e=t-Wd,r=n-Zd,i=kd(e*e+r*r);Ev+=i*(Wd+t)/2,Av+=i*(Zd+n)/2,Cv+=i,ci(Wd=t,Zd=n)}function hi(){Lv.point=ci}function pi(){Lv.point=vi}function di(){_i($d,Vd)}function vi(t,n){Lv.point=_i,ci($d=Wd=t,Vd=Zd=n)}function _i(t,n){var e=t-Wd,r=n-Zd,i=kd(e*e+r*r);Ev+=i*(Wd+t)/2,Av+=i*(Zd+n)/2,Cv+=i,zv+=(i=Zd*t-Wd*n)*(Wd+t),Pv+=i*(Zd+n),Rv+=3*i,ci(Wd=t,Zd=n)}function gi(t){this._context=t}function yi(t,n){Yv.point=mi,Uv=Ov=t,Dv=Fv=n}function mi(t,n){Ov-=t,Fv-=n,Iv.add(kd(Ov*Ov+Fv*Fv)),Ov=t,Fv=n}function xi(){this._string=[]}function bi(t){return"m0,"+t+"a"+t+","+t+" 0 1,1 0,"+-2*t+"a"+t+","+t+" 0 1,1 0,"+2*t+"z"}function wi(t){return function(n){var e=new Mi;for(var r in t)e[r]=t[r];return e.stream=n,e}}function Mi(){}function Ti(t,n,e){var r=n[1][0]-n[0][0],i=n[1][1]-n[0][1],o=t.clipExtent&&t.clipExtent();t.scale(150).translate([0,0]),null!=o&&t.clipExtent(null),Cd(e,t.stream(Tv));var u=Tv.result(),a=Math.min(r/(u[1][0]-u[0][0]),i/(u[1][1]-u[0][1])),c=+n[0][0]+(r-a*(u[1][0]+u[0][0]))/2,s=+n[0][1]+(i-a*(u[1][1]+u[0][1]))/2;return null!=o&&t.clipExtent(o),t.scale(150*a).translate([c,s])}function Ni(t,n,e){return Ti(t,[[0,0],n],e)}function ki(t){return wi({point:function(n,e){n=t(n,e),this.stream.point(n[0],n[1])}})}function Si(t,n){function e(r,i,o,u,a,c,s,f,l,h,p,d,v,_){var g=s-r,y=f-i,m=g*g+y*y;if(m>4*n&&v--){var x=u+h,b=a+p,w=c+d,M=kd(x*x+b*b+w*w),T=Ge(w/=M),N=_d(_d(w)-1)<sd||_d(o-l)<sd?(o+l)/2:yd(b,x),k=t(N,T),S=k[0],E=k[1],A=S-r,C=E-i,z=y*A-g*C;(z*z/m>n||_d((g*A+y*C)/m-.5)>.3||u*h+a*p+c*d<jv)&&(e(r,i,o,u,a,c,S,E,N,x/=M,b/=M,w,v,_),_.point(S,E),e(S,E,N,x,b,w,s,f,l,h,p,d,v,_))}}return function(n){function r(e,r){e=t(e,r),n.point(e[0],e[1])}function i(){g=NaN,w.point=o,n.lineStart()}function o(r,i){var o=ar([r,i]),u=t(r,i);e(g,y,_,m,x,b,g=u[0],y=u[1],_=r,m=o[0],x=o[1],b=o[2],Bv,n),n.point(g,y)}function u(){w.point=r,n.lineEnd()}function a(){i(),w.point=c,w.lineEnd=s}function c(t,n){o(f=t,n),l=g,h=y,p=m,d=x,v=b,w.point=o}function s(){e(g,y,_,m,x,b,l,h,f,p,d,v,Bv,n),w.lineEnd=u,u()}var f,l,h,p,d,v,_,g,y,m,x,b,w={point:r,lineStart:i,lineEnd:u,polygonStart:function(){n.polygonStart(),w.lineStart=a},polygonEnd:function(){n.polygonEnd(),w.lineStart=i}};return w}}function Ei(t){return wi({point:function(n,e){var r=t(n,e);return this.stream.point(r[0],r[1])}})}function Ai(t){return Ci(function(){return t})()}function Ci(t){function n(t){return t=f(t[0]*vd,t[1]*vd),[t[0]*_+a,c-t[1]*_]}function e(t){return(t=f.invert((t[0]-a)/_,(c-t[1])/_))&&[t[0]*dd,t[1]*dd]}function r(t,n){return t=u(t,n),[t[0]*_+a,c-t[1]*_]}function i(){f=Od(s=Lr(b,w,M),u);var t=u(m,x);return a=g-t[0]*_,c=y+t[1]*_,o()}function o(){return d=v=null,n}var u,a,c,s,f,l,h,p,d,v,_=150,g=480,y=250,m=0,x=0,b=0,w=0,M=0,T=null,N=rv,k=null,S=_v,E=.5,A=Hv(r,E);return n.stream=function(t){return d&&v===t?d:d=Xv(Ei(s)(N(A(S(v=t)))))},n.preclip=function(t){return arguments.length?(N=t,T=void 0,o()):N},n.postclip=function(t){return arguments.length?(S=t,k=l=h=p=null,o()):S},n.clipAngle=function(t){return arguments.length?(N=+t?iv(T=t*vd):(T=null,rv),o()):T*dd},n.clipExtent=function(t){return arguments.length?(S=null==t?(k=l=h=p=null,_v):Xr(k=+t[0][0],l=+t[0][1],h=+t[1][0],p=+t[1][1]),o()):null==k?null:[[k,l],[h,p]]},n.scale=function(t){return arguments.length?(_=+t,i()):_},n.translate=function(t){return arguments.length?(g=+t[0],y=+t[1],i()):[g,y]},n.center=function(t){return arguments.length?(m=t[0]%360*vd,x=t[1]%360*vd,i()):[m*dd,x*dd]},n.rotate=function(t){return arguments.length?(b=t[0]%360*vd,w=t[1]%360*vd,M=t.length>2?t[2]%360*vd:0,i()):[b*dd,w*dd,M*dd]},n.precision=function(t){return arguments.length?(A=Hv(r,E=t*t),o()):kd(E)},n.fitExtent=function(t,e){return Ti(n,t,e)},n.fitSize=function(t,e){return Ni(n,t,e)},function(){return u=t.apply(this,arguments),n.invert=u.invert&&e,i()}}function zi(t){var n=0,e=fd/3,r=Ci(t),i=r(n,e);return i.parallels=function(t){return arguments.length?r(n=t[0]*vd,e=t[1]*vd):[n*dd,e*dd]},i}function Pi(t){function n(t,n){return[t*e,Td(n)/e]}var e=md(t);return n.invert=function(t,n){return[t/e,Ge(n*e)]},n}function Ri(t,n){function e(t,n){var e=kd(o-2*i*Td(n))/i;return[e*Td(t*=i),u-e*md(t)]}var r=Td(t),i=(r+Td(n))/2;if(_d(i)<sd)return Pi(t);var o=1+r*(2*i-r),u=kd(o)/i;return e.invert=function(t,n){var e=u-n;return[yd(t,_d(e))/i*Nd(e),Ge((o-(t*t+e*e)*i*i)/(2*i))]},e}function Li(t){var n=t.length;return{point:function(e,r){for(var i=-1;++i<n;)t[i].point(e,r)},sphere:function(){for(var e=-1;++e<n;)t[e].sphere()},lineStart:function(){for(var e=-1;++e<n;)t[e].lineStart()},lineEnd:function(){for(var e=-1;++e<n;)t[e].lineEnd()},polygonStart:function(){for(var e=-1;++e<n;)t[e].polygonStart()},polygonEnd:function(){for(var e=-1;++e<n;)t[e].polygonEnd()}}}function qi(t){return function(n,e){var r=md(n),i=md(e),o=t(r*i);return[o*i*Td(n),o*Td(e)]}}function Ui(t){return function(n,e){var r=kd(n*n+e*e),i=t(r),o=Td(i),u=md(i);return[yd(n*o,r*u),Ge(r&&e*o/r)]}}function Di(t,n){return[t,wd(Sd((ld+n)/2))]}function Oi(t){function n(){var n=fd*a(),u=o(Gd(o.rotate()).invert([0,0]));return s(null==f?[[u[0]-n,u[1]-n],[u[0]+n,u[1]+n]]:t===Di?[[Math.max(u[0]-n,f),e],[Math.min(u[0]+n,r),i]]:[[f,Math.max(u[1]-n,e)],[r,Math.min(u[1]+n,i)]])}var e,r,i,o=Ai(t),u=o.center,a=o.scale,c=o.translate,s=o.clipExtent,f=null;return o.scale=function(t){return arguments.length?(a(t),n()):a()},o.translate=function(t){return arguments.length?(c(t),n()):c()},o.center=function(t){return arguments.length?(u(t),n()):u()},o.clipExtent=function(t){return arguments.length?(null==t?f=e=r=i=null:(f=+t[0][0],e=+t[0][1],r=+t[1][0],i=+t[1][1]),n()):null==f?null:[[f,e],[r,i]]},n()}function Fi(t){return Sd((ld+t)/2)}function Ii(t,n){function e(t,n){o>0?n<-ld+sd&&(n=-ld+sd):n>ld-sd&&(n=ld-sd);var e=o/Md(Fi(n),i);return[e*Td(i*t),o-e*md(i*t)]}var r=md(t),i=t===n?Td(t):wd(r/md(n))/wd(Fi(n)/Fi(t)),o=r*Md(Fi(t),i)/i;return i?(e.invert=function(t,n){var e=o-n,r=Nd(i)*kd(t*t+e*e);return[yd(t,_d(e))/i*Nd(e),2*gd(Md(o/r,1/i))-ld]},e):Di}function Yi(t,n){return[t,n]}function Bi(t,n){function e(t,n){var e=o-n,r=i*t;return[e*Td(r),o-e*md(r)]}var r=md(t),i=t===n?Td(t):(r-md(n))/(n-t),o=r/i+t;return _d(i)<sd?Yi:(e.invert=function(t,n){var e=o-n;return[yd(t,_d(e))/i*Nd(e),o-Nd(i)*kd(t*t+e*e)]},e)}function ji(t,n){var e=md(n),r=md(t)*e;return[e*Td(t)/r,Td(n)/r]}function Hi(t,n,e,r){return 1===t&&1===n&&0===e&&0===r?_v:wi({point:function(i,o){this.stream.point(i*t+e,o*n+r)}})}function Xi(t,n){var e=n*n,r=e*e;return[t*(.8707-.131979*e+r*(r*(.003971*e-.001529*r)-.013791)),n*(1.007226+e*(.015085+r*(.028874*e-.044475-.005916*r)))]}function $i(t,n){return[md(n)*Td(t),Td(n)]}function Vi(t,n){var e=md(n),r=1+md(t)*e;return[e*Td(t)/r,Td(n)/r]}function Wi(t,n){return[wd(Sd((ld+n)/2)),-t]}function Zi(t,n){return t.parent===n.parent?1:2}function Gi(t){return t.reduce(Ji,0)/t.length}function Ji(t,n){return t+n.x}function Qi(t){return 1+t.reduce(Ki,0)}function Ki(t,n){return Math.max(t,n.y)}function to(t){for(var n;n=t.children;)t=n[0];return t}function no(t){for(var n;n=t.children;)t=n[n.length-1];return t}function eo(t){var n=0,e=t.children,r=e&&e.length;if(r)for(;--r>=0;)n+=e[r].value;else n=1;t.value=n}function ro(t,n){if(t===n)return t;var e=t.ancestors(),r=n.ancestors(),i=null;for(t=e.pop(),n=r.pop();t===n;)i=t,t=e.pop(),n=r.pop();return i}function io(t,n){var e,r,i,o,u,a=new co(t),c=+t.value&&(a.value=t.value),s=[a];for(null==n&&(n=oo);e=s.pop();)if(c&&(e.value=+e.data.value),(i=n(e.data))&&(u=i.length))for(e.children=new Array(u),o=u-1;o>=0;--o)s.push(r=e.children[o]=new co(i[o])),r.parent=e,r.depth=e.depth+1;return a.eachBefore(ao)}function oo(t){return t.children}function uo(t){t.data=t.data.data}function ao(t){var n=0;do{t.height=n}while((t=t.parent)&&t.height<++n)}function co(t){this.data=t,this.depth=this.height=0,this.parent=null}function so(t){for(var n,e,r=t.length;r;)e=Math.random()*r--|0,n=t[r],t[r]=t[e],t[e]=n;return t}function fo(t,n){var e,r;if(po(n,t))return[n];for(e=0;e<t.length;++e)if(lo(n,t[e])&&po(go(t[e],n),t))return[t[e],n];for(e=0;e<t.length-1;++e)for(r=e+1;r<t.length;++r)if(lo(go(t[e],t[r]),n)&&lo(go(t[e],n),t[r])&&lo(go(t[r],n),t[e])&&po(yo(t[e],t[r],n),t))return[t[e],t[r],n];throw new Error}function lo(t,n){var e=t.r-n.r,r=n.x-t.x,i=n.y-t.y;return e<0||e*e<r*r+i*i}function ho(t,n){var e=t.r-n.r+1e-6,r=n.x-t.x,i=n.y-t.y;return e>0&&e*e>r*r+i*i}function po(t,n){for(var e=0;e<n.length;++e)if(!ho(t,n[e]))return!1;return!0}function vo(t){switch(t.length){case 1:return _o(t[0]);case 2:return go(t[0],t[1]);case 3:return yo(t[0],t[1],t[2])}}function _o(t){return{x:t.x,y:t.y,r:t.r}}function go(t,n){var e=t.x,r=t.y,i=t.r,o=n.x,u=n.y,a=n.r,c=o-e,s=u-r,f=a-i,l=Math.sqrt(c*c+s*s);return{x:(e+o+c/l*f)/2,y:(r+u+s/l*f)/2,r:(l+i+a)/2}}function yo(t,n,e){var r=t.x,i=t.y,o=t.r,u=n.x,a=n.y,c=n.r,s=e.x,f=e.y,l=e.r,h=r-u,p=r-s,d=i-a,v=i-f,_=c-o,g=l-o,y=r*r+i*i-o*o,m=y-u*u-a*a+c*c,x=y-s*s-f*f+l*l,b=p*d-h*v,w=(d*x-v*m)/(2*b)-r,M=(v*_-d*g)/b,T=(p*m-h*x)/(2*b)-i,N=(h*g-p*_)/b,k=M*M+N*N-1,S=2*(o+w*M+T*N),E=w*w+T*T-o*o,A=-(k?(S+Math.sqrt(S*S-4*k*E))/(2*k):E/S);return{x:r+w+M*A,y:i+T+N*A,r:A}}function mo(t,n,e){var r=t.x,i=t.y,o=n.r+e.r,u=t.r+e.r,a=n.x-r,c=n.y-i,s=a*a+c*c;if(s){var f=.5+((u*=u)-(o*=o))/(2*s),l=Math.sqrt(Math.max(0,2*o*(u+s)-(u-=s)*u-o*o))/(2*s);e.x=r+f*a+l*c,e.y=i+f*c-l*a}else e.x=r+u,e.y=i}function xo(t,n){var e=n.x-t.x,r=n.y-t.y,i=t.r+n.r;return i*i-1e-6>e*e+r*r}function bo(t){var n=t._,e=t.next._,r=n.r+e.r,i=(n.x*e.r+e.x*n.r)/r,o=(n.y*e.r+e.y*n.r)/r;return i*i+o*o}function wo(t){this._=t,this.next=null,this.previous=null}function Mo(t){if(!(i=t.length))return 0;var n,e,r,i,o,u,a,c,s,f,l;if(n=t[0],n.x=0,n.y=0,!(i>1))return n.r;if(e=t[1],n.x=-e.r,e.x=n.r,e.y=0,!(i>2))return n.r+e.r;mo(e,n,r=t[2]),n=new wo(n),e=new wo(e),r=new wo(r),n.next=r.previous=e,e.next=n.previous=r,r.next=e.previous=n;t:for(a=3;a<i;++a){mo(n._,e._,r=t[a]),r=new wo(r),c=e.next,s=n.previous,f=e._.r,l=n._.r;do{if(f<=l){if(xo(c._,r._)){e=c,n.next=e,e.previous=n,--a;continue t}f+=c._.r,c=c.next}else{if(xo(s._,r._)){(n=s).next=e,e.previous=n,--a;continue t}l+=s._.r,s=s.previous}}while(c!==s.next);for(r.previous=n,r.next=e,n.next=e.previous=e=r,o=bo(n);(r=r.next)!==e;)(u=bo(r))<o&&(n=r,o=u);e=n.next}for(n=[e._],r=e;(r=r.next)!==e;)n.push(r._);for(r=Jv(n),a=0;a<i;++a)n=t[a],n.x-=r.x,n.y-=r.y;return r.r}function To(t){return null==t?null:No(t)}function No(t){if("function"!=typeof t)throw new Error;return t}function ko(){return 0}function So(t){return Math.sqrt(t.value)}function Eo(t){return function(n){n.children||(n.r=Math.max(0,+t(n)||0))}}function Ao(t,n){return function(e){if(r=e.children){var r,i,o,u=r.length,a=t(e)*n||0;if(a)for(i=0;i<u;++i)r[i].r+=a;if(o=Mo(r),a)for(i=0;i<u;++i)r[i].r-=a;e.r=o+a}}}function Co(t){return function(n){var e=n.parent;n.r*=t,e&&(n.x=e.x+t*n.x,n.y=e.y+t*n.y)}}function zo(t){return t.id}function Po(t){return t.parentId}function Ro(t,n){return t.parent===n.parent?1:2}function Lo(t){var n=t.children;return n?n[0]:t.t}function qo(t){var n=t.children;return n?n[n.length-1]:t.t}function Uo(t,n,e){var r=e/(n.i-t.i);n.c-=r,n.s+=e,t.c+=r,n.z+=e,n.m+=e}function Do(t){for(var n,e=0,r=0,i=t.children,o=i.length;--o>=0;)(n=i[o]).z+=e,n.m+=e,e+=n.s+(r+=n.c)}function Oo(t,n,e){return t.a.parent===n.parent?t.a:e}function Fo(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 Io(t){for(var n,e,r,i,o,u=new Fo(t,0),a=[u];n=a.pop();)if(r=n._.children)for(n.children=new Array(o=r.length),i=o-1;i>=0;--i)a.push(e=n.children[i]=new Fo(r[i],i)),e.parent=n;return(u.parent=new Fo(null,0)).children=[u],u}function Yo(t,n,e,r,i,o){for(var u,a,c,s,f,l,h,p,d,v,_,g=[],y=n.children,m=0,x=0,b=y.length,w=n.value;m<b;){c=i-e,s=o-r;do{f=y[x++].value}while(!f&&x<b);for(l=h=f,_=f*f*(v=Math.max(s/c,c/s)/(w*t)),d=Math.max(h/_,_/l);x<b;++x){if(f+=a=y[x].value,a<l&&(l=a),a>h&&(h=a),_=f*f*v,(p=Math.max(h/_,_/l))>d){f-=a;break}d=p}g.push(u={value:f,dice:c<s,children:y.slice(m,x)}),u.dice?t_(u,e,r,i,w?r+=s*f/w:o):i_(u,e,r,w?e+=c*f/w:i,o),w-=f,m=x}return g}function Bo(t,n){return t[0]-n[0]||t[1]-n[1]}function jo(t){for(var n=t.length,e=[0,1],r=2,i=2;i<n;++i){for(;r>1&&c_(t[e[r-2]],t[e[r-1]],t[i])<=0;)--r;e[r++]=i}return e.slice(0,r)}function Ho(t){this._size=t,this._call=this._error=null,this._tasks=[],this._data=[],this._waiting=this._active=this._ended=this._start=0}function Xo(t){if(!t._start)try{$o(t)}catch(n){if(t._tasks[t._ended+t._active-1])Wo(t,n);else if(!t._data)throw n}}function $o(t){for(;t._start=t._waiting&&t._active<t._size;){var n=t._ended+t._active,e=t._tasks[n],r=e.length-1,i=e[r];e[r]=Vo(t,n),--t._waiting,++t._active,e=i.apply(null,e),t._tasks[n]&&(t._tasks[n]=e||f_)}}function Vo(t,n){return function(e,r){t._tasks[n]&&(--t._active,++t._ended,t._tasks[n]=null,null==t._error&&(null!=e?Wo(t,e):(t._data[n]=r,t._waiting?Xo(t):Zo(t))))}}function Wo(t,n){var e,r=t._tasks.length;for(t._error=n,t._data=void 0,t._waiting=NaN;--r>=0;)if((e=t._tasks[r])&&(t._tasks[r]=null,e.abort))try{e.abort()}catch(n){}t._active=NaN,Zo(t)}function Zo(t){if(!t._active&&t._call){var n=t._data;t._data=void 0,t._call(t._error,n)}}function Go(t){if(null==t)t=1/0;else if(!((t=+t)>=1))throw new Error("invalid concurrency");return new Ho(t)}function Jo(t){return function(n,e){t(null==n?e:null)}}function Qo(t){var n=t.responseType;return n&&"text"!==n?t.response:t.responseText}function Ko(t,n){return function(e){return t(e.responseText,n)}}function tu(t){function n(n){var o=n+"",u=e.get(o);if(!u){if(i!==C_)return i;e.set(o,u=r.push(n))}return t[(u-1)%t.length]}var e=we(),r=[],i=C_;return t=null==t?[]:A_.call(t),n.domain=function(t){if(!arguments.length)return r.slice();r=[],e=we();for(var i,o,u=-1,a=t.length;++u<a;)e.has(o=(i=t[u])+"")||e.set(o,r.push(i));return n},n.range=function(e){return arguments.length?(t=A_.call(e),n):t.slice()},n.unknown=function(t){return arguments.length?(i=t,n):i},n.copy=function(){return tu().domain(r).range(t).unknown(i)},n}function nu(){function t(){var t=i().length,r=u[1]<u[0],l=u[r-0],h=u[1-r];n=(h-l)/Math.max(1,t-c+2*s),a&&(n=Math.floor(n)),l+=(h-l-n*(t-c))*f,e=n*(1-c),a&&(l=Math.round(l),e=Math.round(e));var p=Ns(t).map(function(t){return l+n*t});return o(r?p.reverse():p)}var n,e,r=tu().unknown(void 0),i=r.domain,o=r.range,u=[0,1],a=!1,c=0,s=0,f=.5;return delete r.unknown,r.domain=function(n){return arguments.length?(i(n),t()):i()},r.range=function(n){return arguments.length?(u=[+n[0],+n[1]],t()):u.slice()},r.rangeRound=function(n){return u=[+n[0],+n[1]],a=!0,t()},r.bandwidth=function(){return e},r.step=function(){return n},r.round=function(n){return arguments.length?(a=!!n,t()):a},r.padding=function(n){return arguments.length?(c=s=Math.max(0,Math.min(1,n)),t()):c},r.paddingInner=function(n){return arguments.length?(c=Math.max(0,Math.min(1,n)),t()):c},r.paddingOuter=function(n){return arguments.length?(s=Math.max(0,Math.min(1,n)),t()):s},r.align=function(n){return arguments.length?(f=Math.max(0,Math.min(1,n)),t()):f},r.copy=function(){return nu().domain(i()).range(u).round(a).paddingInner(c).paddingOuter(s).align(f)},t()}function eu(t){var n=t.copy;return t.padding=t.paddingOuter,delete t.paddingInner,delete t.paddingOuter,t.copy=function(){return eu(n())},t}function ru(t,n){return(n-=t=+t)?function(e){return(e-t)/n}:z_(n)}function iu(t){return function(n,e){var r=t(n=+n,e=+e);return function(t){return t<=n?0:t>=e?1:r(t)}}}function ou(t){return function(n,e){var r=t(n=+n,e=+e);return function(t){return t<=0?n:t>=1?e:r(t)}}}function uu(t,n,e,r){var i=t[0],o=t[1],u=n[0],a=n[1];return o<i?(i=e(o,i),u=r(a,u)):(i=e(i,o),u=r(u,a)),function(t){return u(i(t))}}function au(t,n,e,r){var i=Math.min(t.length,n.length)-1,o=new Array(i),u=new Array(i),a=-1;for(t[i]<t[0]&&(t=t.slice().reverse(),n=n.slice().reverse());++a<i;)o[a]=e(t[a],t[a+1]),u[a]=r(n[a],n[a+1]);return function(n){var e=ds(t,n,1,i)-1;return u[e](o[e](n))}}function cu(t,n){return n.domain(t.domain()).range(t.range()).interpolate(t.interpolate()).clamp(t.clamp())}function su(t,n){function e(){return i=Math.min(a.length,c.length)>2?au:uu,o=u=null,r}function r(n){return(o||(o=i(a,c,f?iu(t):t,s)))(+n)}var i,o,u,a=R_,c=R_,s=fl,f=!1;return r.invert=function(t){return(u||(u=i(c,a,ru,f?ou(n):n)))(+t)},r.domain=function(t){return arguments.length?(a=E_.call(t,P_),e()):a.slice()},r.range=function(t){return arguments.length?(c=A_.call(t),e()):c.slice()},r.rangeRound=function(t){return c=A_.call(t),s=ll,e()},r.clamp=function(t){return arguments.length?(f=!!t,e()):f},r.interpolate=function(t){return arguments.length?(s=t,e()):s},e()}function fu(t){var n=t.domain;return t.ticks=function(t){var e=n();return As(e[0],e[e.length-1],null==t?10:t)},t.tickFormat=function(t,e){return L_(n(),t,e)},t.nice=function(e){null==e&&(e=10);var i,o=n(),u=0,a=o.length-1,c=o[u],s=o[a];return s<c&&(i=c,c=s,s=i,i=u,u=a,a=i),(i=r(c,s,e))>0?i=r(c=Math.floor(c/i)*i,s=Math.ceil(s/i)*i,e):i<0&&(i=r(c=Math.ceil(c*i)/i,s=Math.floor(s*i)/i,e)),i>0?(o[u]=Math.floor(c/i)*i,o[a]=Math.ceil(s/i)*i,n(o)):i<0&&(o[u]=Math.ceil(c*i)/i,o[a]=Math.floor(s*i)/i,n(o)),t},t}function lu(){var t=su(ru,ol);return t.copy=function(){return cu(t,lu())},fu(t)}function hu(){function t(t){return+t}var n=[0,1];return t.invert=t,t.domain=t.range=function(e){return arguments.length?(n=E_.call(e,P_),t):n.slice()},t.copy=function(){return hu().domain(n)},fu(t)}function pu(t,n){return(n=Math.log(n/t))?function(e){return Math.log(e/t)/n}:z_(n)}function du(t,n){return t<0?function(e){return-Math.pow(-n,e)*Math.pow(-t,1-e)}:function(e){return Math.pow(n,e)*Math.pow(t,1-e)}}function vu(t){return isFinite(t)?+("1e"+t):t<0?0:t}function _u(t){return 10===t?vu:t===Math.E?Math.exp:function(n){return Math.pow(t,n)}}function gu(t){return t===Math.E?Math.log:10===t&&Math.log10||2===t&&Math.log2||(t=Math.log(t),function(n){return Math.log(n)/t})}function yu(t){return function(n){return-t(-n)}}function mu(){function n(){return o=gu(i),u=_u(i),r()[0]<0&&(o=yu(o),u=yu(u)),e}var e=su(pu,du).domain([1,10]),r=e.domain,i=10,o=gu(10),u=_u(10);return e.base=function(t){return arguments.length?(i=+t,n()):i},e.domain=function(t){return arguments.length?(r(t),n()):r()},e.ticks=function(t){var n,e=r(),a=e[0],c=e[e.length-1];(n=c<a)&&(h=a,a=c,c=h);var s,f,l,h=o(a),p=o(c),d=null==t?10:+t,v=[];if(!(i%1)&&p-h<d){if(h=Math.round(h)-1,p=Math.round(p)+1,a>0){for(;h<p;++h)for(f=1,s=u(h);f<i;++f)if(!((l=s*f)<a)){if(l>c)break;v.push(l)}}else for(;h<p;++h)for(f=i-1,s=u(h);f>=1;--f)if(!((l=s*f)<a)){if(l>c)break;v.push(l)}}else v=As(h,p,Math.min(p-h,d)).map(u);return n?v.reverse():v},e.tickFormat=function(n,r){if(null==r&&(r=10===i?".0e":","),"function"!=typeof r&&(r=t.format(r)),n===1/0)return r;null==n&&(n=10);var a=Math.max(1,i*n/e.ticks().length);return function(t){var n=t/u(Math.round(o(t)));return n*i<i-.5&&(n*=i),n<=a?r(t):""}},e.nice=function(){return r(q_(r(),{floor:function(t){return u(Math.floor(o(t)))},ceil:function(t){return u(Math.ceil(o(t)))}}))},e.copy=function(){return cu(e,mu().base(i))},e}function xu(t,n){return t<0?-Math.pow(-t,n):Math.pow(t,n)}function bu(){var t=1,n=su(function(n,e){return(e=xu(e,t)-(n=xu(n,t)))?function(r){return(xu(r,t)-n)/e}:z_(e)},function(n,e){return e=xu(e,t)-(n=xu(n,t)),function(r){return xu(n+e*r,1/t)}}),e=n.domain;return n.exponent=function(n){return arguments.length?(t=+n,e(e())):t},n.copy=function(){return cu(n,bu().exponent(t))},fu(n)}function wu(){function t(){var t=0,o=Math.max(1,r.length);for(i=new Array(o-1);++t<o;)i[t-1]=zs(e,t/o);return n}function n(t){if(!isNaN(t=+t))return r[ds(i,t)]}var e=[],r=[],i=[];return n.invertExtent=function(t){var n=r.indexOf(t);return n<0?[NaN,NaN]:[n>0?i[n-1]:e[0],n<i.length?i[n]:e[e.length-1]]},n.domain=function(n){if(!arguments.length)return e.slice();e=[];for(var r,i=0,o=n.length;i<o;++i)null==(r=n[i])||isNaN(r=+r)||e.push(r);return e.sort(ls),t()},n.range=function(n){return arguments.length?(r=A_.call(n),t()):r.slice()},n.quantiles=function(){return i.slice()},n.copy=function(){return wu().domain(e).range(r)},n}function Mu(){function t(t){if(t<=t)return u[ds(o,t,0,i)]}function n(){var n=-1;for(o=new Array(i);++n<i;)o[n]=((n+1)*r-(n-i)*e)/(i+1);return t}var e=0,r=1,i=1,o=[.5],u=[0,1];return t.domain=function(t){return arguments.length?(e=+t[0],r=+t[1],n()):[e,r]},t.range=function(t){return arguments.length?(i=(u=A_.call(t)).length-1,n()):u.slice()},t.invertExtent=function(t){var n=u.indexOf(t);return n<0?[NaN,NaN]:n<1?[e,o[0]]:n>=i?[o[i-1],r]:[o[n-1],o[n]]},t.copy=function(){return Mu().domain([e,r]).range(u)},fu(t)}function Tu(){function t(t){if(t<=t)return e[ds(n,t,0,r)]}var n=[.5],e=[0,1],r=1;return t.domain=function(i){return arguments.length?(n=A_.call(i),r=Math.min(n.length,e.length-1),t):n.slice()},t.range=function(i){return arguments.length?(e=A_.call(i),r=Math.min(n.length,e.length-1),t):e.slice()},t.invertExtent=function(t){var r=e.indexOf(t);return[n[r-1],n[r]]},t.copy=function(){return Tu().domain(n).range(e)},t}function Nu(t,n,e,r){function i(n){return t(n=new Date(+n)),n}return i.floor=i,i.ceil=function(e){return t(e=new Date(e-1)),n(e,1),t(e),e},i.round=function(t){var n=i(t),e=i.ceil(t);return t-n<e-t?n:e},i.offset=function(t,e){return n(t=new Date(+t),null==e?1:Math.floor(e)),t},i.range=function(e,r,o){var u=[];if(e=i.ceil(e),o=null==o?1:Math.floor(o),!(e<r&&o>0))return u;do{u.push(new Date(+e))}while(n(e,o),t(e),e<r);return u},i.filter=function(e){return Nu(function(n){if(n>=n)for(;t(n),!e(n);)n.setTime(n-1)},function(t,r){if(t>=t)if(r<0)for(;++r<=0;)for(;n(t,-1),!e(t););else for(;--r>=0;)for(;n(t,1),!e(t););})},e&&(i.count=function(n,r){return U_.setTime(+n),D_.setTime(+r),t(U_),t(D_),Math.floor(e(U_,D_))},i.every=function(t){return t=Math.floor(t),isFinite(t)&&t>0?t>1?i.filter(r?function(n){return r(n)%t==0}:function(n){return i.count(0,n)%t==0}):i:null}),i}function ku(t){return Nu(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())*I_)/Y_})}function Su(t){return Nu(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)/Y_})}function Eu(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 Au(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 Cu(t){return{y:t,m:0,d:1,H:0,M:0,S:0,L:0}}function zu(t){function n(t,n){return function(e){var r,i,o,u=[],a=-1,c=0,s=t.length;for(e instanceof Date||(e=new Date(+e));++a<s;)37===t.charCodeAt(a)&&(u.push(t.slice(c,a)),null!=(i=Fg[r=t.charAt(++a)])?r=t.charAt(++a):i="e"===r?" ":"0",(o=n[r])&&(r=o(e,i)),u.push(r),c=a+1);return u.push(t.slice(c,a)),u.join("")}}function e(t,n){return function(e){var i=Cu(1900);if(r(i,t,e+="",0)!=e.length)return null;if("p"in i&&(i.H=i.H%12+12*i.p),"W"in i||"U"in i){"w"in i||(i.w="W"in i?1:0);var o="Z"in i?Au(Cu(i.y)).getUTCDay():n(Cu(i.y)).getDay();i.m=0,i.d="W"in i?(i.w+6)%7+7*i.W-(o+5)%7:i.w+7*i.U-(o+6)%7}return"Z"in i?(i.H+=i.Z/100|0,i.M+=i.Z%100,Au(i)):n(i)}}function r(t,n,e,r){for(var i,o,u=0,a=n.length,c=e.length;u<a;){if(r>=c)return-1;if(37===(i=n.charCodeAt(u++))){if(i=n.charAt(u++),!(o=T[i in Fg?n.charAt(u++):i])||(r=o(t,e,r))<0)return-1}else if(i!=e.charCodeAt(r++))return-1}return r}var i=t.dateTime,o=t.date,u=t.time,a=t.periods,c=t.days,s=t.shortDays,f=t.months,l=t.shortMonths,h=Lu(a),p=qu(a),d=Lu(c),v=qu(c),_=Lu(s),g=qu(s),y=Lu(f),m=qu(f),x=Lu(l),b=qu(l),w={a:function(t){return s[t.getDay()]},A:function(t){return c[t.getDay()]},b:function(t){return l[t.getMonth()]},B:function(t){return f[t.getMonth()]},c:null,d:Gu,e:Gu,H:Ju,I:Qu,j:Ku,L:ta,m:na,M:ea,p:function(t){return a[+(t.getHours()>=12)]},S:ra,U:ia,w:oa,W:ua,x:null,X:null,y:aa,Y:ca,Z:sa,"%":Ta},M={a:function(t){return s[t.getUTCDay()]},A:function(t){return c[t.getUTCDay()]},b:function(t){return l[t.getUTCMonth()]},B:function(t){return f[t.getUTCMonth()]},c:null,d:fa,e:fa,H:la,I:ha,j:pa,L:da,m:va,M:_a,p:function(t){return a[+(t.getUTCHours()>=12)]},S:ga,U:ya,w:ma,W:xa,x:null,X:null,y:ba,Y:wa,Z:Ma,"%":Ta},T={a:function(t,n,e){var r=_.exec(n.slice(e));return r?(t.w=g[r[0].toLowerCase()],e+r[0].length):-1},A:function(t,n,e){var r=d.exec(n.slice(e));return r?(t.w=v[r[0].toLowerCase()],e+r[0].length):-1},b:function(t,n,e){var r=x.exec(n.slice(e));return r?(t.m=b[r[0].toLowerCase()],e+r[0].length):-1},B:function(t,n,e){var r=y.exec(n.slice(e));return r?(t.m=m[r[0].toLowerCase()],e+r[0].length):-1},c:function(t,n,e){return r(t,i,n,e)},d:ju,e:ju,H:Xu,I:Xu,j:Hu,L:Wu,m:Bu,M:$u,p:function(t,n,e){var r=h.exec(n.slice(e));return r?(t.p=p[r[0].toLowerCase()],e+r[0].length):-1},S:Vu,U:Du,w:Uu,W:Ou,x:function(t,n,e){return r(t,o,n,e)},X:function(t,n,e){return r(t,u,n,e)},y:Iu,Y:Fu,Z:Yu,"%":Zu};return w.x=n(o,w),w.X=n(u,w),w.c=n(i,w),M.x=n(o,M),M.X=n(u,M),M.c=n(i,M),{format:function(t){var e=n(t+="",w);return e.toString=function(){return t},e},parse:function(t){var n=e(t+="",Eu);return n.toString=function(){return t},n},utcFormat:function(t){var e=n(t+="",M);return e.toString=function(){return t},e},utcParse:function(t){var n=e(t,Au);return n.toString=function(){return t},n}}}function Pu(t,n,e){var r=t<0?"-":"",i=(r?-t:t)+"",o=i.length;return r+(o<e?new Array(e-o+1).join(n)+i:i)}function Ru(t){return t.replace(Bg,"\\$&")}function Lu(t){return new RegExp("^(?:"+t.map(Ru).join("|")+")","i")}function qu(t){for(var n={},e=-1,r=t.length;++e<r;)n[t[e].toLowerCase()]=e;return n}function Uu(t,n,e){var r=Ig.exec(n.slice(e,e+1));return r?(t.w=+r[0],e+r[0].length):-1}function Du(t,n,e){var r=Ig.exec(n.slice(e));return r?(t.U=+r[0],e+r[0].length):-1}function Ou(t,n,e){var r=Ig.exec(n.slice(e));return r?(t.W=+r[0],e+r[0].length):-1}function Fu(t,n,e){var r=Ig.exec(n.slice(e,e+4));return r?(t.y=+r[0],e+r[0].length):-1}function Iu(t,n,e){var r=Ig.exec(n.slice(e,e+2));return r?(t.y=+r[0]+(+r[0]>68?1900:2e3),e+r[0].length):-1}function Yu(t,n,e){var r=/^(Z)|([+-]\d\d)(?:\:?(\d\d))?/.exec(n.slice(e,e+6));return r?(t.Z=r[1]?0:-(r[2]+(r[3]||"00")),e+r[0].length):-1}function Bu(t,n,e){var r=Ig.exec(n.slice(e,e+2));return r?(t.m=r[0]-1,e+r[0].length):-1}function ju(t,n,e){var r=Ig.exec(n.slice(e,e+2));return r?(t.d=+r[0],e+r[0].length):-1}function Hu(t,n,e){var r=Ig.exec(n.slice(e,e+3));return r?(t.m=0,t.d=+r[0],e+r[0].length):-1}function Xu(t,n,e){var r=Ig.exec(n.slice(e,e+2));return r?(t.H=+r[0],e+r[0].length):-1}function $u(t,n,e){var r=Ig.exec(n.slice(e,e+2));return r?(t.M=+r[0],e+r[0].length):-1}function Vu(t,n,e){var r=Ig.exec(n.slice(e,e+2));return r?(t.S=+r[0],e+r[0].length):-1}function Wu(t,n,e){var r=Ig.exec(n.slice(e,e+3));return r?(t.L=+r[0],e+r[0].length):-1}function Zu(t,n,e){var r=Yg.exec(n.slice(e,e+1));return r?e+r[0].length:-1}function Gu(t,n){return Pu(t.getDate(),n,2)}function Ju(t,n){return Pu(t.getHours(),n,2)}function Qu(t,n){return Pu(t.getHours()%12||12,n,2)}function Ku(t,n){return Pu(1+W_.count(hg(t),t),n,3)}function ta(t,n){return Pu(t.getMilliseconds(),n,3)}function na(t,n){return Pu(t.getMonth()+1,n,2)}function ea(t,n){return Pu(t.getMinutes(),n,2)}function ra(t,n){return Pu(t.getSeconds(),n,2)}function ia(t,n){return Pu(G_.count(hg(t),t),n,2)}function oa(t){return t.getDay()}function ua(t,n){return Pu(J_.count(hg(t),t),n,2)}function aa(t,n){return Pu(t.getFullYear()%100,n,2)}function ca(t,n){return Pu(t.getFullYear()%1e4,n,4)}function sa(t){var n=t.getTimezoneOffset();return(n>0?"-":(n*=-1,"+"))+Pu(n/60|0,"0",2)+Pu(n%60,"0",2)}function fa(t,n){return Pu(t.getUTCDate(),n,2)}function la(t,n){return Pu(t.getUTCHours(),n,2)}function ha(t,n){return Pu(t.getUTCHours()%12||12,n,2)}function pa(t,n){return Pu(1+yg.count(Ug(t),t),n,3)}function da(t,n){return Pu(t.getUTCMilliseconds(),n,3)}function va(t,n){return Pu(t.getUTCMonth()+1,n,2)}function _a(t,n){return Pu(t.getUTCMinutes(),n,2)}function ga(t,n){return Pu(t.getUTCSeconds(),n,2)}function ya(t,n){return Pu(xg.count(Ug(t),t),n,2)}function ma(t){return t.getUTCDay()}function xa(t,n){return Pu(bg.count(Ug(t),t),n,2)}function ba(t,n){return Pu(t.getUTCFullYear()%100,n,2)}function wa(t,n){return Pu(t.getUTCFullYear()%1e4,n,4)}function Ma(){return"+0000"}function Ta(){return"%"}function Na(n){return Dg=zu(n),t.timeFormat=Dg.format,t.timeParse=Dg.parse,t.utcFormat=Dg.utcFormat,t.utcParse=Dg.utcParse,Dg}function ka(t){return new Date(t)}function Sa(t){return t instanceof Date?+t:+new Date(+t)}function Ea(t,n,e,r,o,u,a,c,s){function f(i){return(a(i)<i?v:u(i)<i?_:o(i)<i?g:r(i)<i?y:n(i)<i?e(i)<i?m:x:t(i)<i?b:w)(i)}function l(n,e,r,o){if(null==n&&(n=10),"number"==typeof n){var u=Math.abs(r-e)/n,a=hs(function(t){return t[2]}).right(M,u);a===M.length?(o=i(e/Jg,r/Jg,n),n=t):a?(o=(a=M[u/M[a-1][2]<M[a][2]/u?a-1:a])[1],n=a[0]):(o=i(e,r,n),n=c)}return null==o?n:n.every(o)}var h=su(ru,ol),p=h.invert,d=h.domain,v=s(".%L"),_=s(":%S"),g=s("%I:%M"),y=s("%I %p"),m=s("%a %d"),x=s("%b %d"),b=s("%B"),w=s("%Y"),M=[[a,1,Xg],[a,5,5*Xg],[a,15,15*Xg],[a,30,30*Xg],[u,1,$g],[u,5,5*$g],[u,15,15*$g],[u,30,30*$g],[o,1,Vg],[o,3,3*Vg],[o,6,6*Vg],[o,12,12*Vg],[r,1,Wg],[r,2,2*Wg],[e,1,Zg],[n,1,Gg],[n,3,3*Gg],[t,1,Jg]];return h.invert=function(t){return new Date(p(t))},h.domain=function(t){return arguments.length?d(E_.call(t,Sa)):d().map(ka)},h.ticks=function(t,n){var e,r=d(),i=r[0],o=r[r.length-1],u=o<i;return u&&(e=i,i=o,o=e),e=l(t,i,o,n),e=e?e.range(i,o+1):[],u?e.reverse():e},h.tickFormat=function(t,n){return null==n?f:s(n)},h.nice=function(t,n){var e=d();return(t=l(t,e[0],e[e.length-1],n))?d(q_(e,t)):h},h.copy=function(){return cu(h,Ea(t,n,e,r,o,u,a,c,s))},h}function Aa(t){var n=t.length;return function(e){return t[Math.max(0,Math.min(n-1,Math.floor(e*n)))]}}function Ca(t){function n(n){var o=(n-e)/(r-e);return t(i?Math.max(0,Math.min(1,o)):o)}var e=0,r=1,i=!1;return n.domain=function(t){return arguments.length?(e=+t[0],r=+t[1],n):[e,r]},n.clamp=function(t){return arguments.length?(i=!!t,n):i},n.interpolator=function(e){return arguments.length?(t=e,n):t},n.copy=function(){return Ca(t).domain([e,r]).clamp(i)},fu(n)}function za(t){return t>1?0:t<-1?xy:Math.acos(t)}function Pa(t){return t>=1?by:t<=-1?-by:Math.asin(t)}function Ra(t){return t.innerRadius}function La(t){return t.outerRadius}function qa(t){return t.startAngle}function Ua(t){return t.endAngle}function Da(t){return t&&t.padAngle}function Oa(t,n,e,r,i,o,u,a){var c=e-t,s=r-n,f=u-i,l=a-o,h=(f*(n-o)-l*(t-i))/(l*c-f*s);return[t+h*c,n+h*s]}function Fa(t,n,e,r,i,o,u){var a=t-e,c=n-r,s=(u?o:-o)/yy(a*a+c*c),f=s*c,l=-s*a,h=t+f,p=n+l,d=e+f,v=r+l,_=(h+d)/2,g=(p+v)/2,y=d-h,m=v-p,x=y*y+m*m,b=i-o,w=h*v-d*p,M=(m<0?-1:1)*yy(vy(0,b*b*x-w*w)),T=(w*m-y*M)/x,N=(-w*y-m*M)/x,k=(w*m+y*M)/x,S=(-w*y+m*M)/x,E=T-_,A=N-g,C=k-_,z=S-g;return E*E+A*A>C*C+z*z&&(T=k,N=S),{cx:T,cy:N,x01:-f,y01:-l,x11:T*(i/b-1),y11:N*(i/b-1)}}function Ia(t){this._context=t}function Ya(t){return t[0]}function Ba(t){return t[1]}function ja(t){this._curve=t}function Ha(t){function n(n){return new ja(t(n))}return n._curve=t,n}function Xa(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(Ha(t)):n()._curve},t}function $a(t){return t.source}function Va(t){return t.target}function Wa(t){function n(){var n,a=Py.call(arguments),c=e.apply(this,a),s=r.apply(this,a);if(u||(u=n=ve()),t(u,+i.apply(this,(a[0]=c,a)),+o.apply(this,a),+i.apply(this,(a[0]=s,a)),+o.apply(this,a)),n)return u=null,n+""||null}var e=$a,r=Va,i=Ya,o=Ba,u=null;return n.source=function(t){return arguments.length?(e=t,n):e},n.target=function(t){return arguments.length?(r=t,n):r},n.x=function(t){return arguments.length?(i="function"==typeof t?t:ly(+t),n):i},n.y=function(t){return arguments.length?(o="function"==typeof t?t:ly(+t),n):o},n.context=function(t){return arguments.length?(u=null==t?null:t,n):u},n}function Za(t,n,e,r,i){t.moveTo(n,e),t.bezierCurveTo(n=(n+r)/2,e,n,i,r,i)}function Ga(t,n,e,r,i){t.moveTo(n,e),t.bezierCurveTo(n,e=(e+i)/2,r,e,r,i)}function Ja(t,n,e,r,i){var o=zy(n,e),u=zy(n,e=(e+i)/2),a=zy(r,e),c=zy(r,i);t.moveTo(o[0],o[1]),t.bezierCurveTo(u[0],u[1],a[0],a[1],c[0],c[1])}function Qa(t,n,e){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+e)/6)}function Ka(t){this._context=t}function tc(t){this._context=t}function nc(t){this._context=t}function ec(t,n){this._basis=new Ka(t),this._beta=n}function rc(t,n,e){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-e),t._x2,t._y2)}function ic(t,n){this._context=t,this._k=(1-n)/6}function oc(t,n){this._context=t,this._k=(1-n)/6}function uc(t,n){this._context=t,this._k=(1-n)/6}function ac(t,n,e){var r=t._x1,i=t._y1,o=t._x2,u=t._y2;if(t._l01_a>my){var a=2*t._l01_2a+3*t._l01_a*t._l12_a+t._l12_2a,c=3*t._l01_a*(t._l01_a+t._l12_a);r=(r*a-t._x0*t._l12_2a+t._x2*t._l01_2a)/c,i=(i*a-t._y0*t._l12_2a+t._y2*t._l01_2a)/c}if(t._l23_a>my){var s=2*t._l23_2a+3*t._l23_a*t._l12_a+t._l12_2a,f=3*t._l23_a*(t._l23_a+t._l12_a);o=(o*s+t._x1*t._l23_2a-n*t._l12_2a)/f,u=(u*s+t._y1*t._l23_2a-e*t._l12_2a)/f}t._context.bezierCurveTo(r,i,o,u,t._x2,t._y2)}function cc(t,n){this._context=t,this._alpha=n}function sc(t,n){this._context=t,this._alpha=n}function fc(t,n){this._context=t,this._alpha=n}function lc(t){this._context=t}function hc(t){return t<0?-1:1}function pc(t,n,e){var r=t._x1-t._x0,i=n-t._x1,o=(t._y1-t._y0)/(r||i<0&&-0),u=(e-t._y1)/(i||r<0&&-0),a=(o*i+u*r)/(r+i);return(hc(o)+hc(u))*Math.min(Math.abs(o),Math.abs(u),.5*Math.abs(a))||0}function dc(t,n){var e=t._x1-t._x0;return e?(3*(t._y1-t._y0)/e-n)/2:n}function vc(t,n,e){var r=t._x0,i=t._y0,o=t._x1,u=t._y1,a=(o-r)/3;t._context.bezierCurveTo(r+a,i+a*n,o-a,u-a*e,o,u)}function _c(t){this._context=t}function gc(t){this._context=new yc(t)}function yc(t){this._context=t}function mc(t){this._context=t}function xc(t){var n,e,r=t.length-1,i=new Array(r),o=new Array(r),u=new Array(r);for(i[0]=0,o[0]=2,u[0]=t[0]+2*t[1],n=1;n<r-1;++n)i[n]=1,o[n]=4,u[n]=4*t[n]+2*t[n+1];for(i[r-1]=2,o[r-1]=7,u[r-1]=8*t[r-1]+t[r],n=1;n<r;++n)e=i[n]/o[n-1],o[n]-=e,u[n]-=e*u[n-1];for(i[r-1]=u[r-1]/o[r-1],n=r-2;n>=0;--n)i[n]=(u[n]-i[n+1])/o[n];for(o[r-1]=(t[r]+i[r-1])/2,n=0;n<r-1;++n)o[n]=2*t[n+1]-i[n+1];return[i,o]}function bc(t,n){this._context=t,this._t=n}function wc(t,n){return t[n]}function Mc(t){for(var n,e=0,r=-1,i=t.length;++r<i;)(n=+t[r][1])&&(e+=n);return e}function Tc(t){return t[0]}function Nc(t){return t[1]}function kc(){this._=null}function Sc(t){t.U=t.C=t.L=t.R=t.P=t.N=null}function Ec(t,n){var e=n,r=n.R,i=e.U;i?i.L===e?i.L=r:i.R=r:t._=r,r.U=i,e.U=r,e.R=r.L,e.R&&(e.R.U=e),r.L=e}function Ac(t,n){var e=n,r=n.L,i=e.U;i?i.L===e?i.L=r:i.R=r:t._=r,r.U=i,e.U=r,e.L=r.R,e.L&&(e.L.U=e),r.R=e}function Cc(t){for(;t.L;)t=t.L;return t}function zc(t,n,e,r){var i=[null,null],o=pm.push(i)-1;return i.left=t,i.right=n,e&&Rc(i,t,n,e),r&&Rc(i,n,t,r),lm[t.index].halfedges.push(o),lm[n.index].halfedges.push(o),i}function Pc(t,n,e){var r=[n,e];return r.left=t,r}function Rc(t,n,e,r){t[0]||t[1]?t.left===e?t[1]=r:t[0]=r:(t[0]=r,t.left=n,t.right=e)}function Lc(t,n,e,r,i){var o,u=t[0],a=t[1],c=u[0],s=u[1],f=0,l=1,h=a[0]-c,p=a[1]-s;if(o=n-c,h||!(o>0)){if(o/=h,h<0){if(o<f)return;o<l&&(l=o)}else if(h>0){if(o>l)return;o>f&&(f=o)}if(o=r-c,h||!(o<0)){if(o/=h,h<0){if(o>l)return;o>f&&(f=o)}else if(h>0){if(o<f)return;o<l&&(l=o)}if(o=e-s,p||!(o>0)){if(o/=p,p<0){if(o<f)return;o<l&&(l=o)}else if(p>0){if(o>l)return;o>f&&(f=o)}if(o=i-s,p||!(o<0)){if(o/=p,p<0){if(o>l)return;o>f&&(f=o)}else if(p>0){if(o<f)return;o<l&&(l=o)}return!(f>0||l<1)||(f>0&&(t[0]=[c+f*h,s+f*p]),l<1&&(t[1]=[c+l*h,s+l*p]),!0)}}}}}function qc(t,n,e,r,i){var o=t[1];if(o)return!0;var u,a,c=t[0],s=t.left,f=t.right,l=s[0],h=s[1],p=f[0],d=f[1],v=(l+p)/2,_=(h+d)/2;if(d===h){if(v<n||v>=r)return;if(l>p){if(c){if(c[1]>=i)return}else c=[v,e];o=[v,i]}else{if(c){if(c[1]<e)return}else c=[v,i];o=[v,e]}}else if(u=(l-p)/(d-h),a=_-u*v,u<-1||u>1)if(l>p){if(c){if(c[1]>=i)return}else c=[(e-a)/u,e];o=[(i-a)/u,i]}else{if(c){if(c[1]<e)return}else c=[(i-a)/u,i];o=[(e-a)/u,e]}else if(h<d){if(c){if(c[0]>=r)return}else c=[n,u*n+a];o=[r,u*r+a]}else{if(c){if(c[0]<n)return}else c=[r,u*r+a];o=[n,u*n+a]}return t[0]=c,t[1]=o,!0}function Uc(t,n,e,r){for(var i,o=pm.length;o--;)qc(i=pm[o],t,n,e,r)&&Lc(i,t,n,e,r)&&(Math.abs(i[0][0]-i[1][0])>_m||Math.abs(i[0][1]-i[1][1])>_m)||delete pm[o]}function Dc(t){return lm[t.index]={site:t,halfedges:[]}}function Oc(t,n){var e=t.site,r=n.left,i=n.right;return e===i&&(i=r,r=e),i?Math.atan2(i[1]-r[1],i[0]-r[0]):(e===r?(r=n[1],i=n[0]):(r=n[0],i=n[1]),Math.atan2(r[0]-i[0],i[1]-r[1]))}function Fc(t,n){return n[+(n.left!==t.site)]}function Ic(t,n){return n[+(n.left===t.site)]}function Yc(){for(var t,n,e,r,i=0,o=lm.length;i<o;++i)if((t=lm[i])&&(r=(n=t.halfedges).length)){var u=new Array(r),a=new Array(r);for(e=0;e<r;++e)u[e]=e,a[e]=Oc(t,pm[n[e]]);for(u.sort(function(t,n){return a[n]-a[t]}),e=0;e<r;++e)a[e]=n[u[e]];for(e=0;e<r;++e)n[e]=a[e]}}function Bc(t,n,e,r){var i,o,u,a,c,s,f,l,h,p,d,v,_=lm.length,g=!0;for(i=0;i<_;++i)if(o=lm[i]){for(u=o.site,a=(c=o.halfedges).length;a--;)pm[c[a]]||c.splice(a,1);for(a=0,s=c.length;a<s;)d=(p=Ic(o,pm[c[a]]))[0],v=p[1],l=(f=Fc(o,pm[c[++a%s]]))[0],h=f[1],(Math.abs(d-l)>_m||Math.abs(v-h)>_m)&&(c.splice(a,0,pm.push(Pc(u,p,Math.abs(d-t)<_m&&r-v>_m?[t,Math.abs(l-t)<_m?h:r]:Math.abs(v-r)<_m&&e-d>_m?[Math.abs(h-r)<_m?l:e,r]:Math.abs(d-e)<_m&&v-n>_m?[e,Math.abs(l-e)<_m?h:n]:Math.abs(v-n)<_m&&d-t>_m?[Math.abs(h-n)<_m?l:t,n]:null))-1),++s);s&&(g=!1)}if(g){var y,m,x,b=1/0;for(i=0,g=null;i<_;++i)(o=lm[i])&&(x=(y=(u=o.site)[0]-t)*y+(m=u[1]-n)*m)<b&&(b=x,g=o);if(g){var w=[t,n],M=[t,r],T=[e,r],N=[e,n];g.halfedges.push(pm.push(Pc(u=g.site,w,M))-1,pm.push(Pc(u,M,T))-1,pm.push(Pc(u,T,N))-1,pm.push(Pc(u,N,w))-1)}}for(i=0;i<_;++i)(o=lm[i])&&(o.halfedges.length||delete lm[i])}function jc(){Sc(this),this.x=this.y=this.arc=this.site=this.cy=null}function Hc(t){var n=t.P,e=t.N;if(n&&e){var r=n.site,i=t.site,o=e.site;if(r!==o){var u=i[0],a=i[1],c=r[0]-u,s=r[1]-a,f=o[0]-u,l=o[1]-a,h=2*(c*l-s*f);if(!(h>=-gm)){var p=c*c+s*s,d=f*f+l*l,v=(l*p-s*d)/h,_=(c*d-f*p)/h,g=dm.pop()||new jc;g.arc=t,g.site=i,g.x=v+u,g.y=(g.cy=_+a)+Math.sqrt(v*v+_*_),t.circle=g;for(var y=null,m=hm._;m;)if(g.y<m.y||g.y===m.y&&g.x<=m.x){if(!m.L){y=m.P;break}m=m.L}else{if(!m.R){y=m;break}m=m.R}hm.insert(y,g),y||(sm=g)}}}}function Xc(t){var n=t.circle;n&&(n.P||(sm=n.N),hm.remove(n),dm.push(n),Sc(n),t.circle=null)}function $c(){Sc(this),this.edge=this.site=this.circle=null}function Vc(t){var n=vm.pop()||new $c;return n.site=t,n}function Wc(t){Xc(t),fm.remove(t),vm.push(t),Sc(t)}function Zc(t){var n=t.circle,e=n.x,r=n.cy,i=[e,r],o=t.P,u=t.N,a=[t];Wc(t);for(var c=o;c.circle&&Math.abs(e-c.circle.x)<_m&&Math.abs(r-c.circle.cy)<_m;)o=c.P,a.unshift(c),Wc(c),c=o;a.unshift(c),Xc(c);for(var s=u;s.circle&&Math.abs(e-s.circle.x)<_m&&Math.abs(r-s.circle.cy)<_m;)u=s.N,a.push(s),Wc(s),s=u;a.push(s),Xc(s);var f,l=a.length;for(f=1;f<l;++f)s=a[f],c=a[f-1],Rc(s.edge,c.site,s.site,i);c=a[0],(s=a[l-1]).edge=zc(c.site,s.site,null,i),Hc(c),Hc(s)}function Gc(t){for(var n,e,r,i,o=t[0],u=t[1],a=fm._;a;)if((r=Jc(a,u)-o)>_m)a=a.L;else{if(!((i=o-Qc(a,u))>_m)){r>-_m?(n=a.P,e=a):i>-_m?(n=a,e=a.N):n=e=a;break}if(!a.R){n=a;break}a=a.R}Dc(t);var c=Vc(t);if(fm.insert(n,c),n||e){if(n===e)return Xc(n),e=Vc(n.site),fm.insert(c,e),c.edge=e.edge=zc(n.site,c.site),Hc(n),void Hc(e);if(e){Xc(n),Xc(e);var s=n.site,f=s[0],l=s[1],h=t[0]-f,p=t[1]-l,d=e.site,v=d[0]-f,_=d[1]-l,g=2*(h*_-p*v),y=h*h+p*p,m=v*v+_*_,x=[(_*y-p*m)/g+f,(h*m-v*y)/g+l];Rc(e.edge,s,d,x),c.edge=zc(s,t,null,x),e.edge=zc(t,d,null,x),Hc(n),Hc(e)}else c.edge=zc(n.site,c.site)}}function Jc(t,n){var e=t.site,r=e[0],i=e[1],o=i-n;if(!o)return r;var u=t.P;if(!u)return-1/0;var a=(e=u.site)[0],c=e[1],s=c-n;if(!s)return a;var f=a-r,l=1/o-1/s,h=f/s;return l?(-h+Math.sqrt(h*h-2*l*(f*f/(-2*s)-c+s/2+i-o/2)))/l+r:(r+a)/2}function Qc(t,n){var e=t.N;if(e)return Jc(e,n);var r=t.site;return r[1]===n?r[0]:1/0}function Kc(t,n,e){return(t[0]-e[0])*(n[1]-t[1])-(t[0]-n[0])*(e[1]-t[1])}function ts(t,n){return n[1]-t[1]||n[0]-t[0]}function ns(t,n){var e,r,i,o=t.sort(ts).pop();for(pm=[],lm=new Array(t.length),fm=new kc,hm=new kc;;)if(i=sm,o&&(!i||o[1]<i.y||o[1]===i.y&&o[0]<i.x))o[0]===e&&o[1]===r||(Gc(o),e=o[0],r=o[1]),o=t.pop();else{if(!i)break;Zc(i.arc)}if(Yc(),n){var u=+n[0][0],a=+n[0][1],c=+n[1][0],s=+n[1][1];Uc(u,a,c,s),Bc(u,a,c,s)}this.edges=pm,this.cells=lm,fm=hm=pm=lm=null}function es(t,n,e){this.target=t,this.type=n,this.transform=e}function rs(t,n,e){this.k=t,this.x=n,this.y=e}function is(t){return t.__zoom||mm}function os(){t.event.stopImmediatePropagation()}function us(){return!t.event.button}function as(){var t,n,e=this;return e instanceof SVGElement?(t=(e=e.ownerSVGElement||e).width.baseVal.value,n=e.height.baseVal.value):(t=e.clientWidth,n=e.clientHeight),[[0,0],[t,n]]}function cs(){return this.__zoom||mm}function ss(){return-t.event.deltaY*(t.event.deltaMode?120:1)/500}function fs(){return"ontouchstart"in this}var ls=function(t,n){return t<n?-1:t>n?1:t>=n?0:NaN},hs=function(t){return 1===t.length&&(t=n(t)),{left:function(n,e,r,i){for(null==r&&(r=0),null==i&&(i=n.length);r<i;){var o=r+i>>>1;t(n[o],e)<0?r=o+1:i=o}return r},right:function(n,e,r,i){for(null==r&&(r=0),null==i&&(i=n.length);r<i;){var o=r+i>>>1;t(n[o],e)>0?i=o:r=o+1}return r}}},ps=hs(ls),ds=ps.right,vs=ps.left,_s=function(t){return null===t?NaN:+t},gs=function(t,n){var e,r,i=t.length,o=0,u=-1,a=0,c=0;if(null==n)for(;++u<i;)isNaN(e=_s(t[u]))||(c+=(r=e-a)*(e-(a+=r/++o)));else for(;++u<i;)isNaN(e=_s(n(t[u],u,t)))||(c+=(r=e-a)*(e-(a+=r/++o)));if(o>1)return c/(o-1)},ys=function(t,n){var e=gs(t,n);return e?Math.sqrt(e):e},ms=function(t,n){var e,r,i,o=t.length,u=-1;if(null==n){for(;++u<o;)if(null!=(e=t[u])&&e>=e)for(r=i=e;++u<o;)null!=(e=t[u])&&(r>e&&(r=e),i<e&&(i=e))}else for(;++u<o;)if(null!=(e=n(t[u],u,t))&&e>=e)for(r=i=e;++u<o;)null!=(e=n(t[u],u,t))&&(r>e&&(r=e),i<e&&(i=e));return[r,i]},xs=Array.prototype,bs=xs.slice,ws=xs.map,Ms=function(t){return function(){return t}},Ts=function(t){return t},Ns=function(t,n,e){t=+t,n=+n,e=(i=arguments.length)<2?(n=t,t=0,1):i<3?1:+e;for(var r=-1,i=0|Math.max(0,Math.ceil((n-t)/e)),o=new Array(i);++r<i;)o[r]=t+r*e;return o},ks=Math.sqrt(50),Ss=Math.sqrt(10),Es=Math.sqrt(2),As=function(t,n,e){var i,o,u,a,c=-1;if(n=+n,t=+t,e=+e,t===n&&e>0)return[t];if((i=n<t)&&(o=t,t=n,n=o),0===(a=r(t,n,e))||!isFinite(a))return[];if(a>0)for(t=Math.ceil(t/a),n=Math.floor(n/a),u=new Array(o=Math.ceil(n-t+1));++c<o;)u[c]=(t+c)*a;else for(t=Math.floor(t*a),n=Math.ceil(n*a),u=new Array(o=Math.ceil(t-n+1));++c<o;)u[c]=(t-c)/a;return i&&u.reverse(),u},Cs=function(t){return Math.ceil(Math.log(t.length)/Math.LN2)+1},zs=function(t,n,e){if(null==e&&(e=_s),r=t.length){if((n=+n)<=0||r<2)return+e(t[0],0,t);if(n>=1)return+e(t[r-1],r-1,t);var r,i=(r-1)*n,o=Math.floor(i),u=+e(t[o],o,t);return u+(+e(t[o+1],o+1,t)-u)*(i-o)}},Ps=function(t){for(var n,e,r,i=t.length,o=-1,u=0;++o<i;)u+=t[o].length;for(e=new Array(u);--i>=0;)for(n=(r=t[i]).length;--n>=0;)e[--u]=r[n];return e},Rs=function(t,n){var e,r,i=t.length,o=-1;if(null==n){for(;++o<i;)if(null!=(e=t[o])&&e>=e)for(r=e;++o<i;)null!=(e=t[o])&&r>e&&(r=e)}else for(;++o<i;)if(null!=(e=n(t[o],o,t))&&e>=e)for(r=e;++o<i;)null!=(e=n(t[o],o,t))&&r>e&&(r=e);return r},Ls=function(t){if(!(i=t.length))return[];for(var n=-1,e=Rs(t,o),r=new Array(e);++n<e;)for(var i,u=-1,a=r[n]=new Array(i);++u<i;)a[u]=t[u][n];return r},qs=Array.prototype.slice,Us=function(t){return t},Ds=1,Os=2,Fs=3,Is=4,Ys=1e-6,Bs={value:function(){}};p.prototype=h.prototype={constructor:p,on:function(t,n){var e,r=this._,i=d(t+"",r),o=-1,u=i.length;{if(!(arguments.length<2)){if(null!=n&&"function"!=typeof n)throw new Error("invalid callback: "+n);for(;++o<u;)if(e=(t=i[o]).type)r[e]=_(r[e],t.name,n);else if(null==n)for(e in r)r[e]=_(r[e],t.name,null);return this}for(;++o<u;)if((e=(t=i[o]).type)&&(e=v(r[e],t.name)))return e}},copy:function(){var t={},n=this._;for(var e in n)t[e]=n[e].slice();return new p(t)},call:function(t,n){if((e=arguments.length-2)>0)for(var e,r,i=new Array(e),o=0;o<e;++o)i[o]=arguments[o+2];if(!this._.hasOwnProperty(t))throw new Error("unknown type: "+t);for(o=0,e=(r=this._[t]).length;o<e;++o)r[o].value.apply(n,i)},apply:function(t,n,e){if(!this._.hasOwnProperty(t))throw new Error("unknown type: "+t);for(var r=this._[t],i=0,o=r.length;i<o;++i)r[i].value.apply(n,e)}};var js="http://www.w3.org/1999/xhtml",Hs={svg:"http://www.w3.org/2000/svg",xhtml:js,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"},Xs=function(t){var n=t+="",e=n.indexOf(":");return e>=0&&"xmlns"!==(n=t.slice(0,e))&&(t=t.slice(e+1)),Hs.hasOwnProperty(n)?{space:Hs[n],local:t}:t},$s=function(t){var n=Xs(t);return(n.local?y:g)(n)},Vs=0;x.prototype=m.prototype={constructor:x,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._}};var Ws=function(t){return function(){return this.matches(t)}};if("undefined"!=typeof document){var Zs=document.documentElement;if(!Zs.matches){var Gs=Zs.webkitMatchesSelector||Zs.msMatchesSelector||Zs.mozMatchesSelector||Zs.oMatchesSelector;Ws=function(t){return function(){return Gs.call(this,t)}}}}var Js=Ws,Qs={};t.event=null,"undefined"!=typeof document&&("onmouseenter"in document.documentElement||(Qs={mouseenter:"mouseover",mouseleave:"mouseout"}));var Ks=function(){for(var n,e=t.event;n=e.sourceEvent;)e=n;return e},tf=function(t,n){var e=t.ownerSVGElement||t;if(e.createSVGPoint){var r=e.createSVGPoint();return r.x=n.clientX,r.y=n.clientY,r=r.matrixTransform(t.getScreenCTM().inverse()),[r.x,r.y]}var i=t.getBoundingClientRect();return[n.clientX-i.left-t.clientLeft,n.clientY-i.top-t.clientTop]},nf=function(t){var n=Ks();return n.changedTouches&&(n=n.changedTouches[0]),tf(t,n)},ef=function(t){return null==t?S:function(){return this.querySelector(t)}},rf=function(t){return null==t?E:function(){return this.querySelectorAll(t)}},of=function(t){return new Array(t.length)};A.prototype={constructor:A,appendChild:function(t){return this._parent.insertBefore(t,this._next)},insertBefore:function(t,n){return this._parent.insertBefore(t,n)},querySelector:function(t){return this._parent.querySelector(t)},querySelectorAll:function(t){return this._parent.querySelectorAll(t)}};var uf=function(t){return function(){return t}},af="$",cf=function(t){return t.ownerDocument&&t.ownerDocument.defaultView||t.document&&t||t.defaultView};W.prototype={add:function(t){this._names.indexOf(t)<0&&(this._names.push(t),this._node.setAttribute("class",this._names.join(" ")))},remove:function(t){var n=this._names.indexOf(t);n>=0&&(this._names.splice(n,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(t){return this._names.indexOf(t)>=0}};var sf=[null];pt.prototype=dt.prototype={constructor:pt,select:function(t){"function"!=typeof t&&(t=ef(t));for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i)for(var o,u,a=n[i],c=a.length,s=r[i]=new Array(c),f=0;f<c;++f)(o=a[f])&&(u=t.call(o,o.__data__,f,a))&&("__data__"in o&&(u.__data__=o.__data__),s[f]=u);return new pt(r,this._parents)},selectAll:function(t){"function"!=typeof t&&(t=rf(t));for(var n=this._groups,e=n.length,r=[],i=[],o=0;o<e;++o)for(var u,a=n[o],c=a.length,s=0;s<c;++s)(u=a[s])&&(r.push(t.call(u,u.__data__,s,a)),i.push(u));return new pt(r,i)},filter:function(t){"function"!=typeof t&&(t=Js(t));for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i)for(var o,u=n[i],a=u.length,c=r[i]=[],s=0;s<a;++s)(o=u[s])&&t.call(o,o.__data__,s,u)&&c.push(o);return new pt(r,this._parents)},data:function(t,n){if(!t)return p=new Array(this.size()),s=-1,this.each(function(t){p[++s]=t}),p;var e=n?z:C,r=this._parents,i=this._groups;"function"!=typeof t&&(t=uf(t));for(var o=i.length,u=new Array(o),a=new Array(o),c=new Array(o),s=0;s<o;++s){var f=r[s],l=i[s],h=l.length,p=t.call(f,f&&f.__data__,s,r),d=p.length,v=a[s]=new Array(d),_=u[s]=new Array(d);e(f,l,v,_,c[s]=new Array(h),p,n);for(var g,y,m=0,x=0;m<d;++m)if(g=v[m]){for(m>=x&&(x=m+1);!(y=_[x])&&++x<d;);g._next=y||null}}return u=new pt(u,r),u._enter=a,u._exit=c,u},enter:function(){return new pt(this._enter||this._groups.map(of),this._parents)},exit:function(){return new pt(this._exit||this._groups.map(of),this._parents)},merge:function(t){for(var n=this._groups,e=t._groups,r=n.length,i=e.length,o=Math.min(r,i),u=new Array(r),a=0;a<o;++a)for(var c,s=n[a],f=e[a],l=s.length,h=u[a]=new Array(l),p=0;p<l;++p)(c=s[p]||f[p])&&(h[p]=c);for(;a<r;++a)u[a]=n[a];return new pt(u,this._parents)},order:function(){for(var t=this._groups,n=-1,e=t.length;++n<e;)for(var r,i=t[n],o=i.length-1,u=i[o];--o>=0;)(r=i[o])&&(u&&u!==r.nextSibling&&u.parentNode.insertBefore(r,u),u=r);return this},sort:function(t){t||(t=P);for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i){for(var o,u=n[i],a=u.length,c=r[i]=new Array(a),s=0;s<a;++s)(o=u[s])&&(c[s]=o);c.sort(function(n,e){return n&&e?t(n.__data__,e.__data__):!n-!e})}return new pt(r,this._parents).order()},call:function(){var t=arguments[0];return arguments[0]=this,t.apply(null,arguments),this},nodes:function(){var t=new Array(this.size()),n=-1;return this.each(function(){t[++n]=this}),t},node:function(){for(var t=this._groups,n=0,e=t.length;n<e;++n)for(var r=t[n],i=0,o=r.length;i<o;++i){var u=r[i];if(u)return u}return null},size:function(){var t=0;return this.each(function(){++t}),t},empty:function(){return!this.node()},each:function(t){for(var n=this._groups,e=0,r=n.length;e<r;++e)for(var i,o=n[e],u=0,a=o.length;u<a;++u)(i=o[u])&&t.call(i,i.__data__,u,o);return this},attr:function(t,n){var e=Xs(t);if(arguments.length<2){var r=this.node();return e.local?r.getAttributeNS(e.space,e.local):r.getAttribute(e)}return this.each((null==n?e.local?L:R:"function"==typeof n?e.local?O:D:e.local?U:q)(e,n))},style:function(t,n,e){return arguments.length>1?this.each((null==n?F:"function"==typeof n?Y:I)(t,n,null==e?"":e)):B(this.node(),t)},property:function(t,n){return arguments.length>1?this.each((null==n?j:"function"==typeof n?X:H)(t,n)):this.node()[t]},classed:function(t,n){var e=$(t+"");if(arguments.length<2){for(var r=V(this.node()),i=-1,o=e.length;++i<o;)if(!r.contains(e[i]))return!1;return!0}return this.each(("function"==typeof n?K:n?J:Q)(e,n))},text:function(t){return arguments.length?this.each(null==t?tt:("function"==typeof t?et:nt)(t)):this.node().textContent},html:function(t){return arguments.length?this.each(null==t?rt:("function"==typeof t?ot:it)(t)):this.node().innerHTML},raise:function(){return this.each(ut)},lower:function(){return this.each(at)},append:function(t){var n="function"==typeof t?t:$s(t);return this.select(function(){return this.appendChild(n.apply(this,arguments))})},insert:function(t,n){var e="function"==typeof t?t:$s(t),r=null==n?ct:"function"==typeof n?n:ef(n);return this.select(function(){return this.insertBefore(e.apply(this,arguments),r.apply(this,arguments)||null)})},remove:function(){return this.each(st)},datum:function(t){return arguments.length?this.property("__data__",t):this.node().__data__},on:function(t,n,e){var r,i,o=M(t+""),u=o.length;{if(!(arguments.length<2)){for(a=n?N:T,null==e&&(e=!1),r=0;r<u;++r)this.each(a(o[r],n,e));return this}var a=this.node().__on;if(a)for(var c,s=0,f=a.length;s<f;++s)for(r=0,c=a[s];r<u;++r)if((i=o[r]).type===c.type&&i.name===c.name)return c.value}},dispatch:function(t,n){return this.each(("function"==typeof n?ht:lt)(t,n))}};var ff=function(t){return"string"==typeof t?new pt([[document.querySelector(t)]],[document.documentElement]):new pt([[t]],sf)},lf=function(t,n,e){arguments.length<3&&(e=n,n=Ks().changedTouches);for(var r,i=0,o=n?n.length:0;i<o;++i)if((r=n[i]).identifier===e)return tf(t,r);return null},hf=function(){t.event.preventDefault(),t.event.stopImmediatePropagation()},pf=function(t){var n=t.document.documentElement,e=ff(t).on("dragstart.drag",hf,!0);"onselectstart"in n?e.on("selectstart.drag",hf,!0):(n.__noselect=n.style.MozUserSelect,n.style.MozUserSelect="none")},df=function(t){return function(){return t}};gt.prototype.on=function(){var t=this._.on.apply(this._,arguments);return t===this._?this:t};var vf=function(t,n,e){t.prototype=n.prototype=e,e.constructor=t},_f="\\s*([+-]?\\d+)\\s*",gf="\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)\\s*",yf="\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)%\\s*",mf=/^#([0-9a-f]{3})$/,xf=/^#([0-9a-f]{6})$/,bf=new RegExp("^rgb\\("+[_f,_f,_f]+"\\)$"),wf=new RegExp("^rgb\\("+[yf,yf,yf]+"\\)$"),Mf=new RegExp("^rgba\\("+[_f,_f,_f,gf]+"\\)$"),Tf=new RegExp("^rgba\\("+[yf,yf,yf,gf]+"\\)$"),Nf=new RegExp("^hsl\\("+[gf,yf,yf]+"\\)$"),kf=new RegExp("^hsla\\("+[gf,yf,yf,gf]+"\\)$"),Sf={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};vf(Mt,Tt,{displayable:function(){return this.rgb().displayable()},toString:function(){return this.rgb()+""}}),vf(At,Et,wt(Mt,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new At(this.r*t,this.g*t,this.b*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new At(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(1===(t=isNaN(t)?1:Math.max(0,Math.min(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+")")}})),vf(Rt,Pt,wt(Mt,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new Rt(this.h,this.s,this.l*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new Rt(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,e=this.l,r=e+(e<.5?e:1-e)*n,i=2*e-r;return new At(Lt(t>=240?t-240:t+120,i,r),Lt(t,i,r),Lt(t<120?t+240:t-120,i,r),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}}));var Ef=Math.PI/180,Af=180/Math.PI,Cf=.95047,zf=1,Pf=1.08883,Rf=4/29,Lf=6/29,qf=3*Lf*Lf,Uf=Lf*Lf*Lf;vf(Dt,Ut,wt(Mt,{brighter:function(t){return new Dt(this.l+18*(null==t?1:t),this.a,this.b,this.opacity)},darker:function(t){return new Dt(this.l-18*(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,e=isNaN(this.b)?t:t-this.b/200;return t=zf*Ft(t),n=Cf*Ft(n),e=Pf*Ft(e),new At(It(3.2404542*n-1.5371385*t-.4985314*e),It(-.969266*n+1.8760108*t+.041556*e),It(.0556434*n-.2040259*t+1.0572252*e),this.opacity)}})),vf(Ht,jt,wt(Mt,{brighter:function(t){return new Ht(this.h,this.c,this.l+18*(null==t?1:t),this.opacity)},darker:function(t){return new Ht(this.h,this.c,this.l-18*(null==t?1:t),this.opacity)},rgb:function(){return qt(this).rgb()}}));var Df=-.14861,Of=1.78277,Ff=-.29227,If=-.90649,Yf=1.97294,Bf=Yf*If,jf=Yf*Of,Hf=Of*Ff-If*Df;vf(Vt,$t,wt(Mt,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new Vt(this.h,this.s,this.l*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new Vt(this.h,this.s,this.l*t,this.opacity)},rgb:function(){var t=isNaN(this.h)?0:(this.h+120)*Ef,n=+this.l,e=isNaN(this.s)?0:this.s*n*(1-n),r=Math.cos(t),i=Math.sin(t);return new At(255*(n+e*(Df*r+Of*i)),255*(n+e*(Ff*r+If*i)),255*(n+e*(Yf*r)),this.opacity)}}));var Xf,$f,Vf,Wf,Zf,Gf,Jf=function(t){var n=t.length-1;return function(e){var r=e<=0?e=0:e>=1?(e=1,n-1):Math.floor(e*n),i=t[r],o=t[r+1],u=r>0?t[r-1]:2*i-o,a=r<n-1?t[r+2]:2*o-i;return Wt((e-r/n)*n,u,i,o,a)}},Qf=function(t){var n=t.length;return function(e){var r=Math.floor(((e%=1)<0?++e:e)*n),i=t[(r+n-1)%n],o=t[r%n],u=t[(r+1)%n],a=t[(r+2)%n];return Wt((e-r/n)*n,i,o,u,a)}},Kf=function(t){return function(){return t}},tl=function t(n){function e(t,n){var e=r((t=Et(t)).r,(n=Et(n)).r),i=r(t.g,n.g),o=r(t.b,n.b),u=Kt(t.opacity,n.opacity);return function(n){return t.r=e(n),t.g=i(n),t.b=o(n),t.opacity=u(n),t+""}}var r=Qt(n);return e.gamma=t,e}(1),nl=tn(Jf),el=tn(Qf),rl=function(t,n){var e,r=n?n.length:0,i=t?Math.min(r,t.length):0,o=new Array(r),u=new Array(r);for(e=0;e<i;++e)o[e]=fl(t[e],n[e]);for(;e<r;++e)u[e]=n[e];return function(t){for(e=0;e<i;++e)u[e]=o[e](t);return u}},il=function(t,n){var e=new Date;return t=+t,n-=t,function(r){return e.setTime(t+n*r),e}},ol=function(t,n){return t=+t,n-=t,function(e){return t+n*e}},ul=function(t,n){var e,r={},i={};null!==t&&"object"==typeof t||(t={}),null!==n&&"object"==typeof n||(n={});for(e in n)e in t?r[e]=fl(t[e],n[e]):i[e]=n[e];return function(t){for(e in r)i[e]=r[e](t);return i}},al=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,cl=new RegExp(al.source,"g"),sl=function(t,n){var e,r,i,o=al.lastIndex=cl.lastIndex=0,u=-1,a=[],c=[];for(t+="",n+="";(e=al.exec(t))&&(r=cl.exec(n));)(i=r.index)>o&&(i=n.slice(o,i),a[u]?a[u]+=i:a[++u]=i),(e=e[0])===(r=r[0])?a[u]?a[u]+=r:a[++u]=r:(a[++u]=null,c.push({i:u,x:ol(e,r)})),o=cl.lastIndex;return o<n.length&&(i=n.slice(o),a[u]?a[u]+=i:a[++u]=i),a.length<2?c[0]?en(c[0].x):nn(n):(n=c.length,function(t){for(var e,r=0;r<n;++r)a[(e=c[r]).i]=e.x(t);return a.join("")})},fl=function(t,n){var e,r=typeof n;return null==n||"boolean"===r?Kf(n):("number"===r?ol:"string"===r?(e=Tt(n))?(n=e,tl):sl:n instanceof Tt?tl:n instanceof Date?il:Array.isArray(n)?rl:"function"!=typeof n.valueOf&&"function"!=typeof n.toString||isNaN(n)?ul:ol)(t,n)},ll=function(t,n){return t=+t,n-=t,function(e){return Math.round(t+n*e)}},hl=180/Math.PI,pl={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1},dl=function(t,n,e,r,i,o){var u,a,c;return(u=Math.sqrt(t*t+n*n))&&(t/=u,n/=u),(c=t*e+n*r)&&(e-=t*c,r-=n*c),(a=Math.sqrt(e*e+r*r))&&(e/=a,r/=a,c/=a),t*r<n*e&&(t=-t,n=-n,c=-c,u=-u),{translateX:i,translateY:o,rotate:Math.atan2(n,t)*hl,skewX:Math.atan(c)*hl,scaleX:u,scaleY:a}},vl=rn(function(t){return"none"===t?pl:(Xf||(Xf=document.createElement("DIV"),$f=document.documentElement,Vf=document.defaultView),Xf.style.transform=t,t=Vf.getComputedStyle($f.appendChild(Xf),null).getPropertyValue("transform"),$f.removeChild(Xf),t=t.slice(7,-1).split(","),dl(+t[0],+t[1],+t[2],+t[3],+t[4],+t[5]))},"px, ","px)","deg)"),_l=rn(function(t){return null==t?pl:(Wf||(Wf=document.createElementNS("http://www.w3.org/2000/svg","g")),Wf.setAttribute("transform",t),(t=Wf.transform.baseVal.consolidate())?(t=t.matrix,dl(t.a,t.b,t.c,t.d,t.e,t.f)):pl)},", ",")",")"),gl=Math.SQRT2,yl=function(t,n){var e,r,i=t[0],o=t[1],u=t[2],a=n[0],c=n[1],s=n[2],f=a-i,l=c-o,h=f*f+l*l;if(h<1e-12)r=Math.log(s/u)/gl,e=function(t){return[i+t*f,o+t*l,u*Math.exp(gl*t*r)]};else{var p=Math.sqrt(h),d=(s*s-u*u+4*h)/(2*u*2*p),v=(s*s-u*u-4*h)/(2*s*2*p),_=Math.log(Math.sqrt(d*d+1)-d),g=Math.log(Math.sqrt(v*v+1)-v);r=(g-_)/gl,e=function(t){var n=t*r,e=on(_),a=u/(2*p)*(e*an(gl*n+_)-un(_));return[i+a*f,o+a*l,u*e/on(gl*n+_)]}}return e.duration=1e3*r,e},ml=cn(Jt),xl=cn(Kt),bl=sn(Jt),wl=sn(Kt),Ml=fn(Jt),Tl=fn(Kt),Nl=0,kl=0,Sl=0,El=1e3,Al=0,Cl=0,zl=0,Pl="object"==typeof performance&&performance.now?performance:Date,Rl="object"==typeof window&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(t){setTimeout(t,17)};pn.prototype=dn.prototype={constructor:pn,restart:function(t,n,e){if("function"!=typeof t)throw new TypeError("callback is not a function");e=(null==e?ln():+e)+(null==n?0:+n),this._next||Gf===this||(Gf?Gf._next=this:Zf=this,Gf=this),this._call=t,this._time=e,mn()},stop:function(){this._call&&(this._call=null,this._time=1/0,mn())}};var Ll=function(t,n,e){var r=new pn;return n=null==n?0:+n,r.restart(function(e){r.stop(),t(e+n)},n,e),r},ql=h("start","end","interrupt"),Ul=[],Dl=0,Ol=1,Fl=2,Il=3,Yl=4,Bl=5,jl=6,Hl=function(t,n,e,r,i,o){var u=t.__transition;if(u){if(e in u)return}else t.__transition={};Mn(t,e,{name:n,index:r,group:i,on:ql,tween:Ul,time:o.time,delay:o.delay,duration:o.duration,ease:o.ease,timer:null,state:Dl})},Xl=function(t,n){var e,r,i,o=t.__transition,u=!0;if(o){n=null==n?null:n+"";for(i in o)(e=o[i]).name===n?(r=e.state>Fl&&e.state<Bl,e.state=jl,e.timer.stop(),r&&e.on.call("interrupt",t,t.__data__,e.index,e.group),delete o[i]):u=!1;u&&delete t.__transition}},$l=function(t,n){var e;return("number"==typeof n?ol:n instanceof Tt?tl:(e=Tt(n))?(n=e,tl):sl)(t,n)},Vl=dt.prototype.constructor,Wl=0,Zl=dt.prototype;Gn.prototype=Jn.prototype={constructor:Gn,select:function(t){var n=this._name,e=this._id;"function"!=typeof t&&(t=ef(t));for(var r=this._groups,i=r.length,o=new Array(i),u=0;u<i;++u)for(var a,c,s=r[u],f=s.length,l=o[u]=new Array(f),h=0;h<f;++h)(a=s[h])&&(c=t.call(a,a.__data__,h,s))&&("__data__"in a&&(c.__data__=a.__data__),l[h]=c,Hl(l[h],n,e,h,l,wn(a,e)));return new Gn(o,this._parents,n,e)},selectAll:function(t){var n=this._name,e=this._id;"function"!=typeof t&&(t=rf(t));for(var r=this._groups,i=r.length,o=[],u=[],a=0;a<i;++a)for(var c,s=r[a],f=s.length,l=0;l<f;++l)if(c=s[l]){for(var h,p=t.call(c,c.__data__,l,s),d=wn(c,e),v=0,_=p.length;v<_;++v)(h=p[v])&&Hl(h,n,e,v,p,d);o.push(p),u.push(c)}return new Gn(o,u,n,e)},filter:function(t){"function"!=typeof t&&(t=Js(t));for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i)for(var o,u=n[i],a=u.length,c=r[i]=[],s=0;s<a;++s)(o=u[s])&&t.call(o,o.__data__,s,u)&&c.push(o);return new Gn(r,this._parents,this._name,this._id)},merge:function(t){if(t._id!==this._id)throw new Error;for(var n=this._groups,e=t._groups,r=n.length,i=e.length,o=Math.min(r,i),u=new Array(r),a=0;a<o;++a)for(var c,s=n[a],f=e[a],l=s.length,h=u[a]=new Array(l),p=0;p<l;++p)(c=s[p]||f[p])&&(h[p]=c);for(;a<r;++a)u[a]=n[a];return new Gn(u,this._parents,this._name,this._id)},selection:function(){return new Vl(this._groups,this._parents)},transition:function(){for(var t=this._name,n=this._id,e=Qn(),r=this._groups,i=r.length,o=0;o<i;++o)for(var u,a=r[o],c=a.length,s=0;s<c;++s)if(u=a[s]){var f=wn(u,n);Hl(u,t,e,s,a,{time:f.time+f.delay+f.duration,delay:0,duration:f.duration,ease:f.ease})}return new Gn(r,this._parents,t,e)},call:Zl.call,nodes:Zl.nodes,node:Zl.node,size:Zl.size,empty:Zl.empty,each:Zl.each,on:function(t,n){var e=this._id;return arguments.length<2?wn(this.node(),e).on.on(t):this.each(Yn(e,t,n))},attr:function(t,n){var e=Xs(t),r="transform"===e?_l:$l;return this.attrTween(t,"function"==typeof n?(e.local?Pn:zn)(e,r,kn(this,"attr."+t,n)):null==n?(e.local?En:Sn)(e):(e.local?Cn:An)(e,r,n+""))},attrTween:function(t,n){var e="attr."+t;if(arguments.length<2)return(e=this.tween(e))&&e._value;if(null==n)return this.tween(e,null);if("function"!=typeof n)throw new Error;var r=Xs(t);return this.tween(e,(r.local?Rn:Ln)(r,n))},style:function(t,n,e){var r="transform"==(t+="")?vl:$l;return null==n?this.styleTween(t,jn(t,r)).on("end.style."+t,Hn(t)):this.styleTween(t,"function"==typeof n?$n(t,r,kn(this,"style."+t,n)):Xn(t,r,n+""),e)},styleTween:function(t,n,e){var r="style."+(t+="");if(arguments.length<2)return(r=this.tween(r))&&r._value;if(null==n)return this.tween(r,null);if("function"!=typeof n)throw new Error;return this.tween(r,Vn(t,n,null==e?"":e))},text:function(t){return this.tween("text","function"==typeof t?Zn(kn(this,"text",t)):Wn(null==t?"":t+""))},remove:function(){return this.on("end.remove",Bn(this._id))},tween:function(t,n){var e=this._id;if(t+="",arguments.length<2){for(var r,i=wn(this.node(),e).tween,o=0,u=i.length;o<u;++o)if((r=i[o]).name===t)return r.value;return null}return this.each((null==n?Tn:Nn)(e,t,n))},delay:function(t){var n=this._id;return arguments.length?this.each(("function"==typeof t?qn:Un)(n,t)):wn(this.node(),n).delay},duration:function(t){var n=this._id;return arguments.length?this.each(("function"==typeof t?Dn:On)(n,t)):wn(this.node(),n).duration},ease:function(t){var n=this._id;return arguments.length?this.each(Fn(n,t)):wn(this.node(),n).ease}};var Gl=function t(n){function e(t){return Math.pow(t,n)}return n=+n,e.exponent=t,e}(3),Jl=function t(n){function e(t){return 1-Math.pow(1-t,n)}return n=+n,e.exponent=t,e}(3),Ql=function t(n){function e(t){return((t*=2)<=1?Math.pow(t,n):2-Math.pow(2-t,n))/2}return n=+n,e.exponent=t,e}(3),Kl=Math.PI,th=Kl/2,nh=4/11,eh=6/11,rh=8/11,ih=.75,oh=9/11,uh=10/11,ah=.9375,ch=21/22,sh=63/64,fh=1/nh/nh,lh=function t(n){function e(t){return t*t*((n+1)*t-n)}return n=+n,e.overshoot=t,e}(1.70158),hh=function t(n){function e(t){return--t*t*((n+1)*t+n)+1}return n=+n,e.overshoot=t,e}(1.70158),ph=function t(n){function e(t){return((t*=2)<1?t*t*((n+1)*t-n):(t-=2)*t*((n+1)*t+n)+2)/2}return n=+n,e.overshoot=t,e}(1.70158),dh=2*Math.PI,vh=function t(n,e){function r(t){return n*Math.pow(2,10*--t)*Math.sin((i-t)/e)}var i=Math.asin(1/(n=Math.max(1,n)))*(e/=dh);return r.amplitude=function(n){return t(n,e*dh)},r.period=function(e){return t(n,e)},r}(1,.3),_h=function t(n,e){function r(t){return 1-n*Math.pow(2,-10*(t=+t))*Math.sin((t+i)/e)}var i=Math.asin(1/(n=Math.max(1,n)))*(e/=dh);return r.amplitude=function(n){return t(n,e*dh)},r.period=function(e){return t(n,e)},r}(1,.3),gh=function t(n,e){function r(t){return((t=2*t-1)<0?n*Math.pow(2,10*t)*Math.sin((i-t)/e):2-n*Math.pow(2,-10*t)*Math.sin((i+t)/e))/2}var i=Math.asin(1/(n=Math.max(1,n)))*(e/=dh);return r.amplitude=function(n){return t(n,e*dh)},r.period=function(e){return t(n,e)},r}(1,.3),yh={time:null,delay:0,duration:250,ease:te};dt.prototype.interrupt=function(t){return this.each(function(){Xl(this,t)})},dt.prototype.transition=function(t){var n,e;t instanceof Gn?(n=t._id,t=t._name):(n=Qn(),(e=yh).time=ln(),t=null==t?null:t+"");for(var r=this._groups,i=r.length,o=0;o<i;++o)for(var u,a=r[o],c=a.length,s=0;s<c;++s)(u=a[s])&&Hl(u,t,n,s,a,e||oe(u,n));return new Gn(r,this._parents,t,n)};var mh=[null],xh=function(t){return function(){return t}},bh=function(t,n,e){this.target=t,this.type=n,this.selection=e},wh=function(){t.event.preventDefault(),t.event.stopImmediatePropagation()},Mh={name:"drag"},Th={name:"space"},Nh={name:"handle"},kh={name:"center"},Sh={name:"x",handles:["e","w"].map(ae),input:function(t,n){return t&&[[t[0],n[0][1]],[t[1],n[1][1]]]},output:function(t){return t&&[t[0][0],t[1][0]]}},Eh={name:"y",handles:["n","s"].map(ae),input:function(t,n){return t&&[[n[0][0],t[0]],[n[1][0],t[1]]]},output:function(t){return t&&[t[0][1],t[1][1]]}},Ah={name:"xy",handles:["n","e","s","w","nw","ne","se","sw"].map(ae),input:function(t){return t},output:function(t){return t}},Ch={overlay:"crosshair",selection:"move",n:"ns-resize",e:"ew-resize",s:"ns-resize",w:"ew-resize",nw:"nwse-resize",ne:"nesw-resize",se:"nwse-resize",sw:"nesw-resize"},zh={e:"w",w:"e",nw:"ne",ne:"nw",se:"sw",sw:"se"},Ph={n:"s",s:"n",nw:"sw",ne:"se",se:"ne",sw:"nw"},Rh={overlay:1,selection:1,n:null,e:1,s:null,w:-1,nw:-1,ne:1,se:1,sw:-1},Lh={overlay:1,selection:1,n:-1,e:null,s:1,w:null,nw:-1,ne:-1,se:1,sw:1},qh=Math.cos,Uh=Math.sin,Dh=Math.PI,Oh=Dh/2,Fh=2*Dh,Ih=Math.max,Yh=Array.prototype.slice,Bh=function(t){return function(){return t}},jh=Math.PI,Hh=2*jh,Xh=Hh-1e-6;de.prototype=ve.prototype={constructor:de,moveTo:function(t,n){this._+="M"+(this._x0=this._x1=+t)+","+(this._y0=this._y1=+n)},closePath:function(){null!==this._x1&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")},lineTo:function(t,n){this._+="L"+(this._x1=+t)+","+(this._y1=+n)},quadraticCurveTo:function(t,n,e,r){this._+="Q"+ +t+","+ +n+","+(this._x1=+e)+","+(this._y1=+r)},bezierCurveTo:function(t,n,e,r,i,o){this._+="C"+ +t+","+ +n+","+ +e+","+ +r+","+(this._x1=+i)+","+(this._y1=+o)},arcTo:function(t,n,e,r,i){t=+t,n=+n,e=+e,r=+r,i=+i;var o=this._x1,u=this._y1,a=e-t,c=r-n,s=o-t,f=u-n,l=s*s+f*f;if(i<0)throw new Error("negative radius: "+i);if(null===this._x1)this._+="M"+(this._x1=t)+","+(this._y1=n);else if(l>1e-6)if(Math.abs(f*a-c*s)>1e-6&&i){var h=e-o,p=r-u,d=a*a+c*c,v=h*h+p*p,_=Math.sqrt(d),g=Math.sqrt(l),y=i*Math.tan((jh-Math.acos((d+l-v)/(2*_*g)))/2),m=y/g,x=y/_;Math.abs(m-1)>1e-6&&(this._+="L"+(t+m*s)+","+(n+m*f)),this._+="A"+i+","+i+",0,0,"+ +(f*h>s*p)+","+(this._x1=t+x*a)+","+(this._y1=n+x*c)}else this._+="L"+(this._x1=t)+","+(this._y1=n);else;},arc:function(t,n,e,r,i,o){t=+t,n=+n;var u=(e=+e)*Math.cos(r),a=e*Math.sin(r),c=t+u,s=n+a,f=1^o,l=o?r-i:i-r;if(e<0)throw new Error("negative radius: "+e);null===this._x1?this._+="M"+c+","+s:(Math.abs(this._x1-c)>1e-6||Math.abs(this._y1-s)>1e-6)&&(this._+="L"+c+","+s),e&&(l<0&&(l=l%Hh+Hh),l>Xh?this._+="A"+e+","+e+",0,1,"+f+","+(t-u)+","+(n-a)+"A"+e+","+e+",0,1,"+f+","+(this._x1=c)+","+(this._y1=s):l>1e-6&&(this._+="A"+e+","+e+",0,"+ +(l>=jh)+","+f+","+(this._x1=t+e*Math.cos(i))+","+(this._y1=n+e*Math.sin(i))))},rect:function(t,n,e,r){this._+="M"+(this._x0=this._x1=+t)+","+(this._y0=this._y1=+n)+"h"+ +e+"v"+ +r+"h"+-e+"Z"},toString:function(){return this._}};be.prototype=we.prototype={constructor:be,has:function(t){return"$"+t in this},get:function(t){return this["$"+t]},set:function(t,n){return this["$"+t]=n,this},remove:function(t){var n="$"+t;return n in this&&delete this[n]},clear:function(){for(var t in this)"$"===t[0]&&delete this[t]},keys:function(){var t=[];for(var n in this)"$"===n[0]&&t.push(n.slice(1));return t},values:function(){var t=[];for(var n in this)"$"===n[0]&&t.push(this[n]);return t},entries:function(){var t=[];for(var n in this)"$"===n[0]&&t.push({key:n.slice(1),value:this[n]});return t},size:function(){var t=0;for(var n in this)"$"===n[0]&&++t;return t},empty:function(){for(var t in this)if("$"===t[0])return!1;return!0},each:function(t){for(var n in this)"$"===n[0]&&t(this[n],n.slice(1),this)}};var $h=we.prototype;Se.prototype=Ee.prototype={constructor:Se,has:$h.has,add:function(t){return t+="",this["$"+t]=t,this},remove:$h.remove,clear:$h.clear,values:$h.keys,size:$h.size,empty:$h.empty,each:$h.each};var Vh={},Wh={},Zh=34,Gh=10,Jh=13,Qh=function(t){function n(t,n){function e(){if(s)return Wh;if(f)return f=!1,Vh;var n,e,r=a;if(t.charCodeAt(r)===Zh){for(;a++<u&&t.charCodeAt(a)!==Zh||t.charCodeAt(++a)===Zh;);return(n=a)>=u?s=!0:(e=t.charCodeAt(a++))===Gh?f=!0:e===Jh&&(f=!0,t.charCodeAt(a)===Gh&&++a),t.slice(r+1,n-1).replace(/""/g,'"')}for(;a<u;){if((e=t.charCodeAt(n=a++))===Gh)f=!0;else if(e===Jh)f=!0,t.charCodeAt(a)===Gh&&++a;else if(e!==o)continue;return t.slice(r,n)}return s=!0,t.slice(r,u)}var r,i=[],u=t.length,a=0,c=0,s=u<=0,f=!1;for(t.charCodeAt(u-1)===Gh&&--u,t.charCodeAt(u-1)===Jh&&--u;(r=e())!==Wh;){for(var l=[];r!==Vh&&r!==Wh;)l.push(r),r=e();n&&null==(l=n(l,c++))||i.push(l)}return i}function e(n){return n.map(r).join(t)}function r(t){return null==t?"":i.test(t+="")?'"'+t.replace(/"/g,'""')+'"':t}var i=new RegExp('["'+t+"\n\r]"),o=t.charCodeAt(0);return{parse:function(t,e){var r,i,o=n(t,function(t,n){if(r)return r(t,n-1);i=t,r=e?Ce(t,e):Ae(t)});return o.columns=i,o},parseRows:n,format:function(n,e){return null==e&&(e=ze(n)),[e.map(r).join(t)].concat(n.map(function(n){return e.map(function(t){return r(n[t])}).join(t)})).join("\n")},formatRows:function(t){return t.map(e).join("\n")}}},Kh=Qh(","),tp=Kh.parse,np=Kh.parseRows,ep=Kh.format,rp=Kh.formatRows,ip=Qh("\t"),op=ip.parse,up=ip.parseRows,ap=ip.format,cp=ip.formatRows,sp=function(t){return function(){return t}},fp=function(){return 1e-6*(Math.random()-.5)},lp=function(t,n,e,r,i){this.node=t,this.x0=n,this.y0=e,this.x1=r,this.y1=i},hp=qe.prototype=Ue.prototype;hp.copy=function(){var t,n,e=new Ue(this._x,this._y,this._x0,this._y0,this._x1,this._y1),r=this._root;if(!r)return e;if(!r.length)return e._root=De(r),e;for(t=[{source:r,target:e._root=new Array(4)}];r=t.pop();)for(var i=0;i<4;++i)(n=r.source[i])&&(n.length?t.push({source:n,target:r.target[i]=new Array(4)}):r.target[i]=De(n));return e},hp.add=function(t){var n=+this._x.call(null,t),e=+this._y.call(null,t);return Pe(this.cover(n,e),n,e,t)},hp.addAll=function(t){var n,e,r,i,o=t.length,u=new Array(o),a=new Array(o),c=1/0,s=1/0,f=-1/0,l=-1/0;for(e=0;e<o;++e)isNaN(r=+this._x.call(null,n=t[e]))||isNaN(i=+this._y.call(null,n))||(u[e]=r,a[e]=i,r<c&&(c=r),r>f&&(f=r),i<s&&(s=i),i>l&&(l=i));for(f<c&&(c=this._x0,f=this._x1),l<s&&(s=this._y0,l=this._y1),this.cover(c,s).cover(f,l),e=0;e<o;++e)Pe(this,u[e],a[e],t[e]);return this},hp.cover=function(t,n){if(isNaN(t=+t)||isNaN(n=+n))return this;var e=this._x0,r=this._y0,i=this._x1,o=this._y1;if(isNaN(e))i=(e=Math.floor(t))+1,o=(r=Math.floor(n))+1;else{if(!(e>t||t>i||r>n||n>o))return this;var u,a,c=i-e,s=this._root;switch(a=(n<(r+o)/2)<<1|t<(e+i)/2){case 0:do{u=new Array(4),u[a]=s,s=u}while(c*=2,i=e+c,o=r+c,t>i||n>o);break;case 1:do{u=new Array(4),u[a]=s,s=u}while(c*=2,e=i-c,o=r+c,e>t||n>o);break;case 2:do{u=new Array(4),u[a]=s,s=u}while(c*=2,i=e+c,r=o-c,t>i||r>n);break;case 3:do{u=new Array(4),u[a]=s,s=u}while(c*=2,e=i-c,r=o-c,e>t||r>n)}this._root&&this._root.length&&(this._root=s)}return this._x0=e,this._y0=r,this._x1=i,this._y1=o,this},hp.data=function(){var t=[];return this.visit(function(n){if(!n.length)do{t.push(n.data)}while(n=n.next)}),t},hp.extent=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]]},hp.find=function(t,n,e){var r,i,o,u,a,c,s,f=this._x0,l=this._y0,h=this._x1,p=this._y1,d=[],v=this._root;for(v&&d.push(new lp(v,f,l,h,p)),null==e?e=1/0:(f=t-e,l=n-e,h=t+e,p=n+e,e*=e);c=d.pop();)if(!(!(v=c.node)||(i=c.x0)>h||(o=c.y0)>p||(u=c.x1)<f||(a=c.y1)<l))if(v.length){var _=(i+u)/2,g=(o+a)/2;d.push(new lp(v[3],_,g,u,a),new lp(v[2],i,g,_,a),new lp(v[1],_,o,u,g),new lp(v[0],i,o,_,g)),(s=(n>=g)<<1|t>=_)&&(c=d[d.length-1],d[d.length-1]=d[d.length-1-s],d[d.length-1-s]=c)}else{var y=t-+this._x.call(null,v.data),m=n-+this._y.call(null,v.data),x=y*y+m*m;if(x<e){var b=Math.sqrt(e=x);f=t-b,l=n-b,h=t+b,p=n+b,r=v.data}}return r},hp.remove=function(t){if(isNaN(o=+this._x.call(null,t))||isNaN(u=+this._y.call(null,t)))return this;var n,e,r,i,o,u,a,c,s,f,l,h,p=this._root,d=this._x0,v=this._y0,_=this._x1,g=this._y1;if(!p)return this;if(p.length)for(;;){if((s=o>=(a=(d+_)/2))?d=a:_=a,(f=u>=(c=(v+g)/2))?v=c:g=c,n=p,!(p=p[l=f<<1|s]))return this;if(!p.length)break;(n[l+1&3]||n[l+2&3]||n[l+3&3])&&(e=n,h=l)}for(;p.data!==t;)if(r=p,!(p=p.next))return this;return(i=p.next)&&delete p.next,r?(i?r.next=i:delete r.next,this):n?(i?n[l]=i:delete n[l],(p=n[0]||n[1]||n[2]||n[3])&&p===(n[3]||n[2]||n[1]||n[0])&&!p.length&&(e?e[h]=p:this._root=p),this):(this._root=i,this)},hp.removeAll=function(t){for(var n=0,e=t.length;n<e;++n)this.remove(t[n]);return this},hp.root=function(){return this._root},hp.size=function(){var t=0;return this.visit(function(n){if(!n.length)do{++t}while(n=n.next)}),t},hp.visit=function(t){var n,e,r,i,o,u,a=[],c=this._root;for(c&&a.push(new lp(c,this._x0,this._y0,this._x1,this._y1));n=a.pop();)if(!t(c=n.node,r=n.x0,i=n.y0,o=n.x1,u=n.y1)&&c.length){var s=(r+o)/2,f=(i+u)/2;(e=c[3])&&a.push(new lp(e,s,f,o,u)),(e=c[2])&&a.push(new lp(e,r,f,s,u)),(e=c[1])&&a.push(new lp(e,s,i,o,f)),(e=c[0])&&a.push(new lp(e,r,i,s,f))}return this},hp.visitAfter=function(t){var n,e=[],r=[];for(this._root&&e.push(new lp(this._root,this._x0,this._y0,this._x1,this._y1));n=e.pop();){var i=n.node;if(i.length){var o,u=n.x0,a=n.y0,c=n.x1,s=n.y1,f=(u+c)/2,l=(a+s)/2;(o=i[0])&&e.push(new lp(o,u,a,f,l)),(o=i[1])&&e.push(new lp(o,f,a,c,l)),(o=i[2])&&e.push(new lp(o,u,l,f,s)),(o=i[3])&&e.push(new lp(o,f,l,c,s))}r.push(n)}for(;n=r.pop();)t(n.node,n.x0,n.y0,n.x1,n.y1);return this},hp.x=function(t){return arguments.length?(this._x=t,this):this._x},hp.y=function(t){return arguments.length?(this._y=t,this):this._y};var pp,dp=10,vp=Math.PI*(3-Math.sqrt(5)),_p=function(t,n){if((e=(t=n?t.toExponential(n-1):t.toExponential()).indexOf("e"))<0)return null;var e,r=t.slice(0,e);return[r.length>1?r[0]+r.slice(2):r,+t.slice(e+1)]},gp=function(t){return(t=_p(Math.abs(t)))?t[1]:NaN},yp=function(t,n){return function(e,r){for(var i=e.length,o=[],u=0,a=t[0],c=0;i>0&&a>0&&(c+a+1>r&&(a=Math.max(1,r-c)),o.push(e.substring(i-=a,i+a)),!((c+=a+1)>r));)a=t[u=(u+1)%t.length];return o.reverse().join(n)}},mp=function(t){return function(n){return n.replace(/[0-9]/g,function(n){return t[+n]})}},xp=function(t,n){var e=_p(t,n);if(!e)return t+"";var r=e[0],i=e[1];return i<0?"0."+new Array(-i).join("0")+r:r.length>i+1?r.slice(0,i+1)+"."+r.slice(i+1):r+new Array(i-r.length+2).join("0")},bp={"":function(t,n){t:for(var e,r=(t=t.toPrecision(n)).length,i=1,o=-1;i<r;++i)switch(t[i]){case".":o=e=i;break;case"0":0===o&&(o=i),e=i;break;case"e":break t;default:o>0&&(o=0)}return o>0?t.slice(0,o)+t.slice(e+1):t},"%":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 xp(100*t,n)},r:xp,s:function(t,n){var e=_p(t,n);if(!e)return t+"";var r=e[0],i=e[1],o=i-(pp=3*Math.max(-8,Math.min(8,Math.floor(i/3))))+1,u=r.length;return o===u?r:o>u?r+new Array(o-u+1).join("0"):o>0?r.slice(0,o)+"."+r.slice(o):"0."+new Array(1-o).join("0")+_p(t,Math.max(0,n+o-1))[0]},X:function(t){return Math.round(t).toString(16).toUpperCase()},x:function(t){return Math.round(t).toString(16)}},wp=/^(?:(.)?([<>=^]))?([+\-\( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?([a-z%])?$/i;He.prototype=Xe.prototype,Xe.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};var Mp,Tp=function(t){return t},Np=["y","z","a","f","p","n","µ","m","","k","M","G","T","P","E","Z","Y"],kp=function(t){function n(t){function n(t){var n,r,u,f=_,x=g;if("c"===v)x=y(t)+x,t="";else{var b=(t=+t)<0;if(t=y(Math.abs(t),d),b&&0==+t&&(b=!1),f=(b?"("===s?s:"-":"-"===s||"("===s?"":s)+f,x=x+("s"===v?Np[8+pp/3]:"")+(b&&"("===s?")":""),m)for(n=-1,r=t.length;++n<r;)if(48>(u=t.charCodeAt(n))||u>57){x=(46===u?i+t.slice(n+1):t.slice(n))+x,t=t.slice(0,n);break}}p&&!l&&(t=e(t,1/0));var w=f.length+t.length+x.length,M=w<h?new Array(h-w+1).join(a):"";switch(p&&l&&(t=e(M+t,M.length?h-x.length:1/0),M=""),c){case"<":t=f+t+x+M;break;case"=":t=f+M+t+x;break;case"^":t=M.slice(0,w=M.length>>1)+f+t+x+M.slice(w);break;default:t=M+f+t+x}return o(t)}var a=(t=He(t)).fill,c=t.align,s=t.sign,f=t.symbol,l=t.zero,h=t.width,p=t.comma,d=t.precision,v=t.type,_="$"===f?r[0]:"#"===f&&/[boxX]/.test(v)?"0"+v.toLowerCase():"",g="$"===f?r[1]:/[%p]/.test(v)?u:"",y=bp[v],m=!v||/[defgprs%]/.test(v);return d=null==d?v?6:12:/[gprs]/.test(v)?Math.max(1,Math.min(21,d)):Math.max(0,Math.min(20,d)),n.toString=function(){return t+""},n}var e=t.grouping&&t.thousands?yp(t.grouping,t.thousands):Tp,r=t.currency,i=t.decimal,o=t.numerals?mp(t.numerals):Tp,u=t.percent||"%";return{format:n,formatPrefix:function(t,e){var r=n((t=He(t),t.type="f",t)),i=3*Math.max(-8,Math.min(8,Math.floor(gp(e)/3))),o=Math.pow(10,-i),u=Np[8+i/3];return function(t){return r(o*t)+u}}}};$e({decimal:".",thousands:",",grouping:[3],currency:["$",""]});var Sp=function(t){return Math.max(0,-gp(Math.abs(t)))},Ep=function(t,n){return Math.max(0,3*Math.max(-8,Math.min(8,Math.floor(gp(n)/3)))-gp(Math.abs(t)))},Ap=function(t,n){return t=Math.abs(t),n=Math.abs(n)-t,Math.max(0,gp(n)-gp(t))+1},Cp=function(){return new Ve};Ve.prototype={constructor:Ve,reset:function(){this.s=this.t=0},add:function(t){We(cd,t,this.t),We(this,cd.s,this.s),this.s?this.t+=cd.t:this.s=cd.t},valueOf:function(){return this.s}};var zp,Pp,Rp,Lp,qp,Up,Dp,Op,Fp,Ip,Yp,Bp,jp,Hp,Xp,$p,Vp,Wp,Zp,Gp,Jp,Qp,Kp,td,nd,ed,rd,id,od,ud,ad,cd=new Ve,sd=1e-6,fd=Math.PI,ld=fd/2,hd=fd/4,pd=2*fd,dd=180/fd,vd=fd/180,_d=Math.abs,gd=Math.atan,yd=Math.atan2,md=Math.cos,xd=Math.ceil,bd=Math.exp,wd=Math.log,Md=Math.pow,Td=Math.sin,Nd=Math.sign||function(t){return t>0?1:t<0?-1:0},kd=Math.sqrt,Sd=Math.tan,Ed={Feature:function(t,n){Ke(t.geometry,n)},FeatureCollection:function(t,n){for(var e=t.features,r=-1,i=e.length;++r<i;)Ke(e[r].geometry,n)}},Ad={Sphere:function(t,n){n.sphere()},Point:function(t,n){t=t.coordinates,n.point(t[0],t[1],t[2])},MultiPoint:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)t=e[r],n.point(t[0],t[1],t[2])},LineString:function(t,n){tr(t.coordinates,n,0)},MultiLineString:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)tr(e[r],n,0)},Polygon:function(t,n){nr(t.coordinates,n)},MultiPolygon:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)nr(e[r],n)},GeometryCollection:function(t,n){for(var e=t.geometries,r=-1,i=e.length;++r<i;)Ke(e[r],n)}},Cd=function(t,n){t&&Ed.hasOwnProperty(t.type)?Ed[t.type](t,n):Ke(t,n)},zd=Cp(),Pd=Cp(),Rd={point:Qe,lineStart:Qe,lineEnd:Qe,polygonStart:function(){zd.reset(),Rd.lineStart=er,Rd.lineEnd=rr},polygonEnd:function(){var t=+zd;Pd.add(t<0?pd+t:t),this.lineStart=this.lineEnd=this.point=Qe},sphere:function(){Pd.add(pd)}},Ld=Cp(),qd={point:pr,lineStart:vr,lineEnd:_r,polygonStart:function(){qd.point=gr,qd.lineStart=yr,qd.lineEnd=mr,Ld.reset(),Rd.polygonStart()},polygonEnd:function(){Rd.polygonEnd(),qd.point=pr,qd.lineStart=vr,qd.lineEnd=_r,zd<0?(Up=-(Op=180),Dp=-(Fp=90)):Ld>sd?Fp=90:Ld<-sd&&(Dp=-90),Xp[0]=Up,Xp[1]=Op}},Ud={sphere:Qe,point:Mr,lineStart:Nr,lineEnd:Er,polygonStart:function(){Ud.lineStart=Ar,Ud.lineEnd=Cr},polygonEnd:function(){Ud.lineStart=Nr,Ud.lineEnd=Er}},Dd=function(t){return function(){return t}},Od=function(t,n){function e(e,r){return e=t(e,r),n(e[0],e[1])}return t.invert&&n.invert&&(e.invert=function(e,r){return(e=n.invert(e,r))&&t.invert(e[0],e[1])}),e};Rr.invert=Rr;var Fd,Id,Yd,Bd,jd,Hd,Xd,$d,Vd,Wd,Zd,Gd=function(t){function n(n){return n=t(n[0]*vd,n[1]*vd),n[0]*=dd,n[1]*=dd,n}return t=Lr(t[0]*vd,t[1]*vd,t.length>2?t[2]*vd:0),n.invert=function(n){return n=t.invert(n[0]*vd,n[1]*vd),n[0]*=dd,n[1]*=dd,n},n},Jd=function(){var t,n=[];return{point:function(n,e){t.push([n,e])},lineStart:function(){n.push(t=[])},lineEnd:Qe,rejoin:function(){n.length>1&&n.push(n.pop().concat(n.shift()))},result:function(){var e=n;return n=[],t=null,e}}},Qd=function(t,n){return _d(t[0]-n[0])<sd&&_d(t[1]-n[1])<sd},Kd=function(t,n,e,r,i){var o,u,a=[],c=[];if(t.forEach(function(t){if(!((n=t.length-1)<=0)){var n,e,r=t[0],u=t[n];if(Qd(r,u)){for(i.lineStart(),o=0;o<n;++o)i.point((r=t[o])[0],r[1]);i.lineEnd()}else a.push(e=new Ir(r,t,null,!0)),c.push(e.o=new Ir(r,null,e,!1)),a.push(e=new Ir(u,t,null,!1)),c.push(e.o=new Ir(u,null,e,!0))}}),a.length){for(c.sort(n),Yr(a),Yr(c),o=0,u=c.length;o<u;++o)c[o].e=e=!e;for(var s,f,l=a[0];;){for(var h=l,p=!0;h.v;)if((h=h.n)===l)return;s=h.z,i.lineStart();do{if(h.v=h.o.v=!0,h.e){if(p)for(o=0,u=s.length;o<u;++o)i.point((f=s[o])[0],f[1]);else r(h.x,h.n.x,1,i);h=h.n}else{if(p)for(s=h.p.z,o=s.length-1;o>=0;--o)i.point((f=s[o])[0],f[1]);else r(h.x,h.p.x,-1,i);h=h.p}s=(h=h.o).z,p=!p}while(!h.v);i.lineEnd()}}},tv=Cp(),nv=function(t,n){var e=n[0],r=n[1],i=[Td(e),-md(e),0],o=0,u=0;tv.reset();for(var a=0,c=t.length;a<c;++a)if(f=(s=t[a]).length)for(var s,f,l=s[f-1],h=l[0],p=l[1]/2+hd,d=Td(p),v=md(p),_=0;_<f;++_,h=y,d=x,v=b,l=g){var g=s[_],y=g[0],m=g[1]/2+hd,x=Td(m),b=md(m),w=y-h,M=w>=0?1:-1,T=M*w,N=T>fd,k=d*x;if(tv.add(yd(k*M*Td(T),v*b+k*md(T))),o+=N?w+M*pd:w,N^h>=e^y>=e){var S=sr(ar(l),ar(g));hr(S);var E=sr(i,S);hr(E);var A=(N^w>=0?-1:1)*Ge(E[2]);(r>A||r===A&&(S[0]||S[1]))&&(u+=N^w>=0?1:-1)}}return(o<-sd||o<sd&&tv<-sd)^1&u},ev=function(t,n,e,r){return function(i){function o(n,e){t(n,e)&&i.point(n,e)}function u(t,n){v.point(t,n)}function a(){m.point=u,v.lineStart()}function c(){m.point=o,v.lineEnd()}function s(t,n){d.push([t,n]),g.point(t,n)}function f(){g.lineStart(),d=[]}function l(){s(d[0][0],d[0][1]),g.lineEnd();var t,n,e,r,o=g.clean(),u=_.result(),a=u.length;if(d.pop(),h.push(d),d=null,a)if(1&o){if(e=u[0],(n=e.length-1)>0){for(y||(i.polygonStart(),y=!0),i.lineStart(),t=0;t<n;++t)i.point((r=e[t])[0],r[1]);i.lineEnd()}}else a>1&&2&o&&u.push(u.pop().concat(u.shift())),p.push(u.filter(Br))}var h,p,d,v=n(i),_=Jd(),g=n(_),y=!1,m={point:o,lineStart:a,lineEnd:c,polygonStart:function(){m.point=s,m.lineStart=f,m.lineEnd=l,p=[],h=[]},polygonEnd:function(){m.point=o,m.lineStart=a,m.lineEnd=c,p=Ps(p);var t=nv(h,r);p.length?(y||(i.polygonStart(),y=!0),Kd(p,jr,t,e,i)):t&&(y||(i.polygonStart(),y=!0),i.lineStart(),e(null,null,1,i),i.lineEnd()),y&&(i.polygonEnd(),y=!1),p=h=null},sphere:function(){i.polygonStart(),i.lineStart(),e(null,null,1,i),i.lineEnd(),i.polygonEnd()}};return m}},rv=ev(function(){return!0},function(t){var n,e=NaN,r=NaN,i=NaN;return{lineStart:function(){t.lineStart(),n=1},point:function(o,u){var a=o>0?fd:-fd,c=_d(o-e);_d(c-fd)<sd?(t.point(e,r=(r+u)/2>0?ld:-ld),t.point(i,r),t.lineEnd(),t.lineStart(),t.point(a,r),t.point(o,r),n=0):i!==a&&c>=fd&&(_d(e-i)<sd&&(e-=i*sd),_d(o-a)<sd&&(o-=a*sd),r=Hr(e,r,o,u),t.point(i,r),t.lineEnd(),t.lineStart(),t.point(a,r),n=0),t.point(e=o,r=u),i=a},lineEnd:function(){t.lineEnd(),e=r=NaN},clean:function(){return 2-n}}},function(t,n,e,r){var i;if(null==t)i=e*ld,r.point(-fd,i),r.point(0,i),r.point(fd,i),r.point(fd,0),r.point(fd,-i),r.point(0,-i),r.point(-fd,-i),r.point(-fd,0),r.point(-fd,i);else if(_d(t[0]-n[0])>sd){var o=t[0]<n[0]?fd:-fd;i=e*o/2,r.point(-o,i),r.point(0,i),r.point(o,i)}else r.point(n[0],n[1])},[-fd,-ld]),iv=function(t){function n(t,n){return md(t)*md(n)>i}function e(t,n,e){var r=[1,0,0],o=sr(ar(t),ar(n)),u=cr(o,o),a=o[0],c=u-a*a;if(!c)return!e&&t;var s=i*u/c,f=-i*a/c,l=sr(r,o),h=lr(r,s);fr(h,lr(o,f));var p=l,d=cr(h,p),v=cr(p,p),_=d*d-v*(cr(h,h)-1);if(!(_<0)){var g=kd(_),y=lr(p,(-d-g)/v);if(fr(y,h),y=ur(y),!e)return y;var m,x=t[0],b=n[0],w=t[1],M=n[1];b<x&&(m=x,x=b,b=m);var T=b-x,N=_d(T-fd)<sd,k=N||T<sd;if(!N&&M<w&&(m=w,w=M,M=m),k?N?w+M>0^y[1]<(_d(y[0]-x)<sd?w:M):w<=y[1]&&y[1]<=M:T>fd^(x<=y[0]&&y[0]<=b)){var S=lr(p,(-d+g)/v);return fr(S,h),[y,ur(S)]}}}function r(n,e){var r=u?t:fd-t,i=0;return n<-r?i|=1:n>r&&(i|=2),e<-r?i|=4:e>r&&(i|=8),i}var i=md(t),o=6*vd,u=i>0,a=_d(i)>sd;return ev(n,function(t){var i,o,c,s,f;return{lineStart:function(){s=c=!1,f=1},point:function(l,h){var p,d=[l,h],v=n(l,h),_=u?v?0:r(l,h):v?r(l+(l<0?fd:-fd),h):0;if(!i&&(s=c=v)&&t.lineStart(),v!==c&&(!(p=e(i,d))||Qd(i,p)||Qd(d,p))&&(d[0]+=sd,d[1]+=sd,v=n(d[0],d[1])),v!==c)f=0,v?(t.lineStart(),p=e(d,i),t.point(p[0],p[1])):(p=e(i,d),t.point(p[0],p[1]),t.lineEnd()),i=p;else if(a&&i&&u^v){var g;_&o||!(g=e(d,i,!0))||(f=0,u?(t.lineStart(),t.point(g[0][0],g[0][1]),t.point(g[1][0],g[1][1]),t.lineEnd()):(t.point(g[1][0],g[1][1]),t.lineEnd(),t.lineStart(),t.point(g[0][0],g[0][1])))}!v||i&&Qd(i,d)||t.point(d[0],d[1]),i=d,c=v,o=_},lineEnd:function(){c&&t.lineEnd(),i=null},clean:function(){return f|(s&&c)<<1}}},function(n,e,r,i){Or(i,t,o,r,n,e)},u?[0,-t]:[-fd,t-fd])},ov=function(t,n,e,r,i,o){var u,a=t[0],c=t[1],s=0,f=1,l=n[0]-a,h=n[1]-c;if(u=e-a,l||!(u>0)){if(u/=l,l<0){if(u<s)return;u<f&&(f=u)}else if(l>0){if(u>f)return;u>s&&(s=u)}if(u=i-a,l||!(u<0)){if(u/=l,l<0){if(u>f)return;u>s&&(s=u)}else if(l>0){if(u<s)return;u<f&&(f=u)}if(u=r-c,h||!(u>0)){if(u/=h,h<0){if(u<s)return;u<f&&(f=u)}else if(h>0){if(u>f)return;u>s&&(s=u)}if(u=o-c,h||!(u<0)){if(u/=h,h<0){if(u>f)return;u>s&&(s=u)}else if(h>0){if(u<s)return;u<f&&(f=u)}return s>0&&(t[0]=a+s*l,t[1]=c+s*h),f<1&&(n[0]=a+f*l,n[1]=c+f*h),!0}}}}},uv=1e9,av=-uv,cv=Cp(),sv={sphere:Qe,point:Qe,lineStart:function(){sv.point=Vr,sv.lineEnd=$r},lineEnd:Qe,polygonStart:Qe,polygonEnd:Qe},fv=function(t){return cv.reset(),Cd(t,sv),+cv},lv=[null,null],hv={type:"LineString",coordinates:lv},pv=function(t,n){return lv[0]=t,lv[1]=n,fv(hv)},dv={Feature:function(t,n){return Zr(t.geometry,n)},FeatureCollection:function(t,n){for(var e=t.features,r=-1,i=e.length;++r<i;)if(Zr(e[r].geometry,n))return!0;return!1}},vv={Sphere:function(){return!0},Point:function(t,n){return Gr(t.coordinates,n)},MultiPoint:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)if(Gr(e[r],n))return!0;return!1},LineString:function(t,n){return Jr(t.coordinates,n)},MultiLineString:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)if(Jr(e[r],n))return!0;return!1},Polygon:function(t,n){return Qr(t.coordinates,n)},MultiPolygon:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)if(Qr(e[r],n))return!0;return!1},GeometryCollection:function(t,n){for(var e=t.geometries,r=-1,i=e.length;++r<i;)if(Zr(e[r],n))return!0;return!1}},_v=function(t){return t},gv=Cp(),yv=Cp(),mv={point:Qe,lineStart:Qe,lineEnd:Qe,polygonStart:function(){mv.lineStart=ii,mv.lineEnd=ai},polygonEnd:function(){mv.lineStart=mv.lineEnd=mv.point=Qe,gv.add(_d(yv)),yv.reset()},result:function(){var t=gv/2;return gv.reset(),t}},xv=1/0,bv=xv,wv=-xv,Mv=wv,Tv={point:function(t,n){t<xv&&(xv=t),t>wv&&(wv=t),n<bv&&(bv=n),n>Mv&&(Mv=n)},lineStart:Qe,lineEnd:Qe,polygonStart:Qe,polygonEnd:Qe,result:function(){var t=[[xv,bv],[wv,Mv]];return wv=Mv=-(bv=xv=1/0),t}},Nv=0,kv=0,Sv=0,Ev=0,Av=0,Cv=0,zv=0,Pv=0,Rv=0,Lv={point:ci,lineStart:si,lineEnd:hi,polygonStart:function(){Lv.lineStart=pi,Lv.lineEnd=di},polygonEnd:function(){Lv.point=ci,Lv.lineStart=si,Lv.lineEnd=hi},result:function(){var t=Rv?[zv/Rv,Pv/Rv]:Cv?[Ev/Cv,Av/Cv]:Sv?[Nv/Sv,kv/Sv]:[NaN,NaN];return Nv=kv=Sv=Ev=Av=Cv=zv=Pv=Rv=0,t}};gi.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,pd)}},result:Qe};var qv,Uv,Dv,Ov,Fv,Iv=Cp(),Yv={point:Qe,lineStart:function(){Yv.point=yi},lineEnd:function(){qv&&mi(Uv,Dv),Yv.point=Qe},polygonStart:function(){qv=!0},polygonEnd:function(){qv=null},result:function(){var t=+Iv;return Iv.reset(),t}};xi.prototype={_radius:4.5,_circle:bi(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=bi(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}};Mi.prototype={constructor:Mi,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()}};var Bv=16,jv=md(30*vd),Hv=function(t,n){return+n?Si(t,n):ki(t)},Xv=wi({point:function(t,n){this.stream.point(t*vd,n*vd)}}),$v=function(){return zi(Ri).scale(155.424).center([0,33.6442])},Vv=function(){return $v().parallels([29.5,45.5]).scale(1070).translate([480,250]).rotate([96,0]).center([-.6,38.7])},Wv=qi(function(t){return kd(2/(1+t))});Wv.invert=Ui(function(t){return 2*Ge(t/2)});var Zv=qi(function(t){return(t=Ze(t))&&t/Td(t)});Zv.invert=Ui(function(t){return t});Di.invert=function(t,n){return[t,2*gd(bd(n))-ld]};Yi.invert=Yi;ji.invert=Ui(gd);Xi.invert=function(t,n){var e,r=n,i=25;do{var o=r*r,u=o*o;r-=e=(r*(1.007226+o*(.015085+u*(.028874*o-.044475-.005916*u)))-n)/(1.007226+o*(.045255+u*(.259866*o-.311325-.005916*11*u)))}while(_d(e)>sd&&--i>0);return[t/(.8707+(o=r*r)*(o*(o*o*o*(.003971-.001529*o)-.013791)-.131979)),r]};$i.invert=Ui(Ge);Vi.invert=Ui(function(t){return 2*gd(t)});Wi.invert=function(t,n){return[-n,2*gd(bd(t))-ld]};co.prototype=io.prototype={constructor:co,count:function(){return this.eachAfter(eo)},each:function(t){var n,e,r,i,o=this,u=[o];do{for(n=u.reverse(),u=[];o=n.pop();)if(t(o),e=o.children)for(r=0,i=e.length;r<i;++r)u.push(e[r])}while(u.length);return this},eachAfter:function(t){for(var n,e,r,i=this,o=[i],u=[];i=o.pop();)if(u.push(i),n=i.children)for(e=0,r=n.length;e<r;++e)o.push(n[e]);for(;i=u.pop();)t(i);return this},eachBefore:function(t){for(var n,e,r=this,i=[r];r=i.pop();)if(t(r),n=r.children)for(e=n.length-1;e>=0;--e)i.push(n[e]);return this},sum:function(t){return this.eachAfter(function(n){for(var e=+t(n.data)||0,r=n.children,i=r&&r.length;--i>=0;)e+=r[i].value;n.value=e})},sort:function(t){return this.eachBefore(function(n){n.children&&n.children.sort(t)})},path:function(t){for(var n=this,e=ro(n,t),r=[n];n!==e;)n=n.parent,r.push(n);for(var i=r.length;t!==e;)r.splice(i,0,t),t=t.parent;return r},ancestors:function(){for(var t=this,n=[t];t=t.parent;)n.push(t);return n},descendants:function(){var t=[];return this.each(function(n){t.push(n)}),t},leaves:function(){var t=[];return this.eachBefore(function(n){n.children||t.push(n)}),t},links:function(){var t=this,n=[];return t.each(function(e){e!==t&&n.push({source:e.parent,target:e})}),n},copy:function(){return io(this).eachBefore(uo)}};var Gv=Array.prototype.slice,Jv=function(t){for(var n,e,r=0,i=(t=so(Gv.call(t))).length,o=[];r<i;)n=t[r],e&&ho(e,n)?++r:(e=vo(o=fo(o,n)),r=0);return e},Qv=function(t){return function(){return t}},Kv=function(t){t.x0=Math.round(t.x0),t.y0=Math.round(t.y0),t.x1=Math.round(t.x1),t.y1=Math.round(t.y1)},t_=function(t,n,e,r,i){for(var o,u=t.children,a=-1,c=u.length,s=t.value&&(r-n)/t.value;++a<c;)(o=u[a]).y0=e,o.y1=i,o.x0=n,o.x1=n+=o.value*s},n_="$",e_={depth:-1},r_={};Fo.prototype=Object.create(co.prototype);var i_=function(t,n,e,r,i){for(var o,u=t.children,a=-1,c=u.length,s=t.value&&(i-e)/t.value;++a<c;)(o=u[a]).x0=n,o.x1=r,o.y0=e,o.y1=e+=o.value*s},o_=(1+Math.sqrt(5))/2,u_=function t(n){function e(t,e,r,i,o){Yo(n,t,e,r,i,o)}return e.ratio=function(n){return t((n=+n)>1?n:1)},e}(o_),a_=function t(n){function e(t,e,r,i,o){if((u=t._squarify)&&u.ratio===n)for(var u,a,c,s,f,l=-1,h=u.length,p=t.value;++l<h;){for(c=(a=u[l]).children,s=a.value=0,f=c.length;s<f;++s)a.value+=c[s].value;a.dice?t_(a,e,r,i,r+=(o-r)*a.value/p):i_(a,e,r,e+=(i-e)*a.value/p,o),p-=a.value}else t._squarify=u=Yo(n,t,e,r,i,o),u.ratio=n}return e.ratio=function(n){return t((n=+n)>1?n:1)},e}(o_),c_=function(t,n,e){return(n[0]-t[0])*(e[1]-t[1])-(n[1]-t[1])*(e[0]-t[0])},s_=[].slice,f_={};Ho.prototype=Go.prototype={constructor:Ho,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_.call(arguments,1);return n.push(t),++this._waiting,this._tasks.push(n),Xo(this),this},abort:function(){return null==this._error&&Wo(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,e){t.apply(null,[n].concat(e))},Zo(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,Zo(this),this}};var l_=function(){return Math.random()},h_=function t(n){function e(t,e){return t=null==t?0:+t,e=null==e?1:+e,1===arguments.length?(e=t,t=0):e-=t,function(){return n()*e+t}}return e.source=t,e}(l_),p_=function t(n){function e(t,e){var r,i;return t=null==t?0:+t,e=null==e?1:+e,function(){var o;if(null!=r)o=r,r=null;else do{r=2*n()-1,o=2*n()-1,i=r*r+o*o}while(!i||i>1);return t+e*o*Math.sqrt(-2*Math.log(i)/i)}}return e.source=t,e}(l_),d_=function t(n){function e(){var t=p_.source(n).apply(this,arguments);return function(){return Math.exp(t())}}return e.source=t,e}(l_),v_=function t(n){function e(t){return function(){for(var e=0,r=0;r<t;++r)e+=n();return e}}return e.source=t,e}(l_),__=function t(n){function e(t){var e=v_.source(n)(t);return function(){return e()/t}}return e.source=t,e}(l_),g_=function t(n){function e(t){return function(){return-Math.log(1-n())/t}}return e.source=t,e}(l_),y_=function(t,n){function e(t){var n,e=s.status;if(!e&&Qo(s)||e>=200&&e<300||304===e){if(o)try{n=o.call(r,s)}catch(t){return void a.call("error",r,t)}else n=s;a.call("load",r,n)}else a.call("error",r,t)}var r,i,o,u,a=h("beforesend","progress","load","error"),c=we(),s=new XMLHttpRequest,f=null,l=null,p=0;if("undefined"==typeof XDomainRequest||"withCredentials"in s||!/^(http(s)?:)?\/\//.test(t)||(s=new XDomainRequest),"onload"in s?s.onload=s.onerror=s.ontimeout=e:s.onreadystatechange=function(t){s.readyState>3&&e(t)},s.onprogress=function(t){a.call("progress",r,t)},r={header:function(t,n){return t=(t+"").toLowerCase(),arguments.length<2?c.get(t):(null==n?c.remove(t):c.set(t,n+""),r)},mimeType:function(t){return arguments.length?(i=null==t?null:t+"",r):i},responseType:function(t){return arguments.length?(u=t,r):u},timeout:function(t){return arguments.length?(p=+t,r):p},user:function(t){return arguments.length<1?f:(f=null==t?null:t+"",r)},password:function(t){return arguments.length<1?l:(l=null==t?null:t+"",r)},response:function(t){return o=t,r},get:function(t,n){return r.send("GET",t,n)},post:function(t,n){return r.send("POST",t,n)},send:function(n,e,o){return s.open(n,t,!0,f,l),null==i||c.has("accept")||c.set("accept",i+",*/*"),s.setRequestHeader&&c.each(function(t,n){s.setRequestHeader(n,t)}),null!=i&&s.overrideMimeType&&s.overrideMimeType(i),null!=u&&(s.responseType=u),p>0&&(s.timeout=p),null==o&&"function"==typeof e&&(o=e,e=null),null!=o&&1===o.length&&(o=Jo(o)),null!=o&&r.on("error",o).on("load",function(t){o(null,t)}),a.call("beforesend",r,s),s.send(null==e?null:e),r},abort:function(){return s.abort(),r},on:function(){var t=a.on.apply(a,arguments);return t===a?r:t}},null!=n){if("function"!=typeof n)throw new Error("invalid callback: "+n);return r.get(n)}return r},m_=function(t,n){return function(e,r){var i=y_(e).mimeType(t).response(n);if(null!=r){if("function"!=typeof r)throw new Error("invalid callback: "+r);return i.get(r)}return i}},x_=m_("text/html",function(t){return document.createRange().createContextualFragment(t.responseText)}),b_=m_("application/json",function(t){return JSON.parse(t.responseText)}),w_=m_("text/plain",function(t){return t.responseText}),M_=m_("application/xml",function(t){var n=t.responseXML;if(!n)throw new Error("parse error");return n}),T_=function(t,n){return function(e,r,i){arguments.length<3&&(i=r,r=null);var o=y_(e).mimeType(t);return o.row=function(t){return arguments.length?o.response(Ko(n,r=t)):r},o.row(r),i?o.get(i):o}},N_=T_("text/csv",tp),k_=T_("text/tab-separated-values",op),S_=Array.prototype,E_=S_.map,A_=S_.slice,C_={name:"implicit"},z_=function(t){return function(){return t}},P_=function(t){return+t},R_=[0,1],L_=function(n,e,r){var o,u=n[0],a=n[n.length-1],c=i(u,a,null==e?10:e);switch((r=He(null==r?",f":r)).type){case"s":var s=Math.max(Math.abs(u),Math.abs(a));return null!=r.precision||isNaN(o=Ep(c,s))||(r.precision=o),t.formatPrefix(r,s);case"":case"e":case"g":case"p":case"r":null!=r.precision||isNaN(o=Ap(c,Math.max(Math.abs(u),Math.abs(a))))||(r.precision=o-("e"===r.type));break;case"f":case"%":null!=r.precision||isNaN(o=Sp(c))||(r.precision=o-2*("%"===r.type))}return t.format(r)},q_=function(t,n){var e,r=0,i=(t=t.slice()).length-1,o=t[r],u=t[i];return u<o&&(e=r,r=i,i=e,e=o,o=u,u=e),t[r]=n.floor(o),t[i]=n.ceil(u),t},U_=new Date,D_=new Date,O_=Nu(function(){},function(t,n){t.setTime(+t+n)},function(t,n){return n-t});O_.every=function(t){return t=Math.floor(t),isFinite(t)&&t>0?t>1?Nu(function(n){n.setTime(Math.floor(n/t)*t)},function(n,e){n.setTime(+n+e*t)},function(n,e){return(e-n)/t}):O_:null};var F_=O_.range,I_=6e4,Y_=6048e5,B_=Nu(function(t){t.setTime(1e3*Math.floor(t/1e3))},function(t,n){t.setTime(+t+1e3*n)},function(t,n){return(n-t)/1e3},function(t){return t.getUTCSeconds()}),j_=B_.range,H_=Nu(function(t){t.setTime(Math.floor(t/I_)*I_)},function(t,n){t.setTime(+t+n*I_)},function(t,n){return(n-t)/I_},function(t){return t.getMinutes()}),X_=H_.range,$_=Nu(function(t){var n=t.getTimezoneOffset()*I_%36e5;n<0&&(n+=36e5),t.setTime(36e5*Math.floor((+t-n)/36e5)+n)},function(t,n){t.setTime(+t+36e5*n)},function(t,n){return(n-t)/36e5},function(t){return t.getHours()}),V_=$_.range,W_=Nu(function(t){t.setHours(0,0,0,0)},function(t,n){t.setDate(t.getDate()+n)},function(t,n){return(n-t-(n.getTimezoneOffset()-t.getTimezoneOffset())*I_)/864e5},function(t){return t.getDate()-1}),Z_=W_.range,G_=ku(0),J_=ku(1),Q_=ku(2),K_=ku(3),tg=ku(4),ng=ku(5),eg=ku(6),rg=G_.range,ig=J_.range,og=Q_.range,ug=K_.range,ag=tg.range,cg=ng.range,sg=eg.range,fg=Nu(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()}),lg=fg.range,hg=Nu(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()});hg.every=function(t){return isFinite(t=Math.floor(t))&&t>0?Nu(function(n){n.setFullYear(Math.floor(n.getFullYear()/t)*t),n.setMonth(0,1),n.setHours(0,0,0,0)},function(n,e){n.setFullYear(n.getFullYear()+e*t)}):null};var pg=hg.range,dg=Nu(function(t){t.setUTCSeconds(0,0)},function(t,n){t.setTime(+t+n*I_)},function(t,n){return(n-t)/I_},function(t){return t.getUTCMinutes()}),vg=dg.range,_g=Nu(function(t){t.setUTCMinutes(0,0,0)},function(t,n){t.setTime(+t+36e5*n)},function(t,n){return(n-t)/36e5},function(t){return t.getUTCHours()}),gg=_g.range,yg=Nu(function(t){t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCDate(t.getUTCDate()+n)},function(t,n){return(n-t)/864e5},function(t){return t.getUTCDate()-1}),mg=yg.range,xg=Su(0),bg=Su(1),wg=Su(2),Mg=Su(3),Tg=Su(4),Ng=Su(5),kg=Su(6),Sg=xg.range,Eg=bg.range,Ag=wg.range,Cg=Mg.range,zg=Tg.range,Pg=Ng.range,Rg=kg.range,Lg=Nu(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()}),qg=Lg.range,Ug=Nu(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()});Ug.every=function(t){return isFinite(t=Math.floor(t))&&t>0?Nu(function(n){n.setUTCFullYear(Math.floor(n.getUTCFullYear()/t)*t),n.setUTCMonth(0,1),n.setUTCHours(0,0,0,0)},function(n,e){n.setUTCFullYear(n.getUTCFullYear()+e*t)}):null};var Dg,Og=Ug.range,Fg={"-":"",_:" ",0:"0"},Ig=/^\s*\d+/,Yg=/^%/,Bg=/[\\\^\$\*\+\?\|\[\]\(\)\.\{\}]/g;Na({dateTime:"%x, %X",date:"%-m/%-d/%Y",time:"%-I:%M:%S %p",periods:["AM","PM"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]});var jg=Date.prototype.toISOString?function(t){return t.toISOString()}:t.utcFormat("%Y-%m-%dT%H:%M:%S.%LZ"),Hg=+new Date("2000-01-01T00:00:00.000Z")?function(t){var n=new Date(t);return isNaN(n)?null:n}:t.utcParse("%Y-%m-%dT%H:%M:%S.%LZ"),Xg=1e3,$g=60*Xg,Vg=60*$g,Wg=24*Vg,Zg=7*Wg,Gg=30*Wg,Jg=365*Wg,Qg=function(t){return t.match(/.{6}/g).map(function(t){return"#"+t})},Kg=Qg("1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf"),ty=Qg("393b795254a36b6ecf9c9ede6379398ca252b5cf6bcedb9c8c6d31bd9e39e7ba52e7cb94843c39ad494ad6616be7969c7b4173a55194ce6dbdde9ed6"),ny=Qg("3182bd6baed69ecae1c6dbefe6550dfd8d3cfdae6bfdd0a231a35474c476a1d99bc7e9c0756bb19e9ac8bcbddcdadaeb636363969696bdbdbdd9d9d9"),ey=Qg("1f77b4aec7e8ff7f0effbb782ca02c98df8ad62728ff98969467bdc5b0d58c564bc49c94e377c2f7b6d27f7f7fc7c7c7bcbd22dbdb8d17becf9edae5"),ry=Tl($t(300,.5,0),$t(-240,.5,1)),iy=Tl($t(-100,.75,.35),$t(80,1.5,.8)),oy=Tl($t(260,.75,.35),$t(80,1.5,.8)),uy=$t(),ay=Aa(Qg("44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725")),cy=Aa(Qg("00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf")),sy=Aa(Qg("00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4")),fy=Aa(Qg("0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921")),ly=function(t){return function(){return t}},hy=Math.abs,py=Math.atan2,dy=Math.cos,vy=Math.max,_y=Math.min,gy=Math.sin,yy=Math.sqrt,my=1e-12,xy=Math.PI,by=xy/2,wy=2*xy;Ia.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)}}};var My=function(t){return new Ia(t)},Ty=function(){function t(t){var a,c,s,f=t.length,l=!1;for(null==i&&(u=o(s=ve())),a=0;a<=f;++a)!(a<f&&r(c=t[a],a,t))===l&&((l=!l)?u.lineStart():u.lineEnd()),l&&u.point(+n(c,a,t),+e(c,a,t));if(s)return u=null,s+""||null}var n=Ya,e=Ba,r=ly(!0),i=null,o=My,u=null;return t.x=function(e){return arguments.length?(n="function"==typeof e?e:ly(+e),t):n},t.y=function(n){return arguments.length?(e="function"==typeof n?n:ly(+n),t):e},t.defined=function(n){return arguments.length?(r="function"==typeof n?n:ly(!!n),t):r},t.curve=function(n){return arguments.length?(o=n,null!=i&&(u=o(i)),t):o},t.context=function(n){return arguments.length?(null==n?i=u=null:u=o(i=n),t):i},t},Ny=function(){function t(t){var n,f,l,h,p,d=t.length,v=!1,_=new Array(d),g=new Array(d);for(null==a&&(s=c(p=ve())),n=0;n<=d;++n){if(!(n<d&&u(h=t[n],n,t))===v)if(v=!v)f=n,s.areaStart(),s.lineStart();else{for(s.lineEnd(),s.lineStart(),l=n-1;l>=f;--l)s.point(_[l],g[l]);s.lineEnd(),s.areaEnd()}v&&(_[n]=+e(h,n,t),g[n]=+i(h,n,t),s.point(r?+r(h,n,t):_[n],o?+o(h,n,t):g[n]))}if(p)return s=null,p+""||null}function n(){return Ty().defined(u).curve(c).context(a)}var e=Ya,r=null,i=ly(0),o=Ba,u=ly(!0),a=null,c=My,s=null;return t.x=function(n){return arguments.length?(e="function"==typeof n?n:ly(+n),r=null,t):e},t.x0=function(n){return arguments.length?(e="function"==typeof n?n:ly(+n),t):e},t.x1=function(n){return arguments.length?(r=null==n?null:"function"==typeof n?n:ly(+n),t):r},t.y=function(n){return arguments.length?(i="function"==typeof n?n:ly(+n),o=null,t):i},t.y0=function(n){return arguments.length?(i="function"==typeof n?n:ly(+n),t):i},t.y1=function(n){return arguments.length?(o=null==n?null:"function"==typeof n?n:ly(+n),t):o},t.lineX0=t.lineY0=function(){return n().x(e).y(i)},t.lineY1=function(){return n().x(e).y(o)},t.lineX1=function(){return n().x(r).y(i)},t.defined=function(n){return arguments.length?(u="function"==typeof n?n:ly(!!n),t):u},t.curve=function(n){return arguments.length?(c=n,null!=a&&(s=c(a)),t):c},t.context=function(n){return arguments.length?(null==n?a=s=null:s=c(a=n),t):a},t},ky=function(t,n){return n<t?-1:n>t?1:n>=t?0:NaN},Sy=function(t){return t},Ey=Ha(My);ja.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))}};var Ay=function(){return Xa(Ty().curve(Ey))},Cy=function(){var t=Ny().curve(Ey),n=t.curve,e=t.lineX0,r=t.lineX1,i=t.lineY0,o=t.lineY1;return t.angle=t.x,delete t.x,t.startAngle=t.x0,delete t.x0,t.endAngle=t.x1,delete t.x1,t.radius=t.y,delete t.y,t.innerRadius=t.y0,delete t.y0,t.outerRadius=t.y1,delete t.y1,t.lineStartAngle=function(){return Xa(e())},delete t.lineX0,t.lineEndAngle=function(){return Xa(r())},delete t.lineX1,t.lineInnerRadius=function(){return Xa(i())},delete t.lineY0,t.lineOuterRadius=function(){return Xa(o())},delete t.lineY1,t.curve=function(t){return arguments.length?n(Ha(t)):n()._curve},t},zy=function(t,n){return[(n=+n)*Math.cos(t-=Math.PI/2),n*Math.sin(t)]},Py=Array.prototype.slice,Ry={draw:function(t,n){var e=Math.sqrt(n/xy);t.moveTo(e,0),t.arc(0,0,e,0,wy)}},Ly={draw:function(t,n){var e=Math.sqrt(n/5)/2;t.moveTo(-3*e,-e),t.lineTo(-e,-e),t.lineTo(-e,-3*e),t.lineTo(e,-3*e),t.lineTo(e,-e),t.lineTo(3*e,-e),t.lineTo(3*e,e),t.lineTo(e,e),t.lineTo(e,3*e),t.lineTo(-e,3*e),t.lineTo(-e,e),t.lineTo(-3*e,e),t.closePath()}},qy=Math.sqrt(1/3),Uy=2*qy,Dy={draw:function(t,n){var e=Math.sqrt(n/Uy),r=e*qy;t.moveTo(0,-e),t.lineTo(r,0),t.lineTo(0,e),t.lineTo(-r,0),t.closePath()}},Oy=Math.sin(xy/10)/Math.sin(7*xy/10),Fy=Math.sin(wy/10)*Oy,Iy=-Math.cos(wy/10)*Oy,Yy={draw:function(t,n){var e=Math.sqrt(.8908130915292852*n),r=Fy*e,i=Iy*e;t.moveTo(0,-e),t.lineTo(r,i);for(var o=1;o<5;++o){var u=wy*o/5,a=Math.cos(u),c=Math.sin(u);t.lineTo(c*e,-a*e),t.lineTo(a*r-c*i,c*r+a*i)}t.closePath()}},By={draw:function(t,n){var e=Math.sqrt(n),r=-e/2;t.rect(r,r,e,e)}},jy=Math.sqrt(3),Hy={draw:function(t,n){var e=-Math.sqrt(n/(3*jy));t.moveTo(0,2*e),t.lineTo(-jy*e,-e),t.lineTo(jy*e,-e),t.closePath()}},Xy=-.5,$y=Math.sqrt(3)/2,Vy=1/Math.sqrt(12),Wy=3*(Vy/2+1),Zy={draw:function(t,n){var e=Math.sqrt(n/Wy),r=e/2,i=e*Vy,o=r,u=e*Vy+e,a=-o,c=u;t.moveTo(r,i),t.lineTo(o,u),t.lineTo(a,c),t.lineTo(Xy*r-$y*i,$y*r+Xy*i),t.lineTo(Xy*o-$y*u,$y*o+Xy*u),t.lineTo(Xy*a-$y*c,$y*a+Xy*c),t.lineTo(Xy*r+$y*i,Xy*i-$y*r),t.lineTo(Xy*o+$y*u,Xy*u-$y*o),t.lineTo(Xy*a+$y*c,Xy*c-$y*a),t.closePath()}},Gy=[Ry,Ly,Dy,By,Yy,Hy,Zy],Jy=function(){};Ka.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:Qa(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:Qa(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}};tc.prototype={areaStart:Jy,areaEnd:Jy,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._y0=this._y1=this._y2=this._y3=this._y4=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x2,this._y2),this._context.closePath();break;case 2:this._context.moveTo((this._x2+2*this._x3)/3,(this._y2+2*this._y3)/3),this._context.lineTo((this._x3+2*this._x2)/3,(this._y3+2*this._y2)/3),this._context.closePath();break;case 3:this.point(this._x2,this._y2),this.point(this._x3,this._y3),this.point(this._x4,this._y4)}},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._x2=t,this._y2=n;break;case 1:this._point=2,this._x3=t,this._y3=n;break;case 2:this._point=3,this._x4=t,this._y4=n,this._context.moveTo((this._x0+4*this._x1+t)/6,(this._y0+4*this._y1+n)/6);break;default:Qa(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}};nc.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(){(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;var e=(this._x0+4*this._x1+t)/6,r=(this._y0+4*this._y1+n)/6;this._line?this._context.lineTo(e,r):this._context.moveTo(e,r);break;case 3:this._point=4;default:Qa(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}};ec.prototype={lineStart:function(){this._x=[],this._y=[],this._basis.lineStart()},lineEnd:function(){var t=this._x,n=this._y,e=t.length-1;if(e>0)for(var r,i=t[0],o=n[0],u=t[e]-i,a=n[e]-o,c=-1;++c<=e;)r=c/e,this._basis.point(this._beta*t[c]+(1-this._beta)*(i+r*u),this._beta*n[c]+(1-this._beta)*(o+r*a));this._x=this._y=null,this._basis.lineEnd()},point:function(t,n){this._x.push(+t),this._y.push(+n)}};var Qy=function t(n){function e(t){return 1===n?new Ka(t):new ec(t,n)}return e.beta=function(n){return t(+n)},e}(.85);ic.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:rc(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:rc(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}};var Ky=function t(n){function e(t){return new ic(t,n)}return e.tension=function(n){return t(+n)},e}(0);oc.prototype={areaStart:Jy,areaEnd:Jy,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:rc(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}};var tm=function t(n){function e(t){return new oc(t,n)}return e.tension=function(n){return t(+n)},e}(0);uc.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:rc(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}};var nm=function t(n){function e(t){return new uc(t,n)}return e.tension=function(n){return t(+n)},e}(0);cc.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 e=this._x2-t,r=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+r*r,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:ac(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}};var em=function t(n){function e(t){return n?new cc(t,n):new ic(t,0)}return e.alpha=function(n){return t(+n)},e}(.5);sc.prototype={areaStart:Jy,areaEnd:Jy,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,r=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+r*r,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:ac(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}};var rm=function t(n){function e(t){return n?new sc(t,n):new oc(t,0)}return e.alpha=function(n){return t(+n)},e}(.5);fc.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,r=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+r*r,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:ac(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}};var im=function t(n){function e(t){return n?new fc(t,n):new uc(t,0)}return e.alpha=function(n){return t(+n)},e}(.5);lc.prototype={areaStart:Jy,areaEnd:Jy,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))}};_c.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:vc(this,this._t0,dc(this,this._t0))}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){var e=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,vc(this,dc(this,e=pc(this,t,n)),e);break;default:vc(this,this._t0,e=pc(this,t,n))}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n,this._t0=e}}},(gc.prototype=Object.create(_c.prototype)).point=function(t,n){_c.prototype.point.call(this,n,t)},yc.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,e,r,i,o){this._context.bezierCurveTo(n,t,r,e,o,i)}},mc.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=[],this._y=[]},lineEnd:function(){var t=this._x,n=this._y,e=t.length;if(e)if(this._line?this._context.lineTo(t[0],n[0]):this._context.moveTo(t[0],n[0]),2===e)this._context.lineTo(t[1],n[1]);else for(var r=xc(t),i=xc(n),o=0,u=1;u<e;++o,++u)this._context.bezierCurveTo(r[0][o],i[0][o],r[1][o],i[1][o],t[u],n[u]);(this._line||0!==this._line&&1===e)&&this._context.closePath(),this._line=1-this._line,this._x=this._y=null},point:function(t,n){this._x.push(+t),this._y.push(+n)}};bc.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=this._y=NaN,this._point=0},lineEnd:function(){0<this._t&&this._t<1&&2===this._point&&this._context.lineTo(this._x,this._y),(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line>=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 e=this._x*(1-this._t)+t*this._t;this._context.lineTo(e,this._y),this._context.lineTo(e,n)}}this._x=t,this._y=n}};var om=function(t,n){if((i=t.length)>1)for(var e,r,i,o=1,u=t[n[0]],a=u.length;o<i;++o)for(r=u,u=t[n[o]],e=0;e<a;++e)u[e][1]+=u[e][0]=isNaN(r[e][1])?r[e][0]:r[e][1]},um=function(t){for(var n=t.length,e=new Array(n);--n>=0;)e[n]=n;return e},am=function(t){var n=t.map(Mc);return um(t).sort(function(t,e){return n[t]-n[e]})},cm=function(t){return function(){return t}};kc.prototype={constructor:kc,insert:function(t,n){var e,r,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;e=t}else this._?(t=Cc(this._),n.P=null,n.N=t,t.P=t.L=n,e=t):(n.P=n.N=null,this._=n,e=null);for(n.L=n.R=null,n.U=e,n.C=!0,t=n;e&&e.C;)e===(r=e.U).L?(i=r.R)&&i.C?(e.C=i.C=!1,r.C=!0,t=r):(t===e.R&&(Ec(this,e),e=(t=e).U),e.C=!1,r.C=!0,Ac(this,r)):(i=r.L)&&i.C?(e.C=i.C=!1,r.C=!0,t=r):(t===e.L&&(Ac(this,e),e=(t=e).U),e.C=!1,r.C=!0,Ec(this,r)),e=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,e,r,i=t.U,o=t.L,u=t.R;if(e=o?u?Cc(u):o:u,i?i.L===t?i.L=e:i.R=e:this._=e,o&&u?(r=e.C,e.C=t.C,e.L=o,o.U=e,e!==u?(i=e.U,e.U=t.U,t=e.R,i.L=t,e.R=u,u.U=e):(e.U=i,i=e,t=e.R)):(r=t.C,t=e),t&&(t.U=i),!r)if(t&&t.C)t.C=!1;else{do{if(t===this._)break;if(t===i.L){if((n=i.R).C&&(n.C=!1,i.C=!0,Ec(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,Ac(this,n),n=i.R),n.C=i.C,i.C=n.R.C=!1,Ec(this,i),t=this._;break}}else if((n=i.L).C&&(n.C=!1,i.C=!0,Ac(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,Ec(this,n),n=i.L),n.C=i.C,i.C=n.L.C=!1,Ac(this,i),t=this._;break}n.C=!0,t=i,i=i.U}while(!t.C);t&&(t.C=!1)}}};var sm,fm,lm,hm,pm,dm=[],vm=[],_m=1e-6,gm=1e-12;ns.prototype={constructor:ns,polygons:function(){var t=this.edges;return this.cells.map(function(n){var e=n.halfedges.map(function(e){return Fc(n,t[e])});return e.data=n.site.data,e})},triangles:function(){var t=[],n=this.edges;return this.cells.forEach(function(e,r){if(o=(i=e.halfedges).length)for(var i,o,u,a=e.site,c=-1,s=n[i[o-1]],f=s.left===a?s.right:s.left;++c<o;)u=f,f=(s=n[i[c]]).left===a?s.right:s.left,u&&f&&r<u.index&&r<f.index&&Kc(a,u,f)<0&&t.push([a.data,u.data,f.data])}),t},links:function(){return this.edges.filter(function(t){return t.right}).map(function(t){return{source:t.left.data,target:t.right.data}})},find:function(t,n,e){for(var r,i,o=this,u=o._found||0,a=o.cells.length;!(i=o.cells[u]);)if(++u>=a)return null;var c=t-i.site[0],s=n-i.site[1],f=c*c+s*s;do{i=o.cells[r=u],u=null,i.halfedges.forEach(function(e){var r=o.edges[e],a=r.left;if(a!==i.site&&a||(a=r.right)){var c=t-a[0],s=n-a[1],l=c*c+s*s;l<f&&(f=l,u=a.index)}})}while(null!==u);return o._found=r,null==e||f<=e*e?i.site:null}};var ym=function(t){return function(){return t}};rs.prototype={constructor:rs,scale:function(t){return 1===t?this:new rs(this.k*t,this.x,this.y)},translate:function(t,n){return 0===t&0===n?this:new rs(this.k,this.x+this.k*t,this.y+this.k*n)},apply:function(t){return[t[0]*this.k+this.x,t[1]*this.k+this.y]},applyX:function(t){return t*this.k+this.x},applyY:function(t){return t*this.k+this.y},invert:function(t){return[(t[0]-this.x)/this.k,(t[1]-this.y)/this.k]},invertX:function(t){return(t-this.x)/this.k},invertY:function(t){return(t-this.y)/this.k},rescaleX:function(t){return t.copy().domain(t.range().map(this.invertX,this).map(t.invert,t))},rescaleY:function(t){return t.copy().domain(t.range().map(this.invertY,this).map(t.invert,t))},toString:function(){return"translate("+this.x+","+this.y+") scale("+this.k+")"}};var mm=new rs(1,0,0);is.prototype=rs.prototype;var xm=function(){t.event.preventDefault(),t.event.stopImmediatePropagation()};t.version="4.11.0",t.bisect=ds,t.bisectRight=ds,t.bisectLeft=vs,t.ascending=ls,t.bisector=hs,t.cross=function(t,n,r){var i,o,u,a,c=t.length,s=n.length,f=new Array(c*s);for(null==r&&(r=e),i=u=0;i<c;++i)for(a=t[i],o=0;o<s;++o,++u)f[u]=r(a,n[o]);return f},t.descending=function(t,n){return n<t?-1:n>t?1:n>=t?0:NaN},t.deviation=ys,t.extent=ms,t.histogram=function(){function t(t){var o,u,a=t.length,c=new Array(a);for(o=0;o<a;++o)c[o]=n(t[o],o,t);var s=e(c),f=s[0],l=s[1],h=r(c,f,l);Array.isArray(h)||(h=i(f,l,h),h=Ns(Math.ceil(f/h)*h,Math.floor(l/h)*h,h));for(var p=h.length;h[0]<=f;)h.shift(),--p;for(;h[p-1]>l;)h.pop(),--p;var d,v=new Array(p+1);for(o=0;o<=p;++o)(d=v[o]=[]).x0=o>0?h[o-1]:f,d.x1=o<p?h[o]:l;for(o=0;o<a;++o)f<=(u=c[o])&&u<=l&&v[ds(h,u,0,p)].push(t[o]);return v}var n=Ts,e=ms,r=Cs;return t.value=function(e){return arguments.length?(n="function"==typeof e?e:Ms(e),t):n},t.domain=function(n){return arguments.length?(e="function"==typeof n?n:Ms([n[0],n[1]]),t):e},t.thresholds=function(n){return arguments.length?(r="function"==typeof n?n:Ms(Array.isArray(n)?bs.call(n):n),t):r},t},t.thresholdFreedmanDiaconis=function(t,n,e){return t=ws.call(t,_s).sort(ls),Math.ceil((e-n)/(2*(zs(t,.75)-zs(t,.25))*Math.pow(t.length,-1/3)))},t.thresholdScott=function(t,n,e){return Math.ceil((e-n)/(3.5*ys(t)*Math.pow(t.length,-1/3)))},t.thresholdSturges=Cs,t.max=function(t,n){var e,r,i=t.length,o=-1;if(null==n){for(;++o<i;)if(null!=(e=t[o])&&e>=e)for(r=e;++o<i;)null!=(e=t[o])&&e>r&&(r=e)}else for(;++o<i;)if(null!=(e=n(t[o],o,t))&&e>=e)for(r=e;++o<i;)null!=(e=n(t[o],o,t))&&e>r&&(r=e);return r},t.mean=function(t,n){var e,r=t.length,i=r,o=-1,u=0;if(null==n)for(;++o<r;)isNaN(e=_s(t[o]))?--i:u+=e;else for(;++o<r;)isNaN(e=_s(n(t[o],o,t)))?--i:u+=e;if(i)return u/i},t.median=function(t,n){var e,r=t.length,i=-1,o=[];if(null==n)for(;++i<r;)isNaN(e=_s(t[i]))||o.push(e);else for(;++i<r;)isNaN(e=_s(n(t[i],i,t)))||o.push(e);return zs(o.sort(ls),.5)},t.merge=Ps,t.min=Rs,t.pairs=function(t,n){null==n&&(n=e);for(var r=0,i=t.length-1,o=t[0],u=new Array(i<0?0:i);r<i;)u[r]=n(o,o=t[++r]);return u},t.permute=function(t,n){for(var e=n.length,r=new Array(e);e--;)r[e]=t[n[e]];return r},t.quantile=zs,t.range=Ns,t.scan=function(t,n){if(e=t.length){var e,r,i=0,o=0,u=t[o];for(null==n&&(n=ls);++i<e;)(n(r=t[i],u)<0||0!==n(u,u))&&(u=r,o=i);return 0===n(u,u)?o:void 0}},t.shuffle=function(t,n,e){for(var r,i,o=(null==e?t.length:e)-(n=null==n?0:+n);o;)i=Math.random()*o--|0,r=t[o+n],t[o+n]=t[i+n],t[i+n]=r;return t},t.sum=function(t,n){var e,r=t.length,i=-1,o=0;if(null==n)for(;++i<r;)(e=+t[i])&&(o+=e);else for(;++i<r;)(e=+n(t[i],i,t))&&(o+=e);return o},t.ticks=As,t.tickIncrement=r,t.tickStep=i,t.transpose=Ls,t.variance=gs,t.zip=function(){return Ls(arguments)},t.axisTop=function(t){return l(Ds,t)},t.axisRight=function(t){return l(Os,t)},t.axisBottom=function(t){return l(Fs,t)},t.axisLeft=function(t){return l(Is,t)},t.brush=function(){return he(Ah)},t.brushX=function(){return he(Sh)},t.brushY=function(){return he(Eh)},t.brushSelection=function(t){var n=t.__brush;return n?n.dim.output(n.selection):null},t.chord=function(){function t(t){var o,u,a,c,s,f,l=t.length,h=[],p=Ns(l),d=[],v=[],_=v.groups=new Array(l),g=new Array(l*l);for(o=0,s=-1;++s<l;){for(u=0,f=-1;++f<l;)u+=t[s][f];h.push(u),d.push(Ns(l)),o+=u}for(e&&p.sort(function(t,n){return e(h[t],h[n])}),r&&d.forEach(function(n,e){n.sort(function(n,i){return r(t[e][n],t[e][i])})}),c=(o=Ih(0,Fh-n*l)/o)?n:Fh/l,u=0,s=-1;++s<l;){for(a=u,f=-1;++f<l;){var y=p[s],m=d[y][f],x=t[y][m],b=u,w=u+=x*o;g[m*l+y]={index:y,subindex:m,startAngle:b,endAngle:w,value:x}}_[y]={index:y,startAngle:a,endAngle:u,value:h[y]},u+=c}for(s=-1;++s<l;)for(f=s-1;++f<l;){var M=g[f*l+s],T=g[s*l+f];(M.value||T.value)&&v.push(M.value<T.value?{source:T,target:M}:{source:M,target:T})}return i?v.sort(i):v}var n=0,e=null,r=null,i=null;return t.padAngle=function(e){return arguments.length?(n=Ih(0,e),t):n},t.sortGroups=function(n){return arguments.length?(e=n,t):e},t.sortSubgroups=function(n){return arguments.length?(r=n,t):r},t.sortChords=function(n){return arguments.length?(null==n?i=null:(i=pe(n))._=n,t):i&&i._},t},t.ribbon=function(){function t(){var t,a=Yh.call(arguments),c=n.apply(this,a),s=e.apply(this,a),f=+r.apply(this,(a[0]=c,a)),l=i.apply(this,a)-Oh,h=o.apply(this,a)-Oh,p=f*qh(l),d=f*Uh(l),v=+r.apply(this,(a[0]=s,a)),_=i.apply(this,a)-Oh,g=o.apply(this,a)-Oh;if(u||(u=t=ve()),u.moveTo(p,d),u.arc(0,0,f,l,h),l===_&&h===g||(u.quadraticCurveTo(0,0,v*qh(_),v*Uh(_)),u.arc(0,0,v,_,g)),u.quadraticCurveTo(0,0,p,d),u.closePath(),t)return u=null,t+""||null}var n=_e,e=ge,r=ye,i=me,o=xe,u=null;return t.radius=function(n){return arguments.length?(r="function"==typeof n?n:Bh(+n),t):r},t.startAngle=function(n){return arguments.length?(i="function"==typeof n?n:Bh(+n),t):i},t.endAngle=function(n){return arguments.length?(o="function"==typeof n?n:Bh(+n),t):o},t.source=function(e){return arguments.length?(n=e,t):n},t.target=function(n){return arguments.length?(e=n,t):e},t.context=function(n){return arguments.length?(u=null==n?null:n,t):u},t},t.nest=function(){function t(n,i,u,a){if(i>=o.length)return null!=e&&n.sort(e),null!=r?r(n):n;for(var c,s,f,l=-1,h=n.length,p=o[i++],d=we(),v=u();++l<h;)(f=d.get(c=p(s=n[l])+""))?f.push(s):d.set(c,[s]);return d.each(function(n,e){a(v,e,t(n,i,u,a))}),v}function n(t,e){if(++e>o.length)return t;var i,a=u[e-1];return null!=r&&e>=o.length?i=t.entries():(i=[],t.each(function(t,r){i.push({key:r,values:n(t,e)})})),null!=a?i.sort(function(t,n){return a(t.key,n.key)}):i}var e,r,i,o=[],u=[];return i={object:function(n){return t(n,0,Me,Te)},map:function(n){return t(n,0,Ne,ke)},entries:function(e){return n(t(e,0,Ne,ke),0)},key:function(t){return o.push(t),i},sortKeys:function(t){return u[o.length-1]=t,i},sortValues:function(t){return e=t,i},rollup:function(t){return r=t,i}}},t.set=Ee,t.map=we,t.keys=function(t){var n=[];for(var e in t)n.push(e);return n},t.values=function(t){var n=[];for(var e in t)n.push(t[e]);return n},t.entries=function(t){var n=[];for(var e in t)n.push({key:e,value:t[e]});return n},t.color=Tt,t.rgb=Et,t.hsl=Pt,t.lab=Ut,t.hcl=jt,t.cubehelix=$t,t.dispatch=h,t.drag=function(){function n(t){t.on("mousedown.drag",e).filter(g).on("touchstart.drag",o).on("touchmove.drag",u).on("touchend.drag touchcancel.drag",a).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function e(){if(!p&&d.apply(this,arguments)){var n=c("mouse",v.apply(this,arguments),nf,this,arguments);n&&(ff(t.event.view).on("mousemove.drag",r,!0).on("mouseup.drag",i,!0),pf(t.event.view),vt(),l=!1,s=t.event.clientX,f=t.event.clientY,n("start"))}}function r(){if(hf(),!l){var n=t.event.clientX-s,e=t.event.clientY-f;l=n*n+e*e>b}y.mouse("drag")}function i(){ff(t.event.view).on("mousemove.drag mouseup.drag",null),_t(t.event.view,l),hf(),y.mouse("end")}function o(){if(d.apply(this,arguments)){var n,e,r=t.event.changedTouches,i=v.apply(this,arguments),o=r.length;for(n=0;n<o;++n)(e=c(r[n].identifier,i,lf,this,arguments))&&(vt(),e("start"))}}function u(){var n,e,r=t.event.changedTouches,i=r.length;for(n=0;n<i;++n)(e=y[r[n].identifier])&&(hf(),e("drag"))}function a(){var n,e,r=t.event.changedTouches,i=r.length;for(p&&clearTimeout(p),p=setTimeout(function(){p=null},500),n=0;n<i;++n)(e=y[r[n].identifier])&&(vt(),e("end"))}function c(e,r,i,o,u){var a,c,s,f=i(r,e),l=m.copy();if(k(new gt(n,"beforestart",a,e,x,f[0],f[1],0,0,l),function(){return null!=(t.event.subject=a=_.apply(o,u))&&(c=a.x-f[0]||0,s=a.y-f[1]||0,!0)}))return function t(h){var p,d=f;switch(h){case"start":y[e]=t,p=x++;break;case"end":delete y[e],--x;case"drag":f=i(r,e),p=x}k(new gt(n,h,a,e,p,f[0]+c,f[1]+s,f[0]-d[0],f[1]-d[1],l),l.apply,l,[h,o,u])}}var s,f,l,p,d=yt,v=mt,_=xt,g=bt,y={},m=h("start","drag","end"),x=0,b=0;return n.filter=function(t){return arguments.length?(d="function"==typeof t?t:df(!!t),n):d},n.container=function(t){return arguments.length?(v="function"==typeof t?t:df(t),n):v},n.subject=function(t){return arguments.length?(_="function"==typeof t?t:df(t),n):_},n.touchable=function(t){return arguments.length?(g="function"==typeof t?t:df(!!t),n):g},n.on=function(){var t=m.on.apply(m,arguments);return t===m?n:t},n.clickDistance=function(t){return arguments.length?(b=(t=+t)*t,n):Math.sqrt(b)},n},t.dragDisable=pf,t.dragEnable=_t,t.dsvFormat=Qh,t.csvParse=tp,t.csvParseRows=np,t.csvFormat=ep,t.csvFormatRows=rp,t.tsvParse=op,t.tsvParseRows=up,t.tsvFormat=ap,t.tsvFormatRows=cp,t.easeLinear=function(t){return+t},t.easeQuad=Kn,t.easeQuadIn=function(t){return t*t},t.easeQuadOut=function(t){return t*(2-t)},t.easeQuadInOut=Kn,t.easeCubic=te,t.easeCubicIn=function(t){return t*t*t},t.easeCubicOut=function(t){return--t*t*t+1},t.easeCubicInOut=te,t.easePoly=Ql,t.easePolyIn=Gl,t.easePolyOut=Jl,t.easePolyInOut=Ql,t.easeSin=ne,t.easeSinIn=function(t){return 1-Math.cos(t*th)},t.easeSinOut=function(t){return Math.sin(t*th)},t.easeSinInOut=ne,t.easeExp=ee,t.easeExpIn=function(t){return Math.pow(2,10*t-10)},t.easeExpOut=function(t){return 1-Math.pow(2,-10*t)},t.easeExpInOut=ee,t.easeCircle=re,t.easeCircleIn=function(t){return 1-Math.sqrt(1-t*t)},t.easeCircleOut=function(t){return Math.sqrt(1- --t*t)},t.easeCircleInOut=re,t.easeBounce=ie,t.easeBounceIn=function(t){return 1-ie(1-t)},t.easeBounceOut=ie,t.easeBounceInOut=function(t){return((t*=2)<=1?1-ie(1-t):ie(t-1)+1)/2},t.easeBack=ph,t.easeBackIn=lh,t.easeBackOut=hh,t.easeBackInOut=ph,t.easeElastic=_h,t.easeElasticIn=vh,t.easeElasticOut=_h,t.easeElasticInOut=gh,t.forceCenter=function(t,n){function e(){var e,i,o=r.length,u=0,a=0;for(e=0;e<o;++e)u+=(i=r[e]).x,a+=i.y;for(u=u/o-t,a=a/o-n,e=0;e<o;++e)(i=r[e]).x-=u,i.y-=a}var r;return null==t&&(t=0),null==n&&(n=0),e.initialize=function(t){r=t},e.x=function(n){return arguments.length?(t=+n,e):t},e.y=function(t){return arguments.length?(n=+t,e):n},e},t.forceCollide=function(t){function n(){for(var t,n,r,c,s,f,l,h=i.length,p=0;p<a;++p)for(n=qe(i,Oe,Fe).visitAfter(e),t=0;t<h;++t)r=i[t],f=o[r.index],l=f*f,c=r.x+r.vx,s=r.y+r.vy,n.visit(function(t,n,e,i,o){var a=t.data,h=t.r,p=f+h;if(!a)return n>c+p||i<c-p||e>s+p||o<s-p;if(a.index>r.index){var d=c-a.x-a.vx,v=s-a.y-a.vy,_=d*d+v*v;_<p*p&&(0===d&&(d=fp(),_+=d*d),0===v&&(v=fp(),_+=v*v),_=(p-(_=Math.sqrt(_)))/_*u,r.vx+=(d*=_)*(p=(h*=h)/(l+h)),r.vy+=(v*=_)*p,a.vx-=d*(p=1-p),a.vy-=v*p)}})}function e(t){if(t.data)return t.r=o[t.data.index];for(var n=t.r=0;n<4;++n)t[n]&&t[n].r>t.r&&(t.r=t[n].r)}function r(){if(i){var n,e,r=i.length;for(o=new Array(r),n=0;n<r;++n)e=i[n],o[e.index]=+t(e,n,i)}}var i,o,u=1,a=1;return"function"!=typeof t&&(t=sp(null==t?1:+t)),n.initialize=function(t){i=t,r()},n.iterations=function(t){return arguments.length?(a=+t,n):a},n.strength=function(t){return arguments.length?(u=+t,n):u},n.radius=function(e){return arguments.length?(t="function"==typeof e?e:sp(+e),r(),n):t},n},t.forceLink=function(t){function n(n){for(var e=0,r=t.length;e<p;++e)for(var i,a,c,f,l,h,d,v=0;v<r;++v)a=(i=t[v]).source,f=(c=i.target).x+c.vx-a.x-a.vx||fp(),l=c.y+c.vy-a.y-a.vy||fp(),f*=h=((h=Math.sqrt(f*f+l*l))-u[v])/h*n*o[v],l*=h,c.vx-=f*(d=s[v]),c.vy-=l*d,a.vx+=f*(d=1-d),a.vy+=l*d}function e(){if(a){var n,e,l=a.length,h=t.length,p=we(a,f);for(n=0,c=new Array(l);n<h;++n)(e=t[n]).index=n,"object"!=typeof e.source&&(e.source=Ye(p,e.source)),"object"!=typeof e.target&&(e.target=Ye(p,e.target)),c[e.source.index]=(c[e.source.index]||0)+1,c[e.target.index]=(c[e.target.index]||0)+1;for(n=0,s=new Array(h);n<h;++n)e=t[n],s[n]=c[e.source.index]/(c[e.source.index]+c[e.target.index]);o=new Array(h),r(),u=new Array(h),i()}}function r(){if(a)for(var n=0,e=t.length;n<e;++n)o[n]=+l(t[n],n,t)}function i(){if(a)for(var n=0,e=t.length;n<e;++n)u[n]=+h(t[n],n,t)}var o,u,a,c,s,f=Ie,l=function(t){return 1/Math.min(c[t.source.index],c[t.target.index])},h=sp(30),p=1;return null==t&&(t=[]),n.initialize=function(t){a=t,e()},n.links=function(r){return arguments.length?(t=r,e(),n):t},n.id=function(t){return arguments.length?(f=t,n):f},n.iterations=function(t){return arguments.length?(p=+t,n):p},n.strength=function(t){return arguments.length?(l="function"==typeof t?t:sp(+t),r(),n):l},n.distance=function(t){return arguments.length?(h="function"==typeof t?t:sp(+t),i(),n):h},n},t.forceManyBody=function(){function t(t){var n,a=i.length,c=qe(i,Be,je).visitAfter(e);for(u=t,n=0;n<a;++n)o=i[n],c.visit(r)}function n(){if(i){var t,n,e=i.length;for(a=new Array(e),t=0;t<e;++t)n=i[t],a[n.index]=+c(n,t,i)}}function e(t){var n,e,r,i,o,u=0,c=0;if(t.length){for(r=i=o=0;o<4;++o)(n=t[o])&&(e=Math.abs(n.value))&&(u+=n.value,c+=e,r+=e*n.x,i+=e*n.y);t.x=r/c,t.y=i/c}else{(n=t).x=n.data.x,n.y=n.data.y;do{u+=a[n.data.index]}while(n=n.next)}t.value=u}function r(t,n,e,r){if(!t.value)return!0;var i=t.x-o.x,c=t.y-o.y,h=r-n,p=i*i+c*c;if(h*h/l<p)return p<f&&(0===i&&(i=fp(),p+=i*i),0===c&&(c=fp(),p+=c*c),p<s&&(p=Math.sqrt(s*p)),o.vx+=i*t.value*u/p,o.vy+=c*t.value*u/p),!0;if(!(t.length||p>=f)){(t.data!==o||t.next)&&(0===i&&(i=fp(),p+=i*i),0===c&&(c=fp(),p+=c*c),p<s&&(p=Math.sqrt(s*p)));do{t.data!==o&&(h=a[t.data.index]*u/p,o.vx+=i*h,o.vy+=c*h)}while(t=t.next)}}var i,o,u,a,c=sp(-30),s=1,f=1/0,l=.81;return t.initialize=function(t){i=t,n()},t.strength=function(e){return arguments.length?(c="function"==typeof e?e:sp(+e),n(),t):c},t.distanceMin=function(n){return arguments.length?(s=n*n,t):Math.sqrt(s)},t.distanceMax=function(n){return arguments.length?(f=n*n,t):Math.sqrt(f)},t.theta=function(n){return arguments.length?(l=n*n,t):Math.sqrt(l)},t},t.forceRadial=function(t,n,e){function r(t){for(var r=0,i=o.length;r<i;++r){var c=o[r],s=c.x-n||1e-6,f=c.y-e||1e-6,l=Math.sqrt(s*s+f*f),h=(a[r]-l)*u[r]*t/l;c.vx+=s*h,c.vy+=f*h}}function i(){if(o){var n,e=o.length;for(u=new Array(e),a=new Array(e),n=0;n<e;++n)a[n]=+t(o[n],n,o),u[n]=isNaN(a[n])?0:+c(o[n],n,o)}}var o,u,a,c=sp(.1);return"function"!=typeof t&&(t=sp(+t)),null==n&&(n=0),null==e&&(e=0),r.initialize=function(t){o=t,i()},r.strength=function(t){return arguments.length?(c="function"==typeof t?t:sp(+t),i(),r):c},r.radius=function(n){return arguments.length?(t="function"==typeof n?n:sp(+n),i(),r):t},r.x=function(t){return arguments.length?(n=+t,r):n},r.y=function(t){return arguments.length?(e=+t,r):e},r},t.forceSimulation=function(t){function n(){e(),d.call("tick",o),u<a&&(p.stop(),d.call("end",o))}function e(){var n,e,r=t.length;for(u+=(s-u)*c,l.each(function(t){t(u)}),n=0;n<r;++n)null==(e=t[n]).fx?e.x+=e.vx*=f:(e.x=e.fx,e.vx=0),null==e.fy?e.y+=e.vy*=f:(e.y=e.fy,e.vy=0)}function r(){for(var n,e=0,r=t.length;e<r;++e){if(n=t[e],n.index=e,isNaN(n.x)||isNaN(n.y)){var i=dp*Math.sqrt(e),o=e*vp;n.x=i*Math.cos(o),n.y=i*Math.sin(o)}(isNaN(n.vx)||isNaN(n.vy))&&(n.vx=n.vy=0)}}function i(n){return n.initialize&&n.initialize(t),n}var o,u=1,a=.001,c=1-Math.pow(a,1/300),s=0,f=.6,l=we(),p=dn(n),d=h("tick","end");return null==t&&(t=[]),r(),o={tick:e,restart:function(){return p.restart(n),o},stop:function(){return p.stop(),o},nodes:function(n){return arguments.length?(t=n,r(),l.each(i),o):t},alpha:function(t){return arguments.length?(u=+t,o):u},alphaMin:function(t){return arguments.length?(a=+t,o):a},alphaDecay:function(t){return arguments.length?(c=+t,o):+c},alphaTarget:function(t){return arguments.length?(s=+t,o):s},velocityDecay:function(t){return arguments.length?(f=1-t,o):1-f},force:function(t,n){return arguments.length>1?(null==n?l.remove(t):l.set(t,i(n)),o):l.get(t)},find:function(n,e,r){var i,o,u,a,c,s=0,f=t.length;for(null==r?r=1/0:r*=r,s=0;s<f;++s)(u=(i=n-(a=t[s]).x)*i+(o=e-a.y)*o)<r&&(c=a,r=u);return c},on:function(t,n){return arguments.length>1?(d.on(t,n),o):d.on(t)}}},t.forceX=function(t){function n(t){for(var n,e=0,u=r.length;e<u;++e)(n=r[e]).vx+=(o[e]-n.x)*i[e]*t}function e(){if(r){var n,e=r.length;for(i=new Array(e),o=new Array(e),n=0;n<e;++n)i[n]=isNaN(o[n]=+t(r[n],n,r))?0:+u(r[n],n,r)}}var r,i,o,u=sp(.1);return"function"!=typeof t&&(t=sp(null==t?0:+t)),n.initialize=function(t){r=t,e()},n.strength=function(t){return arguments.length?(u="function"==typeof t?t:sp(+t),e(),n):u},n.x=function(r){return arguments.length?(t="function"==typeof r?r:sp(+r),e(),n):t},n},t.forceY=function(t){function n(t){for(var n,e=0,u=r.length;e<u;++e)(n=r[e]).vy+=(o[e]-n.y)*i[e]*t}function e(){if(r){var n,e=r.length;for(i=new Array(e),o=new Array(e),n=0;n<e;++n)i[n]=isNaN(o[n]=+t(r[n],n,r))?0:+u(r[n],n,r)}}var r,i,o,u=sp(.1);return"function"!=typeof t&&(t=sp(null==t?0:+t)),n.initialize=function(t){r=t,e()},n.strength=function(t){return arguments.length?(u="function"==typeof t?t:sp(+t),e(),n):u},n.y=function(r){return arguments.length?(t="function"==typeof r?r:sp(+r),e(),n):t},n},t.formatDefaultLocale=$e,t.formatLocale=kp,t.formatSpecifier=He,t.precisionFixed=Sp,t.precisionPrefix=Ep,t.precisionRound=Ap,t.geoArea=function(t){return Pd.reset(),Cd(t,Rd),2*Pd},t.geoBounds=function(t){var n,e,r,i,o,u,a;if(Fp=Op=-(Up=Dp=1/0),Hp=[],Cd(t,qd),e=Hp.length){for(Hp.sort(br),n=1,o=[r=Hp[0]];n<e;++n)wr(r,(i=Hp[n])[0])||wr(r,i[1])?(xr(r[0],i[1])>xr(r[0],r[1])&&(r[1]=i[1]),xr(i[0],r[1])>xr(r[0],r[1])&&(r[0]=i[0])):o.push(r=i);for(u=-1/0,n=0,r=o[e=o.length-1];n<=e;r=i,++n)i=o[n],(a=xr(r[1],i[0]))>u&&(u=a,Up=i[0],Op=r[1])}return Hp=Xp=null,Up===1/0||Dp===1/0?[[NaN,NaN],[NaN,NaN]]:[[Up,Dp],[Op,Fp]]},t.geoCentroid=function(t){$p=Vp=Wp=Zp=Gp=Jp=Qp=Kp=td=nd=ed=0,Cd(t,Ud);var n=td,e=nd,r=ed,i=n*n+e*e+r*r;return i<1e-12&&(n=Jp,e=Qp,r=Kp,Vp<sd&&(n=Wp,e=Zp,r=Gp),(i=n*n+e*e+r*r)<1e-12)?[NaN,NaN]:[yd(e,n)*dd,Ge(r/kd(i))*dd]},t.geoCircle=function(){function t(){var t=r.apply(this,arguments),a=i.apply(this,arguments)*vd,c=o.apply(this,arguments)*vd;return n=[],e=Lr(-t[0]*vd,-t[1]*vd,0).invert,Or(u,a,c,1),t={type:"Polygon",coordinates:[n]},n=e=null,t}var n,e,r=Dd([0,0]),i=Dd(90),o=Dd(6),u={point:function(t,r){n.push(t=e(t,r)),t[0]*=dd,t[1]*=dd}};return t.center=function(n){return arguments.length?(r="function"==typeof n?n:Dd([+n[0],+n[1]]),t):r},t.radius=function(n){return arguments.length?(i="function"==typeof n?n:Dd(+n),t):i},t.precision=function(n){return arguments.length?(o="function"==typeof n?n:Dd(+n),t):o},t},t.geoClipAntimeridian=rv,t.geoClipCircle=iv,t.geoClipExtent=function(){var t,n,e,r=0,i=0,o=960,u=500;return e={stream:function(e){return t&&n===e?t:t=Xr(r,i,o,u)(n=e)},extent:function(a){return arguments.length?(r=+a[0][0],i=+a[0][1],o=+a[1][0],u=+a[1][1],t=n=null,e):[[r,i],[o,u]]}}},t.geoClipRectangle=Xr,t.geoContains=function(t,n){return(t&&dv.hasOwnProperty(t.type)?dv[t.type]:Zr)(t,n)},t.geoDistance=pv,t.geoGraticule=ri,t.geoGraticule10=function(){return ri()()},t.geoInterpolate=function(t,n){var e=t[0]*vd,r=t[1]*vd,i=n[0]*vd,o=n[1]*vd,u=md(r),a=Td(r),c=md(o),s=Td(o),f=u*md(e),l=u*Td(e),h=c*md(i),p=c*Td(i),d=2*Ge(kd(Je(o-r)+u*c*Je(i-e))),v=Td(d),_=d?function(t){var n=Td(t*=d)/v,e=Td(d-t)/v,r=e*f+n*h,i=e*l+n*p,o=e*a+n*s;return[yd(i,r)*dd,yd(o,kd(r*r+i*i))*dd]}:function(){return[e*dd,r*dd]};return _.distance=d,_},t.geoLength=fv,t.geoPath=function(t,n){function e(t){return t&&("function"==typeof o&&i.pointRadius(+o.apply(this,arguments)),Cd(t,r(i))),i.result()}var r,i,o=4.5;return e.area=function(t){return Cd(t,r(mv)),mv.result()},e.measure=function(t){return Cd(t,r(Yv)),Yv.result()},e.bounds=function(t){return Cd(t,r(Tv)),Tv.result()},e.centroid=function(t){return Cd(t,r(Lv)),Lv.result()},e.projection=function(n){return arguments.length?(r=null==n?(t=null,_v):(t=n).stream,e):t},e.context=function(t){return arguments.length?(i=null==t?(n=null,new xi):new gi(n=t),"function"!=typeof o&&i.pointRadius(o),e):n},e.pointRadius=function(t){return arguments.length?(o="function"==typeof t?t:(i.pointRadius(+t),+t),e):o},e.projection(t).context(n)},t.geoAlbers=Vv,t.geoAlbersUsa=function(){function t(t){var n=t[0],e=t[1];return a=null,i.point(n,e),a||(o.point(n,e),a)||(u.point(n,e),a)}function n(){return e=r=null,t}var e,r,i,o,u,a,c=Vv(),s=$v().rotate([154,0]).center([-2,58.5]).parallels([55,65]),f=$v().rotate([157,0]).center([-3,19.9]).parallels([8,18]),l={point:function(t,n){a=[t,n]}};return t.invert=function(t){var n=c.scale(),e=c.translate(),r=(t[0]-e[0])/n,i=(t[1]-e[1])/n;return(i>=.12&&i<.234&&r>=-.425&&r<-.214?s:i>=.166&&i<.234&&r>=-.214&&r<-.115?f:c).invert(t)},t.stream=function(t){return e&&r===t?e:e=Li([c.stream(r=t),s.stream(t),f.stream(t)])},t.precision=function(t){return arguments.length?(c.precision(t),s.precision(t),f.precision(t),n()):c.precision()},t.scale=function(n){return arguments.length?(c.scale(n),s.scale(.35*n),f.scale(n),t.translate(c.translate())):c.scale()},t.translate=function(t){if(!arguments.length)return c.translate();var e=c.scale(),r=+t[0],a=+t[1];return i=c.translate(t).clipExtent([[r-.455*e,a-.238*e],[r+.455*e,a+.238*e]]).stream(l),o=s.translate([r-.307*e,a+.201*e]).clipExtent([[r-.425*e+sd,a+.12*e+sd],[r-.214*e-sd,a+.234*e-sd]]).stream(l),u=f.translate([r-.205*e,a+.212*e]).clipExtent([[r-.214*e+sd,a+.166*e+sd],[r-.115*e-sd,a+.234*e-sd]]).stream(l),n()},t.fitExtent=function(n,e){return Ti(t,n,e)},t.fitSize=function(n,e){return Ni(t,n,e)},t.scale(1070)},t.geoAzimuthalEqualArea=function(){return Ai(Wv).scale(124.75).clipAngle(179.999)},t.geoAzimuthalEqualAreaRaw=Wv,t.geoAzimuthalEquidistant=function(){return Ai(Zv).scale(79.4188).clipAngle(179.999)},t.geoAzimuthalEquidistantRaw=Zv,t.geoConicConformal=function(){return zi(Ii).scale(109.5).parallels([30,30])},t.geoConicConformalRaw=Ii,t.geoConicEqualArea=$v,t.geoConicEqualAreaRaw=Ri,t.geoConicEquidistant=function(){return zi(Bi).scale(131.154).center([0,13.9389])},t.geoConicEquidistantRaw=Bi,t.geoEquirectangular=function(){return Ai(Yi).scale(152.63)},t.geoEquirectangularRaw=Yi,t.geoGnomonic=function(){return Ai(ji).scale(144.049).clipAngle(60)},t.geoGnomonicRaw=ji,t.geoIdentity=function(){function t(){return i=o=null,u}var n,e,r,i,o,u,a=1,c=0,s=0,f=1,l=1,h=_v,p=null,d=_v;return u={stream:function(t){return i&&o===t?i:i=h(d(o=t))},postclip:function(i){return arguments.length?(d=i,p=n=e=r=null,t()):d},clipExtent:function(i){return arguments.length?(d=null==i?(p=n=e=r=null,_v):Xr(p=+i[0][0],n=+i[0][1],e=+i[1][0],r=+i[1][1]),t()):null==p?null:[[p,n],[e,r]]},scale:function(n){return arguments.length?(h=Hi((a=+n)*f,a*l,c,s),t()):a},translate:function(n){return arguments.length?(h=Hi(a*f,a*l,c=+n[0],s=+n[1]),t()):[c,s]},reflectX:function(n){return arguments.length?(h=Hi(a*(f=n?-1:1),a*l,c,s),t()):f<0},reflectY:function(n){return arguments.length?(h=Hi(a*f,a*(l=n?-1:1),c,s),t()):l<0},fitExtent:function(t,n){return Ti(u,t,n)},fitSize:function(t,n){return Ni(u,t,n)}}},t.geoProjection=Ai,t.geoProjectionMutator=Ci,t.geoMercator=function(){return Oi(Di).scale(961/pd)},t.geoMercatorRaw=Di,t.geoNaturalEarth1=function(){return Ai(Xi).scale(175.295)},t.geoNaturalEarth1Raw=Xi,t.geoOrthographic=function(){return Ai($i).scale(249.5).clipAngle(90+sd)},t.geoOrthographicRaw=$i,t.geoStereographic=function(){return Ai(Vi).scale(250).clipAngle(142)},t.geoStereographicRaw=Vi,t.geoTransverseMercator=function(){var t=Oi(Wi),n=t.center,e=t.rotate;return t.center=function(t){return arguments.length?n([-t[1],t[0]]):(t=n(),[t[1],-t[0]])},t.rotate=function(t){return arguments.length?e([t[0],t[1],t.length>2?t[2]+90:90]):(t=e(),[t[0],t[1],t[2]-90])},e([0,0,90]).scale(159.155)},t.geoTransverseMercatorRaw=Wi,t.geoRotation=Gd,t.geoStream=Cd,t.geoTransform=function(t){return{stream:wi(t)}},t.cluster=function(){function t(t){var o,u=0;t.eachAfter(function(t){var e=t.children;e?(t.x=Gi(e),t.y=Qi(e)):(t.x=o?u+=n(t,o):0,t.y=0,o=t)});var a=to(t),c=no(t),s=a.x-n(a,c)/2,f=c.x+n(c,a)/2;return t.eachAfter(i?function(n){n.x=(n.x-t.x)*e,n.y=(t.y-n.y)*r}:function(n){n.x=(n.x-s)/(f-s)*e,n.y=(1-(t.y?n.y/t.y:1))*r})}var n=Zi,e=1,r=1,i=!1;return t.separation=function(e){return arguments.length?(n=e,t):n},t.size=function(n){return arguments.length?(i=!1,e=+n[0],r=+n[1],t):i?null:[e,r]},t.nodeSize=function(n){return arguments.length?(i=!0,e=+n[0],r=+n[1],t):i?[e,r]:null},t},t.hierarchy=io,t.pack=function(){function t(t){return t.x=e/2,t.y=r/2,n?t.eachBefore(Eo(n)).eachAfter(Ao(i,.5)).eachBefore(Co(1)):t.eachBefore(Eo(So)).eachAfter(Ao(ko,1)).eachAfter(Ao(i,t.r/Math.min(e,r))).eachBefore(Co(Math.min(e,r)/(2*t.r))),t}var n=null,e=1,r=1,i=ko;return t.radius=function(e){return arguments.length?(n=To(e),t):n},t.size=function(n){return arguments.length?(e=+n[0],r=+n[1],t):[e,r]},t.padding=function(n){return arguments.length?(i="function"==typeof n?n:Qv(+n),t):i},t},t.packSiblings=function(t){return Mo(t),t},t.packEnclose=Jv,t.partition=function(){function t(t){var u=t.height+1;return t.x0=t.y0=i,t.x1=e,t.y1=r/u,t.eachBefore(n(r,u)),o&&t.eachBefore(Kv),t}function n(t,n){return function(e){e.children&&t_(e,e.x0,t*(e.depth+1)/n,e.x1,t*(e.depth+2)/n);var r=e.x0,o=e.y0,u=e.x1-i,a=e.y1-i;u<r&&(r=u=(r+u)/2),a<o&&(o=a=(o+a)/2),e.x0=r,e.y0=o,e.x1=u,e.y1=a}}var e=1,r=1,i=0,o=!1;return t.round=function(n){return arguments.length?(o=!!n,t):o},t.size=function(n){return arguments.length?(e=+n[0],r=+n[1],t):[e,r]},t.padding=function(n){return arguments.length?(i=+n,t):i},t},t.stratify=function(){function t(t){var r,i,o,u,a,c,s,f=t.length,l=new Array(f),h={};for(i=0;i<f;++i)r=t[i],a=l[i]=new co(r),null!=(c=n(r,i,t))&&(c+="")&&(h[s=n_+(a.id=c)]=s in h?r_:a);for(i=0;i<f;++i)if(a=l[i],null!=(c=e(t[i],i,t))&&(c+="")){if(!(u=h[n_+c]))throw new Error("missing: "+c);if(u===r_)throw new Error("ambiguous: "+c);u.children?u.children.push(a):u.children=[a],a.parent=u}else{if(o)throw new Error("multiple roots");o=a}if(!o)throw new Error("no root");if(o.parent=e_,o.eachBefore(function(t){t.depth=t.parent.depth+1,--f}).eachBefore(ao),o.parent=null,f>0)throw new Error("cycle");return o}var n=zo,e=Po;return t.id=function(e){return arguments.length?(n=No(e),t):n},t.parentId=function(n){return arguments.length?(e=No(n),t):e},t},t.tree=function(){function t(t){var r=Io(t);if(r.eachAfter(n),r.parent.m=-r.z,r.eachBefore(e),c)t.eachBefore(i);else{var s=t,f=t,l=t;t.eachBefore(function(t){t.x<s.x&&(s=t),t.x>f.x&&(f=t),t.depth>l.depth&&(l=t)});var h=s===f?1:o(s,f)/2,p=h-s.x,d=u/(f.x+h+p),v=a/(l.depth||1);t.eachBefore(function(t){t.x=(t.x+p)*d,t.y=t.depth*v})}return t}function n(t){var n=t.children,e=t.parent.children,i=t.i?e[t.i-1]:null;if(n){Do(t);var u=(n[0].z+n[n.length-1].z)/2;i?(t.z=i.z+o(t._,i._),t.m=t.z-u):t.z=u}else i&&(t.z=i.z+o(t._,i._));t.parent.A=r(t,i,t.parent.A||e[0])}function e(t){t._.x=t.z+t.parent.m,t.m+=t.parent.m}function r(t,n,e){if(n){for(var r,i=t,u=t,a=n,c=i.parent.children[0],s=i.m,f=u.m,l=a.m,h=c.m;a=qo(a),i=Lo(i),a&&i;)c=Lo(c),(u=qo(u)).a=t,(r=a.z+l-i.z-s+o(a._,i._))>0&&(Uo(Oo(a,t,e),t,r),s+=r,f+=r),l+=a.m,s+=i.m,h+=c.m,f+=u.m;a&&!qo(u)&&(u.t=a,u.m+=l-f),i&&!Lo(c)&&(c.t=i,c.m+=s-h,e=t)}return e}function i(t){t.x*=u,t.y=t.depth*a}var o=Ro,u=1,a=1,c=null;return t.separation=function(n){return arguments.length?(o=n,t):o},t.size=function(n){return arguments.length?(c=!1,u=+n[0],a=+n[1],t):c?null:[u,a]},t.nodeSize=function(n){return arguments.length?(c=!0,u=+n[0],a=+n[1],t):c?[u,a]:null},t},t.treemap=function(){function t(t){return t.x0=t.y0=0,t.x1=i,t.y1=o,t.eachBefore(n),u=[0],r&&t.eachBefore(Kv),t}function n(t){var n=u[t.depth],r=t.x0+n,i=t.y0+n,o=t.x1-n,h=t.y1-n;o<r&&(r=o=(r+o)/2),h<i&&(i=h=(i+h)/2),t.x0=r,t.y0=i,t.x1=o,t.y1=h,t.children&&(n=u[t.depth+1]=a(t)/2,r+=l(t)-n,i+=c(t)-n,o-=s(t)-n,h-=f(t)-n,o<r&&(r=o=(r+o)/2),h<i&&(i=h=(i+h)/2),e(t,r,i,o,h))}var e=u_,r=!1,i=1,o=1,u=[0],a=ko,c=ko,s=ko,f=ko,l=ko;return t.round=function(n){return arguments.length?(r=!!n,t):r},t.size=function(n){return arguments.length?(i=+n[0],o=+n[1],t):[i,o]},t.tile=function(n){return arguments.length?(e=No(n),t):e},t.padding=function(n){return arguments.length?t.paddingInner(n).paddingOuter(n):t.paddingInner()},t.paddingInner=function(n){return arguments.length?(a="function"==typeof n?n:Qv(+n),t):a},t.paddingOuter=function(n){return arguments.length?t.paddingTop(n).paddingRight(n).paddingBottom(n).paddingLeft(n):t.paddingTop()},t.paddingTop=function(n){return arguments.length?(c="function"==typeof n?n:Qv(+n),t):c},t.paddingRight=function(n){return arguments.length?(s="function"==typeof n?n:Qv(+n),t):s},t.paddingBottom=function(n){return arguments.length?(f="function"==typeof n?n:Qv(+n),t):f},t.paddingLeft=function(n){return arguments.length?(l="function"==typeof n?n:Qv(+n),t):l},t},t.treemapBinary=function(t,n,e,r,i){function o(t,n,e,r,i,u,a){if(t>=n-1){var s=c[t];return s.x0=r,s.y0=i,s.x1=u,void(s.y1=a)}for(var l=f[t],h=e/2+l,p=t+1,d=n-1;p<d;){var v=p+d>>>1;f[v]<h?p=v+1:d=v}h-f[p-1]<f[p]-h&&t+1<p&&--p;var _=f[p]-l,g=e-_;if(u-r>a-i){var y=(r*g+u*_)/e;o(t,p,_,r,i,y,a),o(p,n,g,y,i,u,a)}else{var m=(i*g+a*_)/e;o(t,p,_,r,i,u,m),o(p,n,g,r,m,u,a)}}var u,a,c=t.children,s=c.length,f=new Array(s+1);for(f[0]=a=u=0;u<s;++u)f[u+1]=a+=c[u].value;o(0,s,t.value,n,e,r,i)},t.treemapDice=t_,t.treemapSlice=i_,t.treemapSliceDice=function(t,n,e,r,i){(1&t.depth?i_:t_)(t,n,e,r,i)},t.treemapSquarify=u_,t.treemapResquarify=a_,t.interpolate=fl,t.interpolateArray=rl,t.interpolateBasis=Jf,t.interpolateBasisClosed=Qf,t.interpolateDate=il,t.interpolateNumber=ol,t.interpolateObject=ul,t.interpolateRound=ll,t.interpolateString=sl,t.interpolateTransformCss=vl,t.interpolateTransformSvg=_l,t.interpolateZoom=yl,t.interpolateRgb=tl,t.interpolateRgbBasis=nl,t.interpolateRgbBasisClosed=el,t.interpolateHsl=ml,t.interpolateHslLong=xl,t.interpolateLab=function(t,n){var e=Kt((t=Ut(t)).l,(n=Ut(n)).l),r=Kt(t.a,n.a),i=Kt(t.b,n.b),o=Kt(t.opacity,n.opacity);return function(n){return t.l=e(n),t.a=r(n),t.b=i(n),t.opacity=o(n),t+""}},t.interpolateHcl=bl,t.interpolateHclLong=wl,t.interpolateCubehelix=Ml,t.interpolateCubehelixLong=Tl,t.quantize=function(t,n){for(var e=new Array(n),r=0;r<n;++r)e[r]=t(r/(n-1));return e},t.path=ve,t.polygonArea=function(t){for(var n,e=-1,r=t.length,i=t[r-1],o=0;++e<r;)n=i,i=t[e],o+=n[1]*i[0]-n[0]*i[1];return o/2},t.polygonCentroid=function(t){for(var n,e,r=-1,i=t.length,o=0,u=0,a=t[i-1],c=0;++r<i;)n=a,a=t[r],c+=e=n[0]*a[1]-a[0]*n[1],o+=(n[0]+a[0])*e,u+=(n[1]+a[1])*e;return c*=3,[o/c,u/c]},t.polygonHull=function(t){if((e=t.length)<3)return null;var n,e,r=new Array(e),i=new Array(e);for(n=0;n<e;++n)r[n]=[+t[n][0],+t[n][1],n];for(r.sort(Bo),n=0;n<e;++n)i[n]=[r[n][0],-r[n][1]];var o=jo(r),u=jo(i),a=u[0]===o[0],c=u[u.length-1]===o[o.length-1],s=[];for(n=o.length-1;n>=0;--n)s.push(t[r[o[n]][2]]);for(n=+a;n<u.length-c;++n)s.push(t[r[u[n]][2]]);return s},t.polygonContains=function(t,n){for(var e,r,i=t.length,o=t[i-1],u=n[0],a=n[1],c=o[0],s=o[1],f=!1,l=0;l<i;++l)e=(o=t[l])[0],(r=o[1])>a!=s>a&&u<(c-e)*(a-r)/(s-r)+e&&(f=!f),c=e,s=r;return f},t.polygonLength=function(t){for(var n,e,r=-1,i=t.length,o=t[i-1],u=o[0],a=o[1],c=0;++r<i;)n=u,e=a,n-=u=(o=t[r])[0],e-=a=o[1],c+=Math.sqrt(n*n+e*e);return c},t.quadtree=qe,t.queue=Go,t.randomUniform=h_,t.randomNormal=p_,t.randomLogNormal=d_,t.randomBates=__,t.randomIrwinHall=v_,t.randomExponential=g_,t.request=y_,t.html=x_,t.json=b_,t.text=w_,t.xml=M_,t.csv=N_,t.tsv=k_,t.scaleBand=nu,t.scalePoint=function(){return eu(nu().paddingInner(1))},t.scaleIdentity=hu,t.scaleLinear=lu,t.scaleLog=mu,t.scaleOrdinal=tu,t.scaleImplicit=C_,t.scalePow=bu,t.scaleSqrt=function(){return bu().exponent(.5)},t.scaleQuantile=wu,t.scaleQuantize=Mu,t.scaleThreshold=Tu,t.scaleTime=function(){return Ea(hg,fg,G_,W_,$_,H_,B_,O_,t.timeFormat).domain([new Date(2e3,0,1),new Date(2e3,0,2)])},t.scaleUtc=function(){return Ea(Ug,Lg,xg,yg,_g,dg,B_,O_,t.utcFormat).domain([Date.UTC(2e3,0,1),Date.UTC(2e3,0,2)])},t.schemeCategory10=Kg,t.schemeCategory20b=ty,t.schemeCategory20c=ny,t.schemeCategory20=ey,t.interpolateCubehelixDefault=ry,t.interpolateRainbow=function(t){(t<0||t>1)&&(t-=Math.floor(t));var n=Math.abs(t-.5);return uy.h=360*t-100,uy.s=1.5-1.5*n,uy.l=.8-.9*n,uy+""},t.interpolateWarm=iy,t.interpolateCool=oy,t.interpolateViridis=ay,t.interpolateMagma=cy,t.interpolateInferno=sy,t.interpolatePlasma=fy,t.scaleSequential=Ca,t.creator=$s,t.local=m,t.matcher=Js,t.mouse=nf,t.namespace=Xs,t.namespaces=Hs,t.select=ff,t.selectAll=function(t){return"string"==typeof t?new pt([document.querySelectorAll(t)],[document.documentElement]):new pt([null==t?[]:t],sf)},t.selection=dt,t.selector=ef,t.selectorAll=rf,t.style=B,t.touch=lf,t.touches=function(t,n){null==n&&(n=Ks().touches);for(var e=0,r=n?n.length:0,i=new Array(r);e<r;++e)i[e]=tf(t,n[e]);return i},t.window=cf,t.customEvent=k,t.arc=function(){function t(){var t,s,f=+n.apply(this,arguments),l=+e.apply(this,arguments),h=o.apply(this,arguments)-by,p=u.apply(this,arguments)-by,d=hy(p-h),v=p>h;if(c||(c=t=ve()),l<f&&(s=l,l=f,f=s),l>my)if(d>wy-my)c.moveTo(l*dy(h),l*gy(h)),c.arc(0,0,l,h,p,!v),f>my&&(c.moveTo(f*dy(p),f*gy(p)),c.arc(0,0,f,p,h,v));else{var _,g,y=h,m=p,x=h,b=p,w=d,M=d,T=a.apply(this,arguments)/2,N=T>my&&(i?+i.apply(this,arguments):yy(f*f+l*l)),k=_y(hy(l-f)/2,+r.apply(this,arguments)),S=k,E=k;if(N>my){var A=Pa(N/f*gy(T)),C=Pa(N/l*gy(T));(w-=2*A)>my?(A*=v?1:-1,x+=A,b-=A):(w=0,x=b=(h+p)/2),(M-=2*C)>my?(C*=v?1:-1,y+=C,m-=C):(M=0,y=m=(h+p)/2)}var z=l*dy(y),P=l*gy(y),R=f*dy(b),L=f*gy(b);if(k>my){var q=l*dy(m),U=l*gy(m),D=f*dy(x),O=f*gy(x);if(d<xy){var F=w>my?Oa(z,P,D,O,q,U,R,L):[R,L],I=z-F[0],Y=P-F[1],B=q-F[0],j=U-F[1],H=1/gy(za((I*B+Y*j)/(yy(I*I+Y*Y)*yy(B*B+j*j)))/2),X=yy(F[0]*F[0]+F[1]*F[1]);S=_y(k,(f-X)/(H-1)),E=_y(k,(l-X)/(H+1))}}M>my?E>my?(_=Fa(D,O,z,P,l,E,v),g=Fa(q,U,R,L,l,E,v),c.moveTo(_.cx+_.x01,_.cy+_.y01),E<k?c.arc(_.cx,_.cy,E,py(_.y01,_.x01),py(g.y01,g.x01),!v):(c.arc(_.cx,_.cy,E,py(_.y01,_.x01),py(_.y11,_.x11),!v),c.arc(0,0,l,py(_.cy+_.y11,_.cx+_.x11),py(g.cy+g.y11,g.cx+g.x11),!v),c.arc(g.cx,g.cy,E,py(g.y11,g.x11),py(g.y01,g.x01),!v))):(c.moveTo(z,P),c.arc(0,0,l,y,m,!v)):c.moveTo(z,P),f>my&&w>my?S>my?(_=Fa(R,L,q,U,f,-S,v),g=Fa(z,P,D,O,f,-S,v),c.lineTo(_.cx+_.x01,_.cy+_.y01),S<k?c.arc(_.cx,_.cy,S,py(_.y01,_.x01),py(g.y01,g.x01),!v):(c.arc(_.cx,_.cy,S,py(_.y01,_.x01),py(_.y11,_.x11),!v),c.arc(0,0,f,py(_.cy+_.y11,_.cx+_.x11),py(g.cy+g.y11,g.cx+g.x11),v),c.arc(g.cx,g.cy,S,py(g.y11,g.x11),py(g.y01,g.x01),!v))):c.arc(0,0,f,b,x,v):c.lineTo(R,L)}else c.moveTo(0,0);if(c.closePath(),t)return c=null,t+""||null}var n=Ra,e=La,r=ly(0),i=null,o=qa,u=Ua,a=Da,c=null;return t.centroid=function(){var t=(+n.apply(this,arguments)+ +e.apply(this,arguments))/2,r=(+o.apply(this,arguments)+ +u.apply(this,arguments))/2-xy/2;return[dy(r)*t,gy(r)*t]},t.innerRadius=function(e){return arguments.length?(n="function"==typeof e?e:ly(+e),t):n},t.outerRadius=function(n){return arguments.length?(e="function"==typeof n?n:ly(+n),t):e},t.cornerRadius=function(n){return arguments.length?(r="function"==typeof n?n:ly(+n),t):r},t.padRadius=function(n){return arguments.length?(i=null==n?null:"function"==typeof n?n:ly(+n),t):i},t.startAngle=function(n){return arguments.length?(o="function"==typeof n?n:ly(+n),t):o},t.endAngle=function(n){return arguments.length?(u="function"==typeof n?n:ly(+n),t):u},t.padAngle=function(n){return arguments.length?(a="function"==typeof n?n:ly(+n),t):a},t.context=function(n){return arguments.length?(c=null==n?null:n,t):c},t},t.area=Ny,t.line=Ty,t.pie=function(){function t(t){var a,c,s,f,l,h=t.length,p=0,d=new Array(h),v=new Array(h),_=+i.apply(this,arguments),g=Math.min(wy,Math.max(-wy,o.apply(this,arguments)-_)),y=Math.min(Math.abs(g)/h,u.apply(this,arguments)),m=y*(g<0?-1:1);for(a=0;a<h;++a)(l=v[d[a]=a]=+n(t[a],a,t))>0&&(p+=l);for(null!=e?d.sort(function(t,n){return e(v[t],v[n])}):null!=r&&d.sort(function(n,e){return r(t[n],t[e])}),a=0,s=p?(g-h*m)/p:0;a<h;++a,_=f)c=d[a],f=_+((l=v[c])>0?l*s:0)+m,v[c]={data:t[c],index:a,value:l,startAngle:_,endAngle:f,padAngle:y};return v}var n=Sy,e=ky,r=null,i=ly(0),o=ly(wy),u=ly(0);return t.value=function(e){return arguments.length?(n="function"==typeof e?e:ly(+e),t):n},t.sortValues=function(n){return arguments.length?(e=n,r=null,t):e},t.sort=function(n){return arguments.length?(r=n,e=null,t):r},t.startAngle=function(n){return arguments.length?(i="function"==typeof n?n:ly(+n),t):i},t.endAngle=function(n){return arguments.length?(o="function"==typeof n?n:ly(+n),t):o},t.padAngle=function(n){return arguments.length?(u="function"==typeof n?n:ly(+n),t):u},t},t.areaRadial=Cy,t.radialArea=Cy,t.lineRadial=Ay,t.radialLine=Ay,t.pointRadial=zy,t.linkHorizontal=function(){return Wa(Za)},t.linkVertical=function(){return Wa(Ga)},t.linkRadial=function(){var t=Wa(Ja);return t.angle=t.x,delete t.x,t.radius=t.y,delete t.y,t},t.symbol=function(){function t(){var t;if(r||(r=t=ve()),n.apply(this,arguments).draw(r,+e.apply(this,arguments)),t)return r=null,t+""||null}var n=ly(Ry),e=ly(64),r=null;return t.type=function(e){return arguments.length?(n="function"==typeof e?e:ly(e),t):n},t.size=function(n){return arguments.length?(e="function"==typeof n?n:ly(+n),t):e},t.context=function(n){return arguments.length?(r=null==n?null:n,t):r},t},t.symbols=Gy,t.symbolCircle=Ry,t.symbolCross=Ly,t.symbolDiamond=Dy,t.symbolSquare=By,t.symbolStar=Yy,t.symbolTriangle=Hy,t.symbolWye=Zy,t.curveBasisClosed=function(t){return new tc(t)},t.curveBasisOpen=function(t){return new nc(t)},t.curveBasis=function(t){return new Ka(t)},t.curveBundle=Qy,t.curveCardinalClosed=tm,t.curveCardinalOpen=nm,t.curveCardinal=Ky,t.curveCatmullRomClosed=rm,t.curveCatmullRomOpen=im,t.curveCatmullRom=em,t.curveLinearClosed=function(t){return new lc(t)},t.curveLinear=My,t.curveMonotoneX=function(t){return new _c(t)},t.curveMonotoneY=function(t){return new gc(t)},t.curveNatural=function(t){return new mc(t)},t.curveStep=function(t){return new bc(t,.5)},t.curveStepAfter=function(t){return new bc(t,1)},t.curveStepBefore=function(t){return new bc(t,0)},t.stack=function(){function t(t){var o,u,a=n.apply(this,arguments),c=t.length,s=a.length,f=new Array(s);for(o=0;o<s;++o){for(var l,h=a[o],p=f[o]=new Array(c),d=0;d<c;++d)p[d]=l=[0,+i(t[d],h,d,t)],l.data=t[d];p.key=h}for(o=0,u=e(f);o<s;++o)f[u[o]].index=o;return r(f,u),f}var n=ly([]),e=um,r=om,i=wc;return t.keys=function(e){return arguments.length?(n="function"==typeof e?e:ly(Py.call(e)),t):n},t.value=function(n){return arguments.length?(i="function"==typeof n?n:ly(+n),t):i},t.order=function(n){return arguments.length?(e=null==n?um:"function"==typeof n?n:ly(Py.call(n)),t):e},t.offset=function(n){return arguments.length?(r=null==n?om:n,t):r},t},t.stackOffsetExpand=function(t,n){if((r=t.length)>0){for(var e,r,i,o=0,u=t[0].length;o<u;++o){for(i=e=0;e<r;++e)i+=t[e][o][1]||0;if(i)for(e=0;e<r;++e)t[e][o][1]/=i}om(t,n)}},t.stackOffsetDiverging=function(t,n){if((a=t.length)>1)for(var e,r,i,o,u,a,c=0,s=t[n[0]].length;c<s;++c)for(o=u=0,e=0;e<a;++e)(i=(r=t[n[e]][c])[1]-r[0])>=0?(r[0]=o,r[1]=o+=i):i<0?(r[1]=u,r[0]=u+=i):r[0]=o},t.stackOffsetNone=om,t.stackOffsetSilhouette=function(t,n){if((e=t.length)>0){for(var e,r=0,i=t[n[0]],o=i.length;r<o;++r){for(var u=0,a=0;u<e;++u)a+=t[u][r][1]||0;i[r][1]+=i[r][0]=-a/2}om(t,n)}},t.stackOffsetWiggle=function(t,n){if((i=t.length)>0&&(r=(e=t[n[0]]).length)>0){for(var e,r,i,o=0,u=1;u<r;++u){for(var a=0,c=0,s=0;a<i;++a){for(var f=t[n[a]],l=f[u][1]||0,h=(l-(f[u-1][1]||0))/2,p=0;p<a;++p){var d=t[n[p]];h+=(d[u][1]||0)-(d[u-1][1]||0)}c+=l,s+=h*l}e[u-1][1]+=e[u-1][0]=o,c&&(o-=s/c)}e[u-1][1]+=e[u-1][0]=o,om(t,n)}},t.stackOrderAscending=am,t.stackOrderDescending=function(t){return am(t).reverse()},t.stackOrderInsideOut=function(t){var n,e,r=t.length,i=t.map(Mc),o=um(t).sort(function(t,n){return i[n]-i[t]}),u=0,a=0,c=[],s=[];for(n=0;n<r;++n)e=o[n],u<a?(u+=i[e],c.push(e)):(a+=i[e],s.push(e));return s.reverse().concat(c)},t.stackOrderNone=um,t.stackOrderReverse=function(t){return um(t).reverse()},t.timeInterval=Nu,t.timeMillisecond=O_,t.timeMilliseconds=F_,t.utcMillisecond=O_,t.utcMilliseconds=F_,t.timeSecond=B_,t.timeSeconds=j_,t.utcSecond=B_,t.utcSeconds=j_,t.timeMinute=H_,t.timeMinutes=X_,t.timeHour=$_,t.timeHours=V_,t.timeDay=W_,t.timeDays=Z_,t.timeWeek=G_,t.timeWeeks=rg,t.timeSunday=G_,t.timeSundays=rg,t.timeMonday=J_,t.timeMondays=ig,t.timeTuesday=Q_,t.timeTuesdays=og,t.timeWednesday=K_,t.timeWednesdays=ug,t.timeThursday=tg,t.timeThursdays=ag,t.timeFriday=ng,t.timeFridays=cg,t.timeSaturday=eg,t.timeSaturdays=sg,t.timeMonth=fg,t.timeMonths=lg,t.timeYear=hg,t.timeYears=pg,t.utcMinute=dg,t.utcMinutes=vg,t.utcHour=_g,t.utcHours=gg,t.utcDay=yg,t.utcDays=mg,t.utcWeek=xg,t.utcWeeks=Sg,t.utcSunday=xg,t.utcSundays=Sg,t.utcMonday=bg,t.utcMondays=Eg,t.utcTuesday=wg,t.utcTuesdays=Ag,t.utcWednesday=Mg,t.utcWednesdays=Cg,t.utcThursday=Tg,t.utcThursdays=zg,t.utcFriday=Ng,t.utcFridays=Pg,t.utcSaturday=kg,t.utcSaturdays=Rg,t.utcMonth=Lg,t.utcMonths=qg,t.utcYear=Ug,t.utcYears=Og,t.timeFormatDefaultLocale=Na,t.timeFormatLocale=zu,t.isoFormat=jg,t.isoParse=Hg,t.now=ln,t.timer=dn,t.timerFlush=vn,t.timeout=Ll,t.interval=function(t,n,e){var r=new pn,i=n;return null==n?(r.restart(t,n,e),r):(n=+n,e=null==e?ln():+e,r.restart(function o(u){u+=i,r.restart(o,i+=n,e),t(u)},n,e),r)},t.transition=Jn,t.active=function(t,n){var e,r,i=t.__transition;if(i){n=null==n?null:n+"";for(r in i)if((e=i[r]).state>Ol&&e.name===n)return new Gn([[t]],mh,n,+r)}return null},t.interrupt=Xl,t.voronoi=function(){function t(t){return new ns(t.map(function(r,i){var o=[Math.round(n(r,i,t)/_m)*_m,Math.round(e(r,i,t)/_m)*_m];return o.index=i,o.data=r,o}),r)}var n=Tc,e=Nc,r=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(e){return arguments.length?(n="function"==typeof e?e:cm(+e),t):n},t.y=function(n){return arguments.length?(e="function"==typeof n?n:cm(+n),t):e},t.extent=function(n){return arguments.length?(r=null==n?null:[[+n[0][0],+n[0][1]],[+n[1][0],+n[1][1]]],t):r&&[[r[0][0],r[0][1]],[r[1][0],r[1][1]]]},t.size=function(n){return arguments.length?(r=null==n?null:[[0,0],[+n[0],+n[1]]],t):r&&[r[1][0]-r[0][0],r[1][1]-r[0][1]]},t},t.zoom=function(){function n(t){t.property("__zoom",cs).on("wheel.zoom",s).on("mousedown.zoom",f).on("dblclick.zoom",l).filter(b).on("touchstart.zoom",p).on("touchmove.zoom",d).on("touchend.zoom touchcancel.zoom",v).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function e(t,n){return(n=Math.max(w,Math.min(M,n)))===t.k?t:new rs(n,t.x,t.y)}function r(t,n,e){var r=n[0]-e[0]*t.k,i=n[1]-e[1]*t.k;return r===t.x&&i===t.y?t:new rs(t.k,r,i)}function i(t,n){var e=t.invertX(n[0][0])-T,r=t.invertX(n[1][0])-N,i=t.invertY(n[0][1])-S,o=t.invertY(n[1][1])-E;return t.translate(r>e?(e+r)/2:Math.min(0,e)||Math.max(0,r),o>i?(i+o)/2:Math.min(0,i)||Math.max(0,o))}function o(t){return[(+t[0][0]+ +t[1][0])/2,(+t[0][1]+ +t[1][1])/2]}function u(t,n,e){t.on("start.zoom",function(){a(this,arguments).start()}).on("interrupt.zoom end.zoom",function(){a(this,arguments).end()}).tween("zoom",function(){var t=this,r=arguments,i=a(t,r),u=m.apply(t,r),c=e||o(u),s=Math.max(u[1][0]-u[0][0],u[1][1]-u[0][1]),f=t.__zoom,l="function"==typeof n?n.apply(t,r):n,h=C(f.invert(c).concat(s/f.k),l.invert(c).concat(s/l.k));return function(t){if(1===t)t=l;else{var n=h(t),e=s/n[2];t=new rs(e,c[0]-n[0]*e,c[1]-n[1]*e)}i.zoom(null,t)}})}function a(t,n){for(var e,r=0,i=z.length;r<i;++r)if((e=z[r]).that===t)return e;return new c(t,n)}function c(t,n){this.that=t,this.args=n,this.index=-1,this.active=0,this.extent=m.apply(t,n)}function s(){if(y.apply(this,arguments)){var t=a(this,arguments),n=this.__zoom,o=Math.max(w,Math.min(M,n.k*Math.pow(2,x.apply(this,arguments)))),u=nf(this);if(t.wheel)t.mouse[0][0]===u[0]&&t.mouse[0][1]===u[1]||(t.mouse[1]=n.invert(t.mouse[0]=u)),clearTimeout(t.wheel);else{if(n.k===o)return;t.mouse=[u,n.invert(u)],Xl(this),t.start()}xm(),t.wheel=setTimeout(function(){t.wheel=null,t.end()},L),t.zoom("mouse",i(r(e(n,o),t.mouse[0],t.mouse[1]),t.extent))}}function f(){if(!g&&y.apply(this,arguments)){var n=a(this,arguments),e=ff(t.event.view).on("mousemove.zoom",function(){if(xm(),!n.moved){var e=t.event.clientX-u,o=t.event.clientY-c;n.moved=e*e+o*o>q}n.zoom("mouse",i(r(n.that.__zoom,n.mouse[0]=nf(n.that),n.mouse[1]),n.extent))},!0).on("mouseup.zoom",function(){e.on("mousemove.zoom mouseup.zoom",null),_t(t.event.view,n.moved),xm(),n.end()},!0),o=nf(this),u=t.event.clientX,c=t.event.clientY;pf(t.event.view),os(),n.mouse=[o,this.__zoom.invert(o)],Xl(this),n.start()}}function l(){if(y.apply(this,arguments)){var o=this.__zoom,a=nf(this),c=o.invert(a),s=i(r(e(o,o.k*(t.event.shiftKey?.5:2)),a,c),m.apply(this,arguments));xm(),A>0?ff(this).transition().duration(A).call(u,s,a):ff(this).call(n.transform,s)}}function p(){if(y.apply(this,arguments)){var n,e,r,i,o=a(this,arguments),u=t.event.changedTouches,c=u.length;for(os(),e=0;e<c;++e)r=u[e],i=[i=lf(this,u,r.identifier),this.__zoom.invert(i),r.identifier],o.touch0?o.touch1||(o.touch1=i):(o.touch0=i,n=!0);if(_&&(_=clearTimeout(_),!o.touch1))return o.end(),void((i=ff(this).on("dblclick.zoom"))&&i.apply(this,arguments));n&&(_=setTimeout(function(){_=null},R),Xl(this),o.start())}}function d(){var n,o,u,c,s=a(this,arguments),f=t.event.changedTouches,l=f.length;for(xm(),_&&(_=clearTimeout(_)),n=0;n<l;++n)o=f[n],u=lf(this,f,o.identifier),s.touch0&&s.touch0[2]===o.identifier?s.touch0[0]=u:s.touch1&&s.touch1[2]===o.identifier&&(s.touch1[0]=u);if(o=s.that.__zoom,s.touch1){var h=s.touch0[0],p=s.touch0[1],d=s.touch1[0],v=s.touch1[1],g=(g=d[0]-h[0])*g+(g=d[1]-h[1])*g,y=(y=v[0]-p[0])*y+(y=v[1]-p[1])*y;o=e(o,Math.sqrt(g/y)),u=[(h[0]+d[0])/2,(h[1]+d[1])/2],c=[(p[0]+v[0])/2,(p[1]+v[1])/2]}else{if(!s.touch0)return;u=s.touch0[0],c=s.touch0[1]}s.zoom("touch",i(r(o,u,c),s.extent))}function v(){var n,e,r=a(this,arguments),i=t.event.changedTouches,o=i.length;for(os(),g&&clearTimeout(g),g=setTimeout(function(){g=null},R),n=0;n<o;++n)e=i[n],r.touch0&&r.touch0[2]===e.identifier?delete r.touch0:r.touch1&&r.touch1[2]===e.identifier&&delete r.touch1;r.touch1&&!r.touch0&&(r.touch0=r.touch1,delete r.touch1),r.touch0?r.touch0[1]=this.__zoom.invert(r.touch0[0]):r.end()}var _,g,y=us,m=as,x=ss,b=fs,w=0,M=1/0,T=-M,N=M,S=T,E=N,A=250,C=yl,z=[],P=h("start","zoom","end"),R=500,L=150,q=0;return n.transform=function(t,n){var e=t.selection?t.selection():t;e.property("__zoom",cs),t!==e?u(t,n):e.interrupt().each(function(){a(this,arguments).start().zoom(null,"function"==typeof n?n.apply(this,arguments):n).end()})},n.scaleBy=function(t,e){n.scaleTo(t,function(){return this.__zoom.k*("function"==typeof e?e.apply(this,arguments):e)})},n.scaleTo=function(t,u){n.transform(t,function(){var t=m.apply(this,arguments),n=this.__zoom,a=o(t),c=n.invert(a);return i(r(e(n,"function"==typeof u?u.apply(this,arguments):u),a,c),t)})},n.translateBy=function(t,e,r){n.transform(t,function(){return i(this.__zoom.translate("function"==typeof e?e.apply(this,arguments):e,"function"==typeof r?r.apply(this,arguments):r),m.apply(this,arguments))})},n.translateTo=function(t,e,r){n.transform(t,function(){var t=m.apply(this,arguments),n=this.__zoom,u=o(t);return i(mm.translate(u[0],u[1]).scale(n.k).translate("function"==typeof e?-e.apply(this,arguments):-e,"function"==typeof r?-r.apply(this,arguments):-r),t)})},c.prototype={start:function(){return 1==++this.active&&(this.index=z.push(this)-1,this.emit("start")),this},zoom:function(t,n){return this.mouse&&"mouse"!==t&&(this.mouse[1]=n.invert(this.mouse[0])),this.touch0&&"touch"!==t&&(this.touch0[1]=n.invert(this.touch0[0])),this.touch1&&"touch"!==t&&(this.touch1[1]=n.invert(this.touch1[0])),this.that.__zoom=n,this.emit("zoom"),this},end:function(){return 0==--this.active&&(z.splice(this.index,1),this.index=-1,this.emit("end")),this},emit:function(t){k(new es(n,t,this.that.__zoom),P.apply,P,[t,this.that,this.args])}},n.wheelDelta=function(t){return arguments.length?(x="function"==typeof t?t:ym(+t),n):x},n.filter=function(t){return arguments.length?(y="function"==typeof t?t:ym(!!t),n):y},n.touchable=function(t){return arguments.length?(b="function"==typeof t?t:ym(!!t),n):b},n.extent=function(t){return arguments.length?(m="function"==typeof t?t:ym([[+t[0][0],+t[0][1]],[+t[1][0],+t[1][1]]]),n):m},n.scaleExtent=function(t){return arguments.length?(w=+t[0],M=+t[1],n):[w,M]},n.translateExtent=function(t){return arguments.length?(T=+t[0][0],N=+t[1][0],S=+t[0][1],E=+t[1][1],n):[[T,S],[N,E]]},n.duration=function(t){return arguments.length?(A=+t,n):A},n.interpolate=function(t){return arguments.length?(C=t,n):C},n.on=function(){var t=P.on.apply(P,arguments);return t===P?n:t},n.clickDistance=function(t){return arguments.length?(q=(t=+t)*t,n):Math.sqrt(q)},n},t.zoomTransform=is,t.zoomIdentity=mm,Object.defineProperty(t,"__esModule",{value:!0})}); 

\ No newline at end of file

@@ -28,8 +28,11 @@ 

      </div>

      <div class="col-10">

        <section id="stats">

-         <span id="data_stats_spinner" class="hidden"></span>

-         <span id="data_stats" class="hidden"></span>

+         <section id="data_stats_spinner" class="hidden"></section>

+         <span id="commiter_list" class="hidden"></span>

+         <canvas nonce="{{ g.nonce }}" id="commit_trend_graph" class="hidden commit_trend"></canvas>

+         <canvas nonce="{{ g.nonce }}" id="issue_trend_graph" class="hidden issue_trend"></canvas>

+         <canvas nonce="{{ g.nonce }}" id="total_issue_trend_graph" class="hidden issue_trend"></canvas>

        </section>

      </div>

    </div>
@@ -38,7 +41,7 @@ 

  {% block jscripts %}

  {{ super() }}

  <script type="text/javascript" nonce="{{ g.nonce }}" src="{{

-   url_for('static', filename='vendor/d3/d3.v4.min.js') }}?version={{ g.version}}"></script>

+   url_for('static', filename='vendor/chartjs/chartjs-2.9.3.min.js') }}?version={{ g.version}}"></script>

  <script type="text/javascript" nonce="{{ g.nonce }}" src="{{

    url_for('static', filename='issues_stats.js') }}?version={{ g.version}}"></script>

  
@@ -55,31 +58,35 @@ 

                      username=username,

                      namespace=repo.namespace,

                      author='---') }}";

+ 

  {% if g.issues_enabled %}

  issues_history_stats_plot_call = function() {

+   $("#commiter_list").hide();

+   $(".commit_trend").hide();

    var _stats_url = "{{ url_for(

      'api_ns.api_view_issues_history_stats',

      repo=g.repo.name,

      username=username,

-     namespace=g.repo.namespace,) }}";

-   var _b = $("#data_stats");

+     namespace=g.repo.namespace,

+     detailed=True) }}";

    var _s = $("#data_stats_spinner");

    _s.html(

      "<img id='spinnergif' src='{{ url_for('static', filename='images/spinner.gif') }}?version={{ g.version}}'>"

    )

    _s.show();

-   _b.html(

-     "<h2>Issues stats</h2><p>Number of issues open on 7 days windows</p>"

-     + "<svg width=\"100%\" height=\"250\"></svg>"

-   );

-   issues_history_stats_plot(_stats_url, _b, _s);

+   $.get(_stats_url)

+   .done(function(data){

+     issues_history_stats_plot(data);

+   });

  };

  {% endif %}

  

  commits_authors_call = function() {

    if (repo_exists){

+     $(".commit_trend").hide();

+     $(".issue_trend").hide();

      var _stats_url = "{{ url_for('internal_ns.get_stats_commits') }}";

-     var _b = $("#data_stats");

+     var _b = $("#data_list");

      var _s = $("#data_stats_spinner");

      _s.html(

        "<img id='spinnergif' src='{{ url_for('static', filename='images/spinner.gif') }}?version={{ g.version}}'>"
@@ -93,7 +100,7 @@ 

      }

      process_async(_stats_url, data, show_commits_authors);

    } else {

-     var _b = $("#data_stats");

+     var _b = $("#data_list");

      var html = '<h2>Authors stats</h2>'

      html += '<div class="alert alert-info">This project\'s repo is empty. No stats available.</div>';

    _b.html(html);
@@ -103,6 +110,8 @@ 

  

  commits_history_call = function() {

    if (repo_exists){

+     $("#commiter_list").hide();

+     $(".issue_trend").hide();

      var _stats_url = "{{ url_for('internal_ns.get_stats_commits_trend') }}";

      var _b = $("#data_stats");

      var _s = $("#data_stats_spinner");
@@ -122,11 +131,11 @@ 

      }

      process_async(_stats_url, data, show_commits_history);

    } else {

-     var _b = $("#data_stats");

+     var _b = $("#commiter_list");

      var html = '<h2>Commits stats</h2>'

      html += '<div class="alert alert-info">This project\'s repo is empty. No stats available.</div>';

-   _b.html(html);

-   _b.show();

+     _b.html(html);

+     _b.show();

    }

  };

  
@@ -134,8 +143,6 @@ 

  $(document).ready(function() {

    $('.stats_btn').click(function(ev){

      ev.preventDefault();

-     var _b = $("#data_stats");

-     _b.hide();

      $('.stats_btn').removeClass('active');

      if ($(this).attr('name') == 'issues') {

        {% if g.issues_enabled %}

@@ -4230,7 +4230,7 @@ 

          """ Test the api_view_issues_history_stats method of the flask api. """

          self.test_api_new_issue()

  

-         # Create private issue

+         # Create private issue, closed and without a closed_at date

          repo = pagure.lib.query.get_authorized_project(self.session, "test")

          msg = pagure.lib.query.new_issue(

              session=self.session,
@@ -4255,6 +4255,27 @@ 

          for k in sorted(data["stats"].keys())[:-1]:

              self.assertEqual(data["stats"][k], 0)

  

+     def test_api_view_issues_history_stats_detailed(self):

+         """ Test the api_view_issues_history_stats method of the flask api. """

+         self.test_api_new_issue()

+ 

+         output = self.app.get("/api/0/test/issues/history/detailed_stats")

+         self.assertEqual(output.status_code, 200)

+         data = json.loads(output.get_data(as_text=True))

+ 

+         self.assertEqual(list(data.keys()), ["stats"])

+         self.assertEqual(len(data["stats"]), 53)

+         last_key = sorted(data["stats"].keys())[-1]

+         self.assertEqual(

+             data["stats"][last_key],

+             {"closed_ticket": 0, "count": 0, "open_ticket": 1},

+         )

+         for k in sorted(data["stats"].keys())[:-1]:

+             self.assertEqual(

+                 data["stats"][k],

+                 {"closed_ticket": 0, "count": 0, "open_ticket": 0},

+             )

+ 

      def test_api_view_user_issues_pingou(self):

          """ Test the api_view_user_issues method of the flask api for pingou.

          """

Welp...

15:43:06  Failed tests:
15:43:06  FAILED test: py3-test_pagure_flask_api_issue

rebased onto 72993d8837a4be3405891b60ee918abec4462543

4 years ago

Would it be possible to add a 3rd item on the tickets: 'total open' ie, the number of open tickets at the start of the week? this would allow you to see easier if backlog was increasing or declining over time.

@kevin I think this was the original idea of this graph but doesn't quite work as expected, I may have an idea though, let's see if that'll work :)

(these are the pagure issues, I'm working on the infra ones to see if they work as well)

Wow, that looks great! : D

@kevin how does this look?
Screenshot_from_2020-04-16_21-02-14.png

Looks great

This looks fantastic!

Awesome! The only nitpick I might have is that I am not sure blue and pink are good colors to use here... not sure what is tho...

great work!

It's actually blue and red, but the alpha layer make the red pinkish yeah :)

I'll see if I can make it a little darker to increase the contrast

4 new commits added

  • Add unit-tests for the detailed view of the issue stats
  • Adjust the red color in the stats graph to increase the contrast
  • Add a new chart tracking the number of open issues throughout the year
  • Rework the detailed provided for the issue stats
4 years ago

Now with unit-tests for the change to the API endpoint.

I've tweaked a little bit the color, but I doubt it's ideal yet, though I figure we can always tweak it more later :)

I don't fully understand this apidoc. Whitout detailed returns info for that week but with detailed for the last 53 weeks? Seems like a c&p glitch :)

It always returns the last 53 weeks, the detailed view as just more info than the non-detailed view.
Tbh, if it was me I'd make the default view be the detailed one, but that would be breaking API so no-go :(

Maybe it would make sense to have a new API endpoint for this, so we can simply remove the old one at some point in the future.

this could be _be instead of callling jquery's selector again? _b already has #commiter-list block from line 155

we were using the d3's minimized version, but now we include Chart.js's non minimized one. Should we import the minimized one?

does the heatmap thing depend on d3.v4.min.jis that this pr removes? (did not test it) or it conitnues working after this?

We have both version for chartjs, we can use the minimized one sure

6 new commits added

  • Add unit-tests for the detailed view of the issue stats
  • Adjust the red color in the stats graph to increase the contrast
  • Add a new chart tracking the number of open issues throughout the year
  • Rework the detailed provided for the issue stats
  • Improve the graph displayed in the stats tab of each projects
  • Add an option to retrieve detailed stats about issues in the API
4 years ago

rebased onto 11a9d5b05800cf866e71636269feb33a585b27b3

4 years ago

rebased onto 1b3a28eb00248bbb6f68da53a6b76b5ff2239d2b

4 years ago

rebased onto 4f0011e

4 years ago

lgtm once Jenkins is happy

Jenkins is happy, I'm happy people like the screenshots.

So let's get this in!

Pull-Request has been merged by pingou

4 years ago