Skip to content

Instantly share code, notes, and snippets.

@cpsievert
Created September 2, 2014 22:24
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save cpsievert/ab9767de8f26b97bf658 to your computer and use it in GitHub Desktop.
Save cpsievert/ab9767de8f26b97bf658 to your computer and use it in GitHub Desktop.
// Define functions to render linked interactive plots using d3.
// Another script should define e.g.
// <script>
// var plot = new animint("#plot","path/to/plot.json");
// </script>
// Constructor for animint Object.
var animint = function (to_select, json_file) {
var dirs = json_file.split("/");
dirs.pop(); //if a directory path exists, remove the JSON file from dirs
var element = d3.select(to_select);
this.element = element;
var Widgets = {};
this.Widgets = Widgets;
var Selectors = {};
this.Selectors = Selectors;
var Plots = {};
this.Plots = Plots;
var Geoms = {};
this.Geoms = Geoms;
// SVGs must be stored separately from Geoms since they are
// initialized first, with the Plots.
var SVGs = {};
this.SVGs = SVGs;
var Animation = {};
this.Animation = Animation;
var all_geom_names = {};
this.all_geom_names = all_geom_names;
var css = document.createElement('style');
css.type = 'text/css';
var styles = [".axis path{fill: none;stroke: black;shape-rendering: crispEdges;}",
".axis line{fill: none;stroke: black;shape-rendering: crispEdges;}",
".axis text {font-family: sans-serif;font-size: 11px;}"];
var axispaddingx = 60;
var axispaddingy = 60;
var labelpaddingx = 35;
var labelpaddingy = 35;
var titlepadding = 30;
var margin = {
left: labelpaddingy + axispaddingy,
right: 0,
top: titlepadding,
bottom: labelpaddingx + axispaddingx
};
var plotdim = {
width: 0,
height: 0,
xstart: 0,
xend: 0,
ystart: 0,
yend: 0,
graph: {
width: 0,
height: 0
},
margin: margin,
xlab: {
x: 0,
y: 0
},
ylab: {
x: 0,
y: 0
},
title: {
x: 0,
y: 0
}
};
var add_geom = function (g_name, g_info) {
// Determine what style to use to show the selection for this
// geom. This is a hack and should be removed when we implement
// the selected.color, selected.size, etc aesthetics.
if(g_info.aes.hasOwnProperty("fill") &&
g_info.geom == "rect"){
g_info.select_style = "stroke";
}else{
g_info.select_style = "opacity";
}
// Add a row to the loading table.
g_info.tr = Widgets["loading"].append("tr");
g_info.tr.append("td").text(g_name);
g_info.tr.append("td").attr("class", "chunk");
g_info.tr.append("td").attr("class", "downloaded").text(0);
g_info.tr.append("td").text(g_info.total);
g_info.tr.append("td").attr("class", "status").text("initialized");
// Save this geom and load it!
g_info.data = {};
g_info.download_status = {};
Geoms[g_name] = g_info;
update_geom(g_name, null);
}
var add_plot = function (p_name, p_info) {
// Each plot may have one or more legends. To make space for the
// legends, we put each plot in a table with one row and two
// columns: tdLeft and tdRight.
var plot_table = element.append("table").style("display", "inline-block");
var plot_tr = plot_table.append("tr");
var tdLeft = plot_tr.append("td");
var tdRight = plot_tr.append("td").attr("id", p_name+"_legend");
var svg = tdLeft.append("svg")
.attr("id", p_name)
.attr("height", p_info.options.height)
.attr("width", p_info.options.width);
// divvy up width/height based on the panel layout
var nrows = Math.max.apply(null, p_info.layout.ROW);
var ncols = Math.max.apply(null, p_info.layout.COL);
var panel_names = p_info.layout.PANEL;
var npanels = Math.max.apply(null, panel_names);
plotdim.width = p_info.options.width / ncols;
plotdim.height = p_info.options.height / nrows;
// Draw the title
titlepadding = measureText(p_info.title, 20).height + 10;
plotdim.title.x = p_info.options.width / 2;
plotdim.title.y = plotdim.margin.top / 2;
svg.append("text")
.text(p_info.title)
.attr("id", "plottitle")
.attr("class", "title")
.attr("font-family", "sans-serif")
.attr("font-size", "20px")
.attr("transform", "translate(" + (plotdim.title.x) + "," + (
plotdim.title.y) + ")")
.style("text-anchor", "middle");
// Note axis names are "shared" across panels (just like the title)
// TODO: add an option to adjust font size?
labelpaddingx = 5 + measureText(p_info["xname"], 11).height;
labelpaddingy = 5 + measureText(p_info["yname"], 11).height;
// grab max text size over axis labels and panels for each axis
axispaddingy = 5 + Math.max.apply(null, p_info.ylabs.map(function(entry){
return measureText(entry, 11).width;
}));
axispaddingx = 5 + Math.max.apply(null, p_info.xlabs.map(function(entry){
return measureText(entry, 11).height;
}));
// margins should be fixed across panels
margin.left = labelpaddingy + axispaddingy;
margin.top = titlepadding;
margin.bottom = labelpaddingx + axispaddingx;
margin.right = 5 + Math.max.apply(null, p_info.xlabs.map(function(entry){
return measureText(entry, 11).width;
})); // to ensure the last x-axis label doesn't get cut off.
plotdim.margin = margin;
// the *entire plot* height/width
plotdim.width = p_info.options.width;
plotdim.height = p_info.options.height;
// the *entire graph* height/width
var graph_width = plotdim.width - ncols * (margin.left + margin.right);
var graph_height = plotdim.height - nrows * (margin.top + margin.bottom);
// Impose the pixelated aspect ratio of the graph upon the width/height
// proportions calculated by the compiler. This has to be done on the
// rendering side since the precomputed proportions apply to the *graph*
// and the graph size depends upon results of measureText()
if (p_info.layout.coord_fixed[0]) {
var aspect = (graph_height / nrows) / (graph_width / ncols);
} else {
var aspect = 1;
}
var wp = p_info.layout.width_proportion.map(function(x){
return x * Math.min(1, aspect);
})
var hp = p_info.layout.height_proportion.map(function(x){
return x * Math.min(1, 1/aspect);
})
// add any change in the width/height proportion to x/y displacement
var xdisplace = p_info.layout.xdisplace;
var ydisplace = p_info.layout.ydisplace;
for (var layout_i = 0; layout_i < npanels; layout_i++) {
xdisplace[layout_i] = xdisplace[layout_i] + (p_info.layout.width_proportion[layout_i] - wp[layout_i])/2;
ydisplace[layout_i] = ydisplace[layout_i] + (p_info.layout.height_proportion[layout_i] - hp[layout_i])/2;
}
// Bind plot data to this plot's SVG element
svg.plot = p_info;
Plots[p_name] = p_info;
p_info.geoms.forEach(function (g_name) {
var layer_g_element = svg.append("g").attr("class", g_name);
panel_names.forEach(function(PANEL){
layer_g_element.append("g").attr("class", "PANEL" + PANEL);
});
SVGs[g_name] = svg;
});
// If we are to draw more than one panel,
// create a grouping for strip labels
if (npanels > 1) {
svg.append("g")
.attr("class", "strip")
.attr("id", "top_strip");
svg.append("g")
.attr("class", "strip")
.attr("id", "right_strip");
}
// this will hold x/y scales for each panel
// eventually we inject this into Plots[p_name]
var scales = {};
// Draw a plot outline for every panel
for (var layout_i = 0; layout_i < npanels; layout_i++) {
var panel_i = layout_i + 1;
var axis = p_info["axis" + panel_i];
//forces values to be in an array
var xaxisvals = [];
var xaxislabs = [];
var yaxisvals = [];
var yaxislabs = [];
//function to write labels and breaks to their respective arrays
var axislabs = function(breaks, labs, axis){
if(axis=="x"){
outbreaks = xaxisvals;
outlabs = xaxislabs;
} else {
outbreaks = yaxisvals;
outlabs = yaxislabs;
} // set appropriate variable names
if (isArray(breaks)) {
breaks.forEach(function (d) {
outbreaks.push(d);
})
} else {
//breaks can be an object!
for (key in breaks) {
outbreaks.push(breaks[key]);
}
}
if (labs){
labs.forEach(function (d) {
outlabs.push(d);
// push each label provided into the array
});
} else {
breaks.forEach(function (d) {
outlabs.push("");
// push a blank string to the array for each axis tick
// if the specified label is null
});
}
}
axislabs(axis.x, axis.xlab, "x");
axislabs(axis.y, axis.ylab, "y");
var current_row = p_info.layout.ROW[layout_i];
var current_col = p_info.layout.COL[layout_i];
// calculate panel specific width/height to be used in placing axes, labels, etc.
// note that width/height proportion/displacement applies to the graph (not margins)
plotdim.graph.width = wp[layout_i] * graph_width;
plotdim.graph.height = hp[layout_i] * graph_height;
plotdim.xstart = xdisplace[layout_i] * graph_width +
current_col * plotdim.margin.left +
(current_col - 1) * plotdim.margin.right;
plotdim.xend = plotdim.xstart + plotdim.graph.width;
plotdim.ystart = ydisplace[layout_i] * graph_height +
current_row * plotdim.margin.top +
(current_row - 1) * plotdim.margin.bottom;
plotdim.yend = plotdim.ystart + plotdim.graph.height;
plotdim.xlab.x = plotdim.xstart + plotdim.graph.width / 2;
plotdim.xlab.y = axispaddingx + labelpaddingx / 2;
plotdim.ylab.x = axispaddingy + labelpaddingy / 2;
plotdim.ylab.y = plotdim.yend - plotdim.graph.height / 2;
// draw the y-axis title when drawing the first panel
if (layout_i === 0) {
svg.append("text")
.text(p_info["ytitle"])
.attr("class", "label")
.attr("id", "ytitle")
.style("text-anchor", "middle")
.style("font-size", "11px")
.attr("transform", "translate(" + (plotdim.xstart - axispaddingy - labelpaddingy / 2)
+ "," + (p_info.options.height / 2) + ")rotate(270)");
}
// draw the x-axis title when drawing the last panel
if (layout_i === (npanels - 1)) {
svg.append("text")
.text(p_info["xtitle"])
.attr("class", "label")
.attr("id", "xtitle")
.style("text-anchor", "middle")
.style("font-size", "11px")
.attr("transform", "translate(" + plotdim.title.x
+ "," + (plotdim.yend + axispaddingx + labelpaddingx / 2) + ")");
}
// idea: use the top/right margins to draw the facet title/strips
// problem: how do we guarantee strips are readable for an arbitrary
// number of strips?
if (npanels > 1) {
var stripLabels = {'top': [], 'right': []};
var strip_location = {};
strip_location.top = {
'x': plotdim.xlab.x,
'y': plotdim.ystart - plotdim.margin.top/2
};
strip_location.right = {
'x': plotdim.xend,
'y': plotdim.ylab.y
};
draw_strip = function(side) {
var x = strip_location[side].x;
var y = strip_location[side].y;
var stripLabs = stripLabels[side];
//create a group
svg.select("#" + side + "_strip")
.selectAll("." + side + "_strips")
.data(stripLabs)
.enter()
.append("text")
.style("text-anchor", "middle")
.text(function(d, i) { return d; })
// NOTE: there could be multiple strips per panel
// TODO: is there a better way to manage spacing?
.attr("transform", function(d, i) {
if (side == "top") {
var y2 = y + i * 12;
return "translate(" + x + "," + y + ")rotate(0)";
} else if (side == "right") { //right
var x2 = x - i * 12;
return "translate(" + x2 + "," + y + ")rotate(90)";
}
});
}
// if Array, facet_wrap() was used; otherwise, facet_grid()
if (p_info.strips instanceof Array) {
// strips should always be on top for facet_wrap(), right?
stripLabels.top = [p_info.strips[layout_i]];
draw_strip("top");
} else {
if (current_row == 1) {
stripLabels.top = [p_info.strips.top[current_col - 1]];
draw_strip("top");
}
if (current_col == ncols) {
stripLabels.right = [p_info.strips.right[current_row - 1]];
draw_strip("right");
}
}
}
// for each of the x and y axes, there is a "real" and fake
// version. The real version will be used for plotting the
// data, and the fake version is just for the display of the
// axes.
scales[panel_i] = {};
scales[panel_i].x = d3.scale.linear()
.domain([0, 1])
.range([plotdim.xstart, plotdim.xend]);
scales[panel_i].x_fake = d3.scale.linear()
.domain(axis.xrange)
.range([plotdim.xstart, plotdim.xend]);
scales[panel_i].y = d3.scale.linear()
.domain([0, 1])
.range([plotdim.yend, plotdim.ystart]);
scales[panel_i].y_fake = d3.scale.linear()
.domain([axis.yrange[1], axis.yrange[0]])
.range([plotdim.ystart, plotdim.yend]);
if(p_info.layout.AXIS_X[layout_i]){
var xaxis = d3.svg.axis()
.scale(scales[panel_i].x)
.tickValues(xaxisvals)
.tickFormat(function (d) {
return xaxislabs[xaxisvals.indexOf(d)].toString();
})
.orient("bottom");
svg.append("g")
.attr("class", "axis")
.attr("id", "xaxis")
.attr("transform", "translate(0," + plotdim.yend + ")")
.call(xaxis);
}
if(p_info.layout.AXIS_Y[layout_i]){
var yaxis = d3.svg.axis()
.scale(scales[panel_i].y)
.tickValues(yaxisvals)
.tickFormat(function (d) {
return yaxislabs[yaxisvals.indexOf(d)].toString();
})
.orient("left");
svg.append("g")
.attr("class", "axis")
.attr("id", "yaxis")
.attr("transform", "translate(" + (plotdim.xstart) + ",0)")
.call(yaxis);
}
if(!axis.xline) {
styles.push("#"+p_name+" #xaxis"+" path{stroke:none;}");
}
if(!axis.xticks) {
styles.push("#"+p_name+" #xaxis .tick"+" line{stroke:none;}");
}
if(!axis.yline) {
styles.push("#"+p_name+" #yaxis"+" path{stroke:none;}");
}
if(!axis.yticks) {
styles.push("#"+p_name+" #yaxis .tick"+" line{stroke:none;}");
}
} //end of for loop
Plots[p_name].scales = scales;
} //end of add_plot()
var add_selector = function (s_name, s_info) {
Selectors[s_name] = s_info;
}
var get_tsv = function(g_info, chunk_id){
return g_info.classed + "_chunk" + chunk_id + ".tsv";
}
// update_geom is called from add_geom and update_selector. It
// downloads data if necessary, and then calls draw_geom.
var update_geom = function (g_name, selector_name) {
var g_info = Geoms[g_name];
// First apply chunk_order selector variables.
var chunk_id = g_info.chunks;
g_info.chunk_order.forEach(function (v_name) {
if(chunk_id == null){
return; //no data in a higher up chunk var.
}
var value = Selectors[v_name].selected;
if(chunk_id.hasOwnProperty(value)){
chunk_id = chunk_id[value];
}else{
chunk_id = null; // no data to show in this subset.
}
});
if(chunk_id == null){
draw_panels(g_info, [], selector_name); //draw nothing.
return;
}
var tsv_name = get_tsv(g_info, chunk_id);
// get the data if it has not yet been downloaded.
g_info.tr.select("td.chunk").text(tsv_name);
if(g_info.data.hasOwnProperty(tsv_name)){
draw_panels(g_info, g_info.data[tsv_name], selector_name);
}else{
g_info.tr.select("td.status").text("downloading");
var svg = SVGs[g_name];
var loading = svg.append("text")
.attr("class", "loading"+tsv_name)
.text("Downloading "+tsv_name+"...")
.attr("font-size", 9)
.attr("y", 10)
.style("fill", "red")
//.attr("x", svg.attr("width")/2)
;
download_chunk(g_info, tsv_name, function(chunk){
loading.remove();
draw_panels(g_info, chunk, selector_name);
});
}
}
var draw_panels = function(g_info, chunk, selector_name) {
// derive the plot name from the geometry name
var g_names = g_info.classed.split("_");
var p_name = g_names[g_names.length - 1];
var panels = Plots[p_name].layout.PANEL;
panels.forEach(function(panel) {
draw_geom(g_info, chunk, selector_name, panel);
});
}
var download_sequence = function(g_name, s_name, seq){
var g_info = Geoms[g_name];
var s_info = Selectors[s_name];
g_info.seq_i = seq.indexOf(s_info.selected);
g_info.seq_count = 0;
g_info.seq = seq;
download_next(g_name);
}
var download_next = function(g_name){
var g_info = Geoms[g_name];
var selector_value = g_info.seq[g_info.seq_i];
var chunk_id = g_info.chunks[selector_value];
var tsv_name = get_tsv(g_info, chunk_id);
g_info.seq_count += 1;
if(g_info.seq_count > g_info.seq.length){
return;
}
g_info.seq_i += 1;
if(g_info.seq_i == g_info.seq.length){
g_info.seq_i = 0;
}
download_chunk(g_info, tsv_name, function(chunk){
download_next(g_name);
})
}
// download_chunk is called from update_geom and download_sequence.
var download_chunk = function(g_info, tsv_name, funAfter){
if(g_info.download_status.hasOwnProperty(tsv_name)){
for (i = 0; i < 6; i++) {
funAfter();
}
return; // do not download twice.
}
g_info.download_status[tsv_name] = "downloading";
//prefix tsv file with appropriate path
var tsv_file = dirs.concat(tsv_name).join("/");
d3.tsv(tsv_file, function (error, response) {
// First convert to correct types.
g_info.download_status[tsv_name] = "processing";
response.forEach(function (d) {
for (var v_name in g_info.types) {
var r_type = g_info.types[v_name];
if (r_type == "integer") {
d[v_name] = parseInt(d[v_name]);
} else if (r_type == "numeric") {
d[v_name] = parseFloat(d[v_name]);
} else if (r_type == "factor") {
//keep it as a character.
} else if (r_type == "rgb") {
//keep it as a character.
} else if (r_type == "linetype") {
//keep it as a character.
} else if (r_type == "label") {
//keep it as a character
} else if (r_type == "character" & v_name == "outliers") {
d[v_name] = parseFloat(d[v_name].split(" @ "));
} else {
throw "unsupported R type " + r_type;
}
}
});
var nest = d3.nest();
g_info.nest_order.forEach(function (v_name) {
nest.key(function (d) {
return d[v_name];
});
});
var chunk = nest.map(response);
g_info.data[tsv_name] = chunk;
g_info.tr.select("td.downloaded").text(d3.keys(g_info.data).length);
g_info.download_status[tsv_name] = "saved";
funAfter(chunk);
});
}
// update_geom is responsible for obtaining a chunk of downloaded
// data, and then calling draw_geom to actually draw it.
var draw_geom = function(g_info, chunk, selector_name, PANEL){
g_info.tr.select("td.status").text("displayed");
var svg = SVGs[g_info.classed];
var data = chunk;
// derive the plot name from the geometry name
var g_names = g_info.classed.split("_");
var p_name = g_names[g_names.length - 1];
var scales = Plots[p_name].scales[PANEL];
g_info.subset_order.forEach(function (aes_name) {
var value;
if (aes_name != "group") {
if(aes_name == "PANEL"){
value = PANEL;
}else{
var v_name = g_info.aes[aes_name];
value = Selectors[v_name].selected;
}
if (data.hasOwnProperty(value)) {
data = data[value];
} else {
data = [];
}
}
});
var aes = g_info.aes;
var toXY = function (xy, a) {
return function (d) {
return scales[xy](d[a]);
}
}
var layer_g_element = svg.select("g." + g_info.classed);
var panel_g_element = layer_g_element.select("g.PANEL" + PANEL);
var elements = panel_g_element.selectAll(".geom");
// TODO: standardize this code across aes/styles.
var base_opacity = 1;
if (g_info.params.alpha) {
base_opacity = g_info.params.alpha;
}
//alert(g_info.classed+" "+base_opacity);
var get_alpha = function (d) {
var a;
if (aes.hasOwnProperty("alpha") && d.hasOwnProperty("alpha")) {
a = d["alpha"];
} else {
a = base_opacity;
}
return a;
}
var size = 2;
if(g_info.geom == "text"){
size = 12;
}
if (g_info.params.hasOwnProperty("size")) {
size = g_info.params.size;
}
var get_size = function (d) {
if (aes.hasOwnProperty("size") && d.hasOwnProperty("size")) {
return d["size"];
}
return size;
}
var linetype = "solid";
if (g_info.params.linetype) {
linetype = g_info.params.linetype;
}
var get_dasharray = function (d) {
var lt;
if (aes.hasOwnProperty("linetype") && d.hasOwnProperty(
"linetype")) {
try {
lt = d["linetype"];
} catch (err) {
lt = g_info.params.linetype;
}
} else {
lt = linetype;
}
return linetypesize2dasharray(lt, get_size(d));
}
var colour = "black";
var fill = "black";
var get_colour = function (d) {
if (d.hasOwnProperty("colour")) {
return d["colour"]
}
return colour;
}
var get_fill = function (d) {
if (d.hasOwnProperty("fill")) {
return d["fill"];
}
return fill;
}
if (g_info.params.colour) {
colour = g_info.params.colour;
}
if (g_info.params.fill) {
fill = g_info.params.fill;
}else if(g_info.params.colour){
fill = g_info.params.colour;
}
var text_anchor = "middle";
if (g_info.params.hjust == 0) {
text_anchor = "start";
}
if (g_info.params.hjust == 1) {
text_anchor = "end";
}
var eActions, eAppend;
var key_fun = null;
if(g_info.aes.hasOwnProperty("key")){
key_fun = function(d){
return d.key;
};
}
if (g_info.geom == "line" || g_info.geom == "path" || g_info.geom == "polygon" || g_info.geom == "ribbon") {
// Lines, paths, polygons, and ribbons are a bit special. For
// every unique value of the group variable, we take the
// corresponding data rows and make 1 path. The tricky part is
// that to use d3 I do a data-bind of some "fake" data which are
// just group ids, which is the kv variable in the code below
// // case of only 1 line and no groups.
// if(!aes.hasOwnProperty("group")){
// kv = [{"key":0,"value":0}];
// data = {0:data};
// }else{
// // we need to use a path for each group.
// var kv = d3.entries(d3.keys(data));
// kv = kv.map(function(d){
// d[aes.group] = d.value;
// return d;
// });
// }
// For an example consider breakpointError$error which is
// defined using this R code
// geom_line(aes(segments, error, group=bases.per.probe,
// clickSelects=bases.per.probe), data=only.error, lwd=4)
// Inside update_geom the variables take the following values
// (pseudo-Javascript code)
// var kv = [{"key":"0","value":"133","bases.per.probe":"133"},
// {"key":"1","value":"2667","bases.per.probe":"2667"}];
// var data = {"133":[array of 20 points used to draw the line for group 133],
// "2667":[array of 20 points used to draw the line for group 2667]};
// I do elements.data(kv) so that when I set the d attribute of
// each path, I need to select the correct group before
// returning anything.
// e.attr("d",function(group_info){
// var one_group = data[group_info.value];
// return lineThing(one_group);
// })
// To make color work I think you just have to select the group
// and take the color of the first element, e.g.
// .style("stroke",function(group_info){
// var one_group = data[group_info.value];
// var one_row = one_group[0];
// return get_color(one_row);
// }
//In order to get d3 lines to play nice, bind fake "data" (group
//id's) -- the kv variable. Then each separate object is plotted
//using path (case of only 1 thing and no groups).
if (!aes.hasOwnProperty("group")) {
// There is either 1 or 0 groups.
if(data.length == 0){
kv = [];
} else {
kv = [{
"key": 0,
"value": 0
}];
data = {
0: data
};
}
} else {
// we need to use a path for each group.
var kv = d3.entries(d3.keys(data));
kv = kv.map(function (d) {
//d[aes.group] = d.value;
// Need to store the clickSelects value that will
// be passed to the selector when we click on this
// item.
d.clickSelects = data[d.value][0].clickSelects;
return d;
});
}
// line, path, and polygon use d3.svg.line(),
// ribbon uses d3.svg.area()
// we have to define lineThing accordingly.
if (g_info.geom == "ribbon") {
var lineThing = d3.svg.area()
.x(toXY("x", "x"))
.y(toXY("y", "ymax"))
.y0(toXY("y", "ymin"))
;
} else {
var lineThing = d3.svg.line()
.x(toXY("x", "x"))
.y(toXY("y", "y"))
;
}
//select the correct group before returning anything.
var group_key_fun = null;
if(key_fun != null){
group_key_fun = function(group_info){
var one_group = data[group_info.value];
var one_row = one_group[0];
//take key from first value in the group.
return key_fun(one_row);
};
}
elements = elements.data(kv);
eActions = function (e) {
e.attr("d", function (d) {
var one_group = data[d.value];
// filter NaN since they make the whole line disappear!
var no_na = one_group.filter(function(d){
if(g_info.geom == "ribbon"){
return !isNaN(d.x) && !isNaN(d.ymin) && !isNaN(d.ymax);
}else{
return !isNaN(d.x) && !isNaN(d.y);
}
})
return lineThing(no_na);
})
.style("fill", function (group_info) {
if (g_info.geom == "line" || g_info.geom == "path") {
return "none";
}
var one_group = data[group_info.value];
var one_row = one_group[0];
// take color for first value in the group
return get_fill(one_row);
})
.style("stroke-width", function (group_info) {
var one_group = data[group_info.value];
var one_row = one_group[0];
// take size for first value in the group
return get_size(one_row);
})
.style("stroke", function (group_info) {
var one_group = data[group_info.value];
var one_row = one_group[0];
// take color for first value in the group
return get_colour(one_row);
})
.style("stroke-dasharray", function (group_info) {
var one_group = data[group_info.value];
var one_row = one_group[0];
// take linetype for first value in the group
return get_dasharray(one_row);
})
.style("stroke-width", function (group_info) {
var one_group = data[group_info.value];
var one_row = one_group[0];
// take line size for first value in the group
return get_size(one_row);
});
}
eAppend = "path";
} else if (g_info.geom == "segment") {
elements = elements.data(data, key_fun);
eActions = function (e) {
e.attr("x1", function (d) {
return scales.x(d["x"]);
})
.attr("x2", function (d) {
return scales.x(d["xend"]);
})
.attr("y1", function (d) {
return scales.y(d["y"]);
})
.attr("y2", function (d) {
return scales.y(d["yend"]);
})
.style("stroke-dasharray", get_dasharray)
.style("stroke-width", get_size)
.style("stroke", get_colour);
}
eAppend = "line";
} else if (g_info.geom == "linerange") {
elements = elements.data(data, key_fun);
eActions = function (e) {
e.attr("x1", function (d) {
return scales.x(d["x"]);
})
.attr("x2", function (d) {
return scales.x(d["x"]);
})
.attr("y1", function (d) {
return scales.y(d["ymax"]);
})
.attr("y2", function (d) {
return scales.y(d["ymin"]);
})
.style("stroke-dasharray", get_dasharray)
.style("stroke-width", get_size)
.style("stroke", get_colour);
}
eAppend = "line";
} else if (g_info.geom == "vline") {
elements = elements.data(data, key_fun);
eActions = function (e) {
e.attr("x1", toXY("x", "xintercept"))
.attr("x2", toXY("x", "xintercept"))
.attr("y1", scales.y.range()[0])
.attr("y2", scales.y.range()[1])
.style("stroke-dasharray", get_dasharray)
.style("stroke-width", get_size)
.style("stroke", get_colour);
}
eAppend = "line";
} else if (g_info.geom == "hline") {
//pretty much a copy of geom_vline with obvious modifications
elements = elements.data(data, key_fun);
eActions = function (e) {
e.attr("y1", toXY("y", "yintercept"))
.attr("y2", toXY("y", "yintercept"))
.attr("x1", scales.x.range()[0] + plotdim.margin.left)
.attr("x2", scales.x.range()[1] - plotdim.margin.right)
.style("stroke-dasharray", get_dasharray)
.style("stroke-width", get_size)
.style("stroke", get_colour);
}
eAppend = "line";
} else if (g_info.geom == "text") {
elements = elements.data(data, key_fun);
// TODO: how to support vjust? firefox doensn't support
// baseline-shift... use paths?
// http://commons.oreilly.com/wiki/index.php/SVG_Essentials/Text
eActions = function (e) {
e.attr("x", toXY("x", "x"))
.attr("y", toXY("y", "y"))
.style("fill", get_colour)
.attr("font-size", get_size)
.style("text-anchor", text_anchor)
.text(function (d) {
return d.label;
});
}
eAppend = "text";
} else if (g_info.geom == "point") {
elements = elements.data(data, key_fun);
eActions = function (e) {
e.attr("cx", toXY("x", "x"))
.attr("cy", toXY("y", "y"))
.attr("r", get_size)
.style("fill", get_fill)
.style("stroke", get_colour);
}
eAppend = "circle";
} else if (g_info.geom == "jitter") {
elements = elements.data(data, key_fun);
eActions = function (e) {
e.attr("cx", toXY("x", "x"))
.attr("cy", toXY("y", "y"))
.attr("r", get_size)
.style("fill", get_fill)
.style("stroke", get_colour);
}
eAppend = "circle";
} else if (g_info.geom == "tallrect") {
elements = elements.data(data, key_fun);
eActions = function (e) {
e.attr("x", toXY("x", "xmin"))
.attr("width", function (d) {
return scales.x(d["xmax"]) - scales.x(d["xmin"]);
})
.attr("y", scales.y.range()[1])
.attr("height", scales.y.range()[0] - scales.y.range()[1])
.style("fill", get_fill)
.style("stroke-width", get_size)
.style("stroke", get_colour);
}
eAppend = "rect";
} else if (g_info.geom == "rect") {
elements = elements.data(data, key_fun);
eActions = function (e) {
e.attr("x", toXY("x", "xmin"))
.attr("width", function (d) {
return Math.abs(scales.x(d.xmax) - scales.x(d.xmin));
})
.attr("y", toXY("y", "ymax"))
.attr("height", function (d) {
return Math.abs(scales.y(d.ymin) - scales.y(d.ymax));
})
.style("stroke-dasharray", get_dasharray)
.style("stroke-width", get_size)
.style("fill", get_fill);
if(g_info.select_style != "stroke"){
e.style("stroke", get_colour);
}
}
eAppend = "rect";
} else if (g_info.geom == "boxplot") {
// TODO: currently boxplots are unsupported (we intentionally
// stop with an error in the R code). The reason why is that
// boxplots are drawn using multiple geoms and it is not
// straightforward to deal with that using our current JS
// code. After all, a boxplot could be produced by combing 3
// other geoms (rects, lines, and points) if you really wanted
// it.
fill = "white";
elements = elements.data(data);
eActions = function (e) {
e.append("line")
.attr("x1", function (d) {
return scales.x(d["x"]);
})
.attr("x2", function (d) {
return scales.x(d["x"]);
})
.attr("y1", function (d) {
return scales.y(d["ymin"]);
})
.attr("y2", function (d) {
return scales.y(d["lower"]);
})
.style("stroke-dasharray", get_dasharray)
.style("stroke-width", get_size)
.style("stroke", get_colour);
e.append("line")
.attr("x1", function (d) {
return scales.x(d["x"]);
})
.attr("x2", function (d) {
return scales.x(d["x"]);
})
.attr("y1", function (d) {
return scales.y(d["upper"]);
})
.attr("y2", function (d) {
return scales.y(d["ymax"]);
})
.style("stroke-dasharray", get_dasharray)
.style("stroke-width", get_size)
.style("stroke", get_colour);
e.append("rect")
.attr("x", function (d) {
return scales.x(d["xmin"]);
})
.attr("width", function (d) {
return scales.x(d["xmax"]) - scales.x(d["xmin"]);
})
.attr("y", function (d) {
return scales.y(d["upper"]);
})
.attr("height", function (d) {
return Math.abs(scales.y(d["upper"]) - scales.y(d["lower"]));
})
.style("stroke-dasharray", get_dasharray)
.style("stroke-width", get_size)
.style("stroke", get_colour)
.style("fill", get_fill);
e.append("line")
.attr("x1", function (d) {
return scales.x(d["xmin"]);
})
.attr("x2", function (d) {
return scales.x(d["xmax"]);
})
.attr("y1", function (d) {
return scales.y(d["middle"]);
})
.attr("y2", function (d) {
return scales.y(d["middle"]);
})
.style("stroke-dasharray", get_dasharray)
.style("stroke-width", get_size)
.style("stroke", get_colour);
}
} else {
return "unsupported geom " + g_info.geom;
}
elements.exit().remove();
var enter = elements.enter();
var linkActions = function(a_elements){
a_elements
.attr("xlink:href", function(d){ return d.href; })
.attr("target", "_blank")
.attr("class", "geom")
;
}
if(g_info.aes.hasOwnProperty("href")){
enter = enter.append("svg:a")
.append("svg:"+eAppend)
;
}else{
enter = enter.append(eAppend)
.attr("class", "geom")
;
}
if (g_info.aes.hasOwnProperty("clickSelects")) {
var selected_funs = {
"opacity":{
"mouseout":function (d) {
return ifSelectedElse(d, g_info.aes.clickSelects,
get_alpha(d), get_alpha(d) - 1/2);
},
"mouseover":function (d) {
return get_alpha(d);
}
},
"stroke":{
"mouseout":function(d){
return ifSelectedElse(d, g_info.aes.clickSelects,
"black", "transparent");
},
"mouseover":function(d){
return "black";
}
}
};
// My original design for clicking/interactivity/transparency:
// Basically I wanted a really simple way to show which element
// in a group of clickable geom elements is currently
// selected. So I decided that all the non-selected elements
// should have alpha transparency 0.5 less than normal, and the
// selected element should have normal alpha transparency. Also,
// the element currently under the mouse has normal alpha
// transparency, to visually indicate that it can be
// clicked. Looking at my examples, you will see that I
// basically use this in two ways:
// 1. By specifying
// geom_vline(aes(clickSelects=variable),alpha=0.5), which
// implies a normal alpha transparency of 0.5. So all the vlines
// are hidden (normal alpha 0.5 - 0.5 = 0), except the current
// selection and the current element under the mouse pointer are
// drawn a bit faded with alpha=0.5.
// 2. By specifying e.g. geom_point(aes(clickSelects=variable)),
// that implies a normal alpha=1. Thus the current selection and
// the current element under the mouse pointer are fully drawn
// with alpha=1 and the others are shown but a bit faded with
// alpha=0.5 (normal alpha 1 - 0.5 = 0.5).
// Edit 19 March 2014: Now there are two styles to show the
// selection, depending on the geom. For most geoms it is as
// described above. But for geoms like rects with
// aes(fill=numericVariable), using opacity to indicate the
// selection results in a misleading decoding of the fill
// variable. So in this case we set stroke to "black" for the
// current selection.
// TODO: user-configurable selection styles.
var style_funs = selected_funs[g_info.select_style];
var over_fun = function(e){
e.style(g_info.select_style, style_funs["mouseover"]);
}
var out_fun = function(e){
e.style(g_info.select_style, style_funs["mouseout"]);
}
elements.call(out_fun)
.on("mouseover", function (d) {
d3.select(this).call(over_fun);
})
.on("mouseout", function (d) {
d3.select(this).call(out_fun);
})
.on("click", function (d) {
// The main idea of how clickSelects works: when we click
// something, we calls update_selector and then
// update_geom. Inside, I select the relevant subset of data
// and store it in the data variable, which is
// e.g. [{row1},{row2},...]. These are bound to SVG elements
// using D3 to update the plot.
var v_name = g_info.aes.clickSelects;
update_selector(v_name, d.clickSelects);
})
.text("")
.append("svg:title")
.text(function (d) {
var v_name = g_info.aes.clickSelects;
return v_name + " " + d.clickSelects;
});
} else { //no clickSelects for this geom.
// Assign opacity. treat lines and ribbons (groups of points)
// specially.
if (g_info.geom == "line" || g_info.geom == "ribbon") {
enter.style("opacity", function (group_info) {
var one_group = data[group_info.value];
var one_row = one_group[0]; // take aesthetic for first value in the group
return get_alpha(one_row);
})
} else {
enter.style("opacity", get_alpha);
}
}
//eActions(enter); //Set attributes of only the entering elements... why??
if(g_info.duration && g_info.duration.selector == selector_name) {
elements = elements.transition().duration(g_info.duration.ms);
}
if(g_info.aes.hasOwnProperty("href")){
// elements are <a>, children are e.g. <circle>
var linked_geoms = elements.select(eAppend);
linked_geoms.data(elements.data(), key_fun);
eActions(linked_geoms);
linkActions(elements);
}else{
// elements are e.g. <circle>
eActions(elements); // Set the attributes of all elements (enter/exit/stay)
}
}
var update_selector = function (v_name, value) {
Selectors[v_name].selected = value;
Selectors[v_name].update.forEach(function(g_name){
update_geom(g_name, v_name);
});
//Selectors[v_name].hilite.forEach(update_geom);
}
var ifSelectedElse = function (d, v_name, selected, not_selected) {
if (d.clickSelects == Selectors[v_name].selected) {
return selected;
} else {
return not_selected;
}
}
var animateIfLoaded = function () {
var v_name = Animation.variable;
var cur = Selectors[v_name].selected;
var next = Animation.next[cur];
// Before starting the animation, make sure all the geoms have
// loaded.
var geomLoaded = function(x){
return d3.keys(Geoms).indexOf(x)!=-1;
}
if(all_geom_names.every(geomLoaded)){
update_selector(v_name, next);
}
}
//The main idea of how legends work:
// 1. In getLegend in animint.R I export the legend entries as a
// list of rows that can be used in a data() bind in D3.
// 2. Here in add_legend I create a <table> for every legend, and
// then I bind the legend entries to <tr>, <td>, and <svg> elements.
var add_legend = function(p_name, p_info){
// case of multiple legends, d3 reads legend structure in as an array
var tdRight = element.select("td#"+p_name+"_legend");
var legendkeys = d3.keys(p_info.legend);
for(var i=0; i<legendkeys.length; i++){
// the table that contains one row for each legend element.
var legend_table = tdRight.append("table").append("tr")
.append("th").attr("align", "left")
.text(p_info.legend[legendkeys[i]].title);
var l_info = p_info.legend[legendkeys[i]];
// the legend table with breaks/value/label.
var legendgeoms = l_info.geoms;
var legend_rows = legend_table.selectAll("tr")
.data(l_info.entries)
.sort(function(d) {return d["order"];})
.enter()
.append("tr")
;
var legend_svgs = legend_rows.append("td")
.append("svg")
.attr("id", function(d){return "legend-"+d["label"];})
.attr("height", 14)
.attr("width", 20)
;
var pointscale = d3.scale.linear().domain([0,7]).range([1,4]);
// scale points so they are visible in the legend. (does not
// affect plot scaling)
var linescale = d3.scale.linear().domain([0,6]).range([1,4]);
// scale lines so they are visible in the legend. (does not
// affect plot scaling)
if(legendgeoms.indexOf("polygon")>-1){
// aesthetics that would draw a rect
legend_svgs.append("rect")
.attr("x", 2)
.attr("y", 2)
.attr("width", 10)
.attr("height", 10)
.style("stroke-width", function(d){return d["polygonsize"]||1;})
.style("stroke-dasharray", function(d){
return linetypesize2dasharray(d["polygonlinetype"]||"solid",
d["size"]||2);
})
.style("stroke", function(d){return d["polygoncolour"] || "#000000";})
.style("fill", function(d){return d["polygonfill"] || "#FFFFFF";})
.style("opacity", function(d){return d["polygonalpha"]||1;});
}
if(legendgeoms.indexOf("text")>-1){
// aesthetics that would draw a rect
legend_svgs.append("text")
.attr("x", 10)
.attr("y", 14)
.style("fill", function(d){return d["textcolour"]||1;})
.style("text-anchor", "middle")
.attr("font-size", function(d){return d["textsize"]||1;})
.text("a")
;
}
if(legendgeoms.indexOf("path")>-1){
// aesthetics that would draw a line
legend_svgs.append("line")
.attr("x1", 1).attr("x2", 19).attr("y1", 7).attr("y2", 7)
.style("stroke-width", function(d){
return linescale(d["pathsize"])||2;
})
.style("stroke-dasharray", function(d){
return linetypesize2dasharray(d["pathlinetype"]||"solid",
d["pathsize"] || 2);
})
.style("stroke", function(d){return d["pathcolour"] || "#000000";})
.style("opacity", function(d){return d["pathalpha"]||1;});
}
if(legendgeoms.indexOf("point")>-1){
// aesthetics that would draw a point
legend_svgs.append("circle")
.attr("cx", 10)
.attr("cy", 7)
.attr("r", function(d){return pointscale(d["pointsize"])||4;})
.style("stroke", function(d){return d["pointcolour"] || "#000000";})
.style("fill", function(d){
return d["pointfill"] || d["pointcolour"] || "#000000";
})
.style("opacity", function(d){return d["pointalpha"]||1;});
}
legend_rows.append("td")
.attr("align", "left")
.text(function(d){ return d["label"];})
;
}
}
// Download the main description of the interactive plot.
d3.json(json_file, function (error, response) {
if(response.hasOwnProperty("title")){
d3.select("title").text(response.title);
}
// Add plots.
for (var p_name in response.plots) {
add_plot(p_name, response.plots[p_name]);
add_legend(p_name, response.plots[p_name]);
// Append style sheet to document head.
css.appendChild(document.createTextNode(styles.join(" ")));
document.head.appendChild(css);
}
// Then add selectors and start downloading the first data subset.
for (var s_name in response.selectors) {
add_selector(s_name, response.selectors[s_name]);
}
// loading table.
element.append("br");
var show_hide_table = element.append("button")
.text("Show download status table")
;
show_hide_table
.on("click", function(){
if(this.textContent == "Show download status table"){
loading.style("display", "");
show_hide_table.text("Hide download status table");
}else{
loading.style("display", "none");
show_hide_table.text("Show download status table");
}
})
;
var loading = element.append("table")
.style("display", "none")
;
Widgets["loading"] = loading;
var tr = loading.append("tr");
tr.append("th").text("geom");
tr.append("th").attr("class", "chunk").text("selected chunk");
tr.append("th").attr("class", "downloaded").text("downloaded");
tr.append("th").attr("class", "total").text("total");
tr.append("th").attr("class", "status").text("status");
// Add geoms and construct nest operators.
for (var g_name in response.geoms) {
add_geom(g_name, response.geoms[g_name]);
}
// If this is an animation, then start downloading all the rest of
// the data, and start the animation.
if (response.time) {
Animation.next = {};
Animation.ms = response.time.ms;
Animation.variable = response.time.variable;
Animation.sequence = response.time.sequence;
var i, prev, cur;
Selectors[Animation.variable].update.forEach(function(g_name){
var g_info = Geoms[g_name];
// If there is only 1 chunk we don't need to download anything
// else.
if(g_info.chunk_order.length == 0){
return;
}
if(g_info.chunk_order.length != 1){
throw "do not know how to handle more than 1 chunk variable";
}
if(g_info.chunk_order[0] != Animation.variable){
return; //ignore if this geom is chunked on a non-anim variable.
}
download_sequence(g_name, Animation.variable, Animation.sequence);
});
for (i = 0; i < Animation.sequence.length; i++) {
if (i == 0) {
prev = Animation.sequence[Animation.sequence.length-1];
} else {
prev = Animation.sequence[i - 1];
}
cur = Animation.sequence[i];
Animation.next[prev] = cur;
}
all_geom_names = d3.keys(response.geoms);
// as shown on http://bl.ocks.org/mbostock/3808234
setInterval(animateIfLoaded, Animation.ms);
}
});
}
var measureText = function (pText, pFontSize, pStyle) {
var lDiv = document.createElement('lDiv');
document.body.appendChild(lDiv);
if (pStyle != null) {
lDiv.style = pStyle;
}
lDiv.style.fontSize = "" + pFontSize + "px";
lDiv.style.position = "absolute";
lDiv.style.left = -1000;
lDiv.style.top = -1000;
lDiv.innerHTML = pText;
var lResult = {
width: lDiv.clientWidth,
height: lDiv.clientHeight
};
document.body.removeChild(lDiv);
lDiv = null;
return lResult;
}
var linetypesize2dasharray = function (lt, size) {
var isInt = function(n) { return typeof n === 'number' && parseFloat(n) == parseInt(n, 10) && !isNaN(n); }
if(isInt(lt)){ // R integer line types.
var o = {
0: size * 0 + "," + size * 10,
1: 0,
2: size * 4 + "," + size * 4,
3: size + "," + size * 2,
4: size + "," + size * 2 + "," + size * 4 + "," + size * 2,
5: size * 8 + "," + size * 4,
6: size * 2 + "," + size * 2 + "," + size * 6 + "," + size * 2
};
} else { //R defined line types
var o = {
"blank": size * 0 + "," + size * 10,
"solid": 0,
"dashed": size * 4 + "," + size * 4,
"dotted": size + "," + size * 2,
"dotdash": size + "," + size * 2 + "," + size * 4 + "," + size * 2,
"longdash": size * 8 + "," + size * 4,
"twodash": size * 2 + "," + size * 2 + "," + size * 6 + "," + size * 2,
"22": size * 2 + "," + size * 2,
"42": size * 4 + "," + size * 2,
"44": size * 4 + "," + size * 4,
"13": size + "," + size * 3,
"1343": size + "," + size * 3 + "," + size * 4 + "," + size * 3,
"73": size * 7 + "," + size * 3,
"2262": size * 2 + "," + size * 2 + "," + size * 6 + "," + size * 2,
"12223242": size + "," + size * 2 + "," + size * 2 + "," + size * 2 + "," + size * 3 + "," + size * 2 + "," + size * 4 + "," + size * 2,
"F282": size * 15 + "," + size * 2 + "," + size * 8 + "," + size * 2,
"F4448444": size * 15 + "," + size * 4 + "," + size * 4 + "," + size * 4 + "," + size * 8 + "," + size * 4 + "," + size * 4 + "," + size * 4,
"224282F2": size * 2 + "," + size * 2 + "," + size * 4 + "," + size * 2 + "," + size * 8 + "," + size * 2 + "," + size * 16 + "," + size * 2,
"F1": size * 16 + "," + size
};
}
if (lt in o){
return o[lt];
} else{ // manually specified line types
str = lt.split("");
strnum = str.map(function (d) {
return size * parseInt(d, 16);
});
return strnum;
}
}
var isArray = function(o) {
return Object.prototype.toString.call(o) === '[object Array]';
}
// Copyright (c) 2013, Michael Bostock
// All rights reserved.
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
// * Redistributions of source code must retain the above copyright notice, this
// list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
// * The name Michael Bostock may not be used to endorse or promote products
// derived from this software without specific prior written permission.
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
// DISCLAIMED. IN NO EVENT SHALL MICHAEL BOSTOCK BE LIABLE FOR ANY DIRECT,
// INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
// BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
d3 = function() {
var π = Math.PI, ε = 1e-6, d3 = {
version: "3.0.6"
}, d3_radians = π / 180, d3_degrees = 180 / π, d3_document = document, d3_window = window;
function d3_target(d) {
return d.target;
}
function d3_source(d) {
return d.source;
}
var d3_format_decimalPoint = ".", d3_format_thousandsSeparator = ",", d3_format_grouping = [ 3, 3 ];
if (!Date.now) Date.now = function() {
return +new Date();
};
try {
d3_document.createElement("div").style.setProperty("opacity", 0, "");
} catch (error) {
var d3_style_prototype = d3_window.CSSStyleDeclaration.prototype, d3_style_setProperty = d3_style_prototype.setProperty;
d3_style_prototype.setProperty = function(name, value, priority) {
d3_style_setProperty.call(this, name, value + "", priority);
};
}
function d3_class(ctor, properties) {
try {
for (var key in properties) {
Object.defineProperty(ctor.prototype, key, {
value: properties[key],
enumerable: false
});
}
} catch (e) {
ctor.prototype = properties;
}
}
var d3_array = d3_arraySlice;
function d3_arrayCopy(pseudoarray) {
var i = -1, n = pseudoarray.length, array = [];
while (++i < n) array.push(pseudoarray[i]);
return array;
}
function d3_arraySlice(pseudoarray) {
return Array.prototype.slice.call(pseudoarray);
}
try {
d3_array(d3_document.documentElement.childNodes)[0].nodeType;
} catch (e) {
d3_array = d3_arrayCopy;
}
var d3_arraySubclass = [].__proto__ ? function(array, prototype) {
array.__proto__ = prototype;
} : function(array, prototype) {
for (var property in prototype) array[property] = prototype[property];
};
d3.map = function(object) {
var map = new d3_Map();
for (var key in object) map.set(key, object[key]);
return map;
};
function d3_Map() {}
d3_class(d3_Map, {
has: function(key) {
return d3_map_prefix + key in this;
},
get: function(key) {
return this[d3_map_prefix + key];
},
set: function(key, value) {
return this[d3_map_prefix + key] = value;
},
remove: function(key) {
key = d3_map_prefix + key;
return key in this && delete this[key];
},
keys: function() {
var keys = [];
this.forEach(function(key) {
keys.push(key);
});
return keys;
},
values: function() {
var values = [];
this.forEach(function(key, value) {
values.push(value);
});
return values;
},
entries: function() {
var entries = [];
this.forEach(function(key, value) {
entries.push({
key: key,
value: value
});
});
return entries;
},
forEach: function(f) {
for (var key in this) {
if (key.charCodeAt(0) === d3_map_prefixCode) {
f.call(this, key.substring(1), this[key]);
}
}
}
});
var d3_map_prefix = "\0", d3_map_prefixCode = d3_map_prefix.charCodeAt(0);
function d3_identity(d) {
return d;
}
function d3_true() {
return true;
}
function d3_functor(v) {
return typeof v === "function" ? v : function() {
return v;
};
}
d3.functor = d3_functor;
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 arguments.length ? target : value;
};
}
d3.ascending = function(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.mean = function(array, f) {
var n = array.length, a, m = 0, i = -1, j = 0;
if (arguments.length === 1) {
while (++i < n) if (d3_number(a = array[i])) m += (a - m) / ++j;
} else {
while (++i < n) if (d3_number(a = f.call(array, array[i], i))) m += (a - m) / ++j;
}
return j ? m : undefined;
};
d3.median = function(array, f) {
if (arguments.length > 1) array = array.map(f);
array = array.filter(d3_number);
return array.length ? d3.quantile(array.sort(d3.ascending), .5) : undefined;
};
d3.min = function(array, f) {
var i = -1, n = array.length, a, b;
if (arguments.length === 1) {
while (++i < n && ((a = array[i]) == null || a != a)) a = undefined;
while (++i < n) if ((b = array[i]) != null && a > b) a = b;
} else {
while (++i < n && ((a = f.call(array, array[i], i)) == null || a != a)) a = undefined;
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 && ((a = array[i]) == null || a != a)) a = undefined;
while (++i < n) if ((b = array[i]) != null && b > a) a = b;
} else {
while (++i < n && ((a = f.call(array, array[i], i)) == null || a != a)) a = undefined;
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 && ((a = c = array[i]) == null || a != a)) a = c = undefined;
while (++i < n) if ((b = array[i]) != null) {
if (a > b) a = b;
if (c < b) c = b;
}
} else {
while (++i < n && ((a = c = f.call(array, array[i], i)) == null || a != a)) a = undefined;
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 ];
};
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());
};
},
irwinHall: function(m) {
return function() {
for (var s = 0, j = 0; j < m; j++) s += Math.random();
return s / m;
};
}
};
function d3_number(x) {
return x != null && !isNaN(x);
}
d3.sum = function(array, f) {
var s = 0, n = array.length, a, i = -1;
if (arguments.length === 1) {
while (++i < n) if (!isNaN(a = +array[i])) s += a;
} else {
while (++i < n) if (!isNaN(a = +f.call(array, array[i], i))) s += a;
}
return s;
};
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.shuffle = function(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;
};
d3.transpose = function(matrix) {
return d3.zip.apply(d3, matrix);
};
d3.zip = function() {
if (!(n = arguments.length)) return [];
for (var i = -1, m = d3.min(arguments, d3_zipLength), zips = new Array(m); ++i < m; ) {
for (var j = -1, n, zip = zips[i] = new Array(n); ++j < n; ) {
zip[j] = arguments[j][i];
}
}
return zips;
};
function d3_zipLength(d) {
return d.length;
}
d3.bisector = function(f) {
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 (f.call(a, a[mid], mid) < x) 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 (x < f.call(a, a[mid], mid)) hi = mid; else lo = mid + 1;
}
return lo;
}
};
};
var d3_bisector = d3.bisector(function(d) {
return d;
});
d3.bisectLeft = d3_bisector.left;
d3.bisect = d3.bisectRight = d3_bisector.right;
d3.nest = function() {
var nest = {}, keys = [], sortKeys = [], sortValues, rollup;
function map(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, valuesByKey = new d3_Map(), values, o = {};
while (++i < n) {
if (values = valuesByKey.get(keyValue = key(object = array[i]))) {
values.push(object);
} else {
valuesByKey.set(keyValue, [ object ]);
}
}
valuesByKey.forEach(function(keyValue, values) {
o[keyValue] = map(values, depth);
});
return o;
}
function entries(map, depth) {
if (depth >= keys.length) return map;
var a = [], sortKey = sortKeys[depth++], key;
for (key in map) {
a.push({
key: key,
values: entries(map[key], depth)
});
}
if (sortKey) a.sort(function(a, b) {
return sortKey(a.key, b.key);
});
return a;
}
nest.map = function(array) {
return map(array, 0);
};
nest.entries = function(array) {
return entries(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.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.permute = function(array, indexes) {
var permutes = [], i = -1, n = indexes.length;
while (++i < n) permutes[i] = array[indexes[i]];
return permutes;
};
d3.merge = function(arrays) {
return Array.prototype.concat.apply([], arrays);
};
function d3_collapse(s) {
return s.trim().replace(/\s+/g, " ");
}
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(Math.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;
}
d3.requote = function(s) {
return s.replace(d3_requote_re, "\\$&");
};
var d3_requote_re = /[\\\^\$\*\+\?\|\[\]\(\)\.\{\}]/g;
d3.round = function(x, n) {
return n ? Math.round(x * (n = Math.pow(10, n))) / n : Math.round(x);
};
d3.xhr = function(url, mimeType, callback) {
var xhr = {}, dispatch = d3.dispatch("progress", "load", "error"), headers = {}, response = d3_identity, request = new (d3_window.XDomainRequest && /^(http(s)?:)?\/\//.test(url) ? XDomainRequest : XMLHttpRequest)();
"onload" in request ? request.onload = request.onerror = respond : request.onreadystatechange = function() {
request.readyState > 3 && respond();
};
function respond() {
var s = request.status;
!s && request.responseText || s >= 200 && s < 300 || s === 304 ? dispatch.load.call(xhr, response.call(xhr, request)) : 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.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 (callback != null) xhr.on("error", callback).on("load", function(request) {
callback(null, request);
});
request.send(data == null ? null : data);
return xhr;
};
xhr.abort = function() {
request.abort();
return xhr;
};
d3.rebind(xhr, dispatch, "on");
if (arguments.length === 2 && typeof mimeType === "function") callback = mimeType,
mimeType = null;
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;
}
d3.text = function() {
return d3.xhr.apply(d3, arguments).response(d3_text);
};
function d3_text(request) {
return request.responseText;
}
d3.json = function(url, callback) {
return d3.xhr(url, "application/json", callback).response(d3_json);
};
function d3_json(request) {
return JSON.parse(request.responseText);
}
d3.html = function(url, callback) {
return d3.xhr(url, "text/html", callback).response(d3_html);
};
function d3_html(request) {
var range = d3_document.createRange();
range.selectNode(d3_document.body);
return range.createContextualFragment(request.responseText);
}
d3.xml = function() {
return d3.xhr.apply(d3, arguments).response(d3_xml);
};
function d3_xml(request) {
return request.responseXML;
}
var d3_nsPrefix = {
svg: "http://www.w3.org/2000/svg",
xhtml: "http://www.w3.org/1999/xhtml",
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.substring(0, i);
name = name.substring(i + 1);
}
return d3_nsPrefix.hasOwnProperty(prefix) ? {
space: d3_nsPrefix[prefix],
local: name
} : name;
}
};
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.substring(i + 1);
type = type.substring(0, i);
}
return arguments.length < 2 ? this[type].on(name) : this[type].on(name, listener);
};
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.format = function(specifier) {
var match = d3_format_re.exec(specifier), fill = match[1] || " ", align = match[2] || ">", sign = match[3] || "", basePrefix = match[4] || "", zfill = match[5], width = +match[6], comma = match[7], precision = match[8], type = match[9], scale = 1, suffix = "", integer = false;
if (precision) precision = +precision.substring(1);
if (zfill || fill === "0" && align === "=") {
zfill = fill = "0";
align = "=";
if (comma) width -= Math.floor((width - 1) / 4);
}
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 (basePrefix) basePrefix = "0" + type.toLowerCase();
case "c":
case "d":
integer = true;
precision = 0;
break;
case "s":
scale = -1;
type = "r";
break;
}
if (basePrefix === "#") basePrefix = "";
if (type == "r" && !precision) type = "g";
type = d3_format_types.get(type) || d3_format_typeDefault;
var zcomma = zfill && comma;
return function(value) {
if (integer && value % 1) return "";
var negative = value < 0 || value === 0 && 1 / value < 0 ? (value = -value, "-") : sign;
if (scale < 0) {
var prefix = d3.formatPrefix(value, precision);
value = prefix.scale(value);
suffix = prefix.symbol;
} else {
value *= scale;
}
value = type(value, precision);
if (!zfill && comma) value = d3_format_group(value);
var length = basePrefix.length + value.length + (zcomma ? 0 : negative.length), padding = length < width ? new Array(length = width - length + 1).join(fill) : "";
if (zcomma) value = d3_format_group(padding + value);
if (d3_format_decimalPoint) value.replace(".", d3_format_decimalPoint);
negative += basePrefix;
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)) + suffix;
};
};
var d3_format_re = /(?:([^{])?([<>=^]))?([+\- ])?(#)?(0)?([0-9]+)?(,)?(\.[0-9]+)?([a-zA-Z%])?/;
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_precision(x, p) {
return p - (x ? Math.ceil(Math.log(x) / Math.LN10) : 1);
}
function d3_format_typeDefault(x) {
return x + "";
}
var d3_format_group = d3_identity;
if (d3_format_grouping) {
var d3_format_groupingLength = d3_format_grouping.length;
d3_format_group = function(value) {
var i = value.lastIndexOf("."), f = i >= 0 ? "." + value.substring(i + 1) : (i = value.length,
""), t = [], j = 0, g = d3_format_grouping[0];
while (i > 0 && g > 0) {
t.push(value.substring(i -= g, i + g));
g = d3_format_grouping[j = (j + 1) % d3_format_groupingLength];
}
return t.reverse().join(d3_format_thousandsSeparator || "") + f;
};
}
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) {
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 <= 0 ? i + 1 : i - 1) / 3) * 3));
}
return d3_formatPrefixes[8 + i / 3];
};
function d3_formatPrefix(d, i) {
var k = Math.pow(10, Math.abs(8 - i) * 3);
return {
scale: i > 8 ? function(d) {
return d / k;
} : function(d) {
return d * k;
},
symbol: d
};
}
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.substring(0, i) : name, m = i >= 0 ? name.substring(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, Array.prototype.slice.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 * π / 2);
}
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 / (2 * π) * 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) * 2 * π / 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.event = null;
function d3_eventCancel() {
d3.event.stopPropagation();
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.transform = function(string) {
var g = d3_document.createElementNS(d3.ns.prefix.svg, "g");
return (d3.transform = function(string) {
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.interpolate = function(a, b) {
var i = d3.interpolators.length, f;
while (--i >= 0 && !(f = d3.interpolators[i](a, b))) ;
return f;
};
d3.interpolateNumber = function(a, b) {
b -= a;
return function(t) {
return a + b * t;
};
};
d3.interpolateRound = function(a, b) {
b -= a;
return function(t) {
return Math.round(a + b * t);
};
};
d3.interpolateString = function(a, b) {
var m, i, j, s0 = 0, s1 = 0, s = [], q = [], n, o;
d3_interpolate_number.lastIndex = 0;
for (i = 0; m = d3_interpolate_number.exec(b); ++i) {
if (m.index) s.push(b.substring(s0, s1 = m.index));
q.push({
i: s.length,
x: m[0]
});
s.push(null);
s0 = d3_interpolate_number.lastIndex;
}
if (s0 < b.length) s.push(b.substring(s0));
for (i = 0, n = q.length; (m = d3_interpolate_number.exec(a)) && i < n; ++i) {
o = q[i];
if (o.x == m[0]) {
if (o.i) {
if (s[o.i + 1] == null) {
s[o.i - 1] += o.x;
s.splice(o.i, 1);
for (j = i + 1; j < n; ++j) q[j].i--;
} else {
s[o.i - 1] += o.x + s[o.i + 1];
s.splice(o.i, 2);
for (j = i + 1; j < n; ++j) q[j].i -= 2;
}
} else {
if (s[o.i + 1] == null) {
s[o.i] = o.x;
} else {
s[o.i] = o.x + s[o.i + 1];
s.splice(o.i + 1, 1);
for (j = i + 1; j < n; ++j) q[j].i--;
}
}
q.splice(i, 1);
n--;
i--;
} else {
o.x = d3.interpolateNumber(parseFloat(m[0]), parseFloat(o.x));
}
}
while (i < n) {
o = q.pop();
if (s[o.i + 1] == null) {
s[o.i] = o.x;
} else {
s[o.i] = o.x + s[o.i + 1];
s.splice(o.i + 1, 1);
}
n--;
}
if (s.length === 1) {
return s[0] == null ? q[0].x : function() {
return b;
};
}
return function(t) {
for (i = 0; i < n; ++i) s[(o = q[i]).i] = o.x(t);
return s.join("");
};
};
d3.interpolateTransform = function(a, b) {
var s = [], q = [], n, A = d3.transform(a), B = d3.transform(b), ta = A.translate, tb = B.translate, ra = A.rotate, rb = B.rotate, wa = A.skew, wb = B.skew, ka = A.scale, kb = B.scale;
if (ta[0] != tb[0] || ta[1] != tb[1]) {
s.push("translate(", null, ",", null, ")");
q.push({
i: 1,
x: d3.interpolateNumber(ta[0], tb[0])
}, {
i: 3,
x: d3.interpolateNumber(ta[1], tb[1])
});
} else if (tb[0] || tb[1]) {
s.push("translate(" + tb + ")");
} else {
s.push("");
}
if (ra != rb) {
if (ra - rb > 180) rb += 360; else if (rb - ra > 180) ra += 360;
q.push({
i: s.push(s.pop() + "rotate(", null, ")") - 2,
x: d3.interpolateNumber(ra, rb)
});
} else if (rb) {
s.push(s.pop() + "rotate(" + rb + ")");
}
if (wa != wb) {
q.push({
i: s.push(s.pop() + "skewX(", null, ")") - 2,
x: d3.interpolateNumber(wa, wb)
});
} else if (wb) {
s.push(s.pop() + "skewX(" + wb + ")");
}
if (ka[0] != kb[0] || ka[1] != kb[1]) {
n = s.push(s.pop() + "scale(", null, ",", null, ")");
q.push({
i: n - 4,
x: d3.interpolateNumber(ka[0], kb[0])
}, {
i: n - 2,
x: d3.interpolateNumber(ka[1], kb[1])
});
} else if (kb[0] != 1 || kb[1] != 1) {
s.push(s.pop() + "scale(" + kb + ")");
}
n = q.length;
return function(t) {
var i = -1, o;
while (++i < n) s[(o = q[i]).i] = o.x(t);
return s.join("");
};
};
d3.interpolateRgb = function(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.interpolateHsl = function(a, b) {
a = d3.hsl(a);
b = d3.hsl(b);
var h0 = a.h, s0 = a.s, l0 = a.l, h1 = b.h - h0, s1 = b.s - s0, l1 = b.l - l0;
if (h1 > 180) h1 -= 360; else if (h1 < -180) h1 += 360;
return function(t) {
return d3_hsl_rgb(h0 + h1 * t, s0 + s1 * t, l0 + l1 * t) + "";
};
};
d3.interpolateLab = function(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.interpolateHcl = function(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 (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.interpolateArray = function(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;
};
};
d3.interpolateObject = function(a, b) {
var i = {}, c = {}, k;
for (k in a) {
if (k in b) {
i[k] = d3_interpolateByName(k)(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;
};
};
var d3_interpolate_number = /[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g;
function d3_interpolateByName(name) {
return name == "transform" ? d3.interpolateTransform : d3.interpolate;
}
d3.interpolators = [ d3.interpolateObject, function(a, b) {
return b instanceof Array && d3.interpolateArray(a, b);
}, function(a, b) {
return (typeof a === "string" || typeof b === "string") && d3.interpolateString(a + "", b + "");
}, function(a, b) {
return (typeof b === "string" ? d3_rgb_names.has(b) || /^(#|rgb\(|hsl\()/.test(b) : b instanceof d3_Color) && d3.interpolateRgb(a, b);
}, function(a, b) {
return !isNaN(a = +a) && !isNaN(b = +b) && d3.interpolateNumber(a, b);
} ];
function d3_uninterpolateNumber(a, b) {
b = b - (a = +a) ? 1 / (b - a) : 0;
return function(x) {
return (x - a) * b;
};
}
function d3_uninterpolateClamp(a, b) {
b = b - (a = +a) ? 1 / (b - a) : 0;
return function(x) {
return Math.max(0, Math.min(1, (x - a) * b));
};
}
function d3_Color() {}
d3_Color.prototype.toString = function() {
return this.rgb() + "";
};
d3.rgb = function(r, g, b) {
return arguments.length === 1 ? r instanceof d3_Rgb ? d3_rgb(r.r, r.g, r.b) : d3_rgb_parse("" + r, d3_rgb, d3_hsl_rgb) : d3_rgb(~~r, ~~g, ~~b);
};
function d3_rgb(r, g, b) {
return new d3_Rgb(r, g, b);
}
function d3_Rgb(r, g, b) {
this.r = r;
this.g = g;
this.b = b;
}
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 d3_rgb(i, i, i);
if (r && r < i) r = i;
if (g && g < i) g = i;
if (b && b < i) b = i;
return d3_rgb(Math.min(255, Math.floor(r / k)), Math.min(255, Math.floor(g / k)), Math.min(255, Math.floor(b / k)));
};
d3_rgbPrototype.darker = function(k) {
k = Math.pow(.7, arguments.length ? k : 1);
return d3_rgb(Math.floor(k * this.r), Math.floor(k * this.g), Math.floor(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, name;
m1 = /([a-z]+)\((.*)\)/i.exec(format);
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 (name = d3_rgb_names.get(format)) return rgb(name.r, name.g, name.b);
if (format != null && format.charAt(0) === "#") {
if (format.length === 4) {
r = format.charAt(1);
r += r;
g = format.charAt(2);
g += g;
b = format.charAt(3);
b += b;
} else if (format.length === 7) {
r = format.substring(1, 3);
g = format.substring(3, 5);
b = format.substring(5, 7);
}
r = parseInt(r, 16);
g = parseInt(g, 16);
b = parseInt(b, 16);
}
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 {
s = h = 0;
}
return 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: "#f0f8ff",
antiquewhite: "#faebd7",
aqua: "#00ffff",
aquamarine: "#7fffd4",
azure: "#f0ffff",
beige: "#f5f5dc",
bisque: "#ffe4c4",
black: "#000000",
blanchedalmond: "#ffebcd",
blue: "#0000ff",
blueviolet: "#8a2be2",
brown: "#a52a2a",
burlywood: "#deb887",
cadetblue: "#5f9ea0",
chartreuse: "#7fff00",
chocolate: "#d2691e",
coral: "#ff7f50",
cornflowerblue: "#6495ed",
cornsilk: "#fff8dc",
crimson: "#dc143c",
cyan: "#00ffff",
darkblue: "#00008b",
darkcyan: "#008b8b",
darkgoldenrod: "#b8860b",
darkgray: "#a9a9a9",
darkgreen: "#006400",
darkgrey: "#a9a9a9",
darkkhaki: "#bdb76b",
darkmagenta: "#8b008b",
darkolivegreen: "#556b2f",
darkorange: "#ff8c00",
darkorchid: "#9932cc",
darkred: "#8b0000",
darksalmon: "#e9967a",
darkseagreen: "#8fbc8f",
darkslateblue: "#483d8b",
darkslategray: "#2f4f4f",
darkslategrey: "#2f4f4f",
darkturquoise: "#00ced1",
darkviolet: "#9400d3",
deeppink: "#ff1493",
deepskyblue: "#00bfff",
dimgray: "#696969",
dimgrey: "#696969",
dodgerblue: "#1e90ff",
firebrick: "#b22222",
floralwhite: "#fffaf0",
forestgreen: "#228b22",
fuchsia: "#ff00ff",
gainsboro: "#dcdcdc",
ghostwhite: "#f8f8ff",
gold: "#ffd700",
goldenrod: "#daa520",
gray: "#808080",
green: "#008000",
greenyellow: "#adff2f",
grey: "#808080",
honeydew: "#f0fff0",
hotpink: "#ff69b4",
indianred: "#cd5c5c",
indigo: "#4b0082",
ivory: "#fffff0",
khaki: "#f0e68c",
lavender: "#e6e6fa",
lavenderblush: "#fff0f5",
lawngreen: "#7cfc00",
lemonchiffon: "#fffacd",
lightblue: "#add8e6",
lightcoral: "#f08080",
lightcyan: "#e0ffff",
lightgoldenrodyellow: "#fafad2",
lightgray: "#d3d3d3",
lightgreen: "#90ee90",
lightgrey: "#d3d3d3",
lightpink: "#ffb6c1",
lightsalmon: "#ffa07a",
lightseagreen: "#20b2aa",
lightskyblue: "#87cefa",
lightslategray: "#778899",
lightslategrey: "#778899",
lightsteelblue: "#b0c4de",
lightyellow: "#ffffe0",
lime: "#00ff00",
limegreen: "#32cd32",
linen: "#faf0e6",
magenta: "#ff00ff",
maroon: "#800000",
mediumaquamarine: "#66cdaa",
mediumblue: "#0000cd",
mediumorchid: "#ba55d3",
mediumpurple: "#9370db",
mediumseagreen: "#3cb371",
mediumslateblue: "#7b68ee",
mediumspringgreen: "#00fa9a",
mediumturquoise: "#48d1cc",
mediumvioletred: "#c71585",
midnightblue: "#191970",
mintcream: "#f5fffa",
mistyrose: "#ffe4e1",
moccasin: "#ffe4b5",
navajowhite: "#ffdead",
navy: "#000080",
oldlace: "#fdf5e6",
olive: "#808000",
olivedrab: "#6b8e23",
orange: "#ffa500",
orangered: "#ff4500",
orchid: "#da70d6",
palegoldenrod: "#eee8aa",
palegreen: "#98fb98",
paleturquoise: "#afeeee",
palevioletred: "#db7093",
papayawhip: "#ffefd5",
peachpuff: "#ffdab9",
peru: "#cd853f",
pink: "#ffc0cb",
plum: "#dda0dd",
powderblue: "#b0e0e6",
purple: "#800080",
red: "#ff0000",
rosybrown: "#bc8f8f",
royalblue: "#4169e1",
saddlebrown: "#8b4513",
salmon: "#fa8072",
sandybrown: "#f4a460",
seagreen: "#2e8b57",
seashell: "#fff5ee",
sienna: "#a0522d",
silver: "#c0c0c0",
skyblue: "#87ceeb",
slateblue: "#6a5acd",
slategray: "#708090",
slategrey: "#708090",
snow: "#fffafa",
springgreen: "#00ff7f",
steelblue: "#4682b4",
tan: "#d2b48c",
teal: "#008080",
thistle: "#d8bfd8",
tomato: "#ff6347",
turquoise: "#40e0d0",
violet: "#ee82ee",
wheat: "#f5deb3",
white: "#ffffff",
whitesmoke: "#f5f5f5",
yellow: "#ffff00",
yellowgreen: "#9acd32"
});
d3_rgb_names.forEach(function(key, value) {
d3_rgb_names.set(key, d3_rgb_parse(value, d3_rgb, d3_hsl_rgb));
});
d3.hsl = function(h, s, l) {
return arguments.length === 1 ? h instanceof d3_Hsl ? d3_hsl(h.h, h.s, h.l) : d3_rgb_parse("" + h, d3_rgb_hsl, d3_hsl) : d3_hsl(+h, +s, +l);
};
function d3_hsl(h, s, l) {
return new d3_Hsl(h, s, l);
}
function d3_Hsl(h, s, l) {
this.h = h;
this.s = s;
this.l = l;
}
var d3_hslPrototype = d3_Hsl.prototype = new d3_Color();
d3_hslPrototype.brighter = function(k) {
k = Math.pow(.7, arguments.length ? k : 1);
return d3_hsl(this.h, this.s, this.l / k);
};
d3_hslPrototype.darker = function(k) {
k = Math.pow(.7, arguments.length ? k : 1);
return 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 = h % 360;
if (h < 0) h += 360;
s = 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 d3_rgb(vv(h + 120), vv(h), vv(h - 120));
}
d3.hcl = function(h, c, l) {
return arguments.length === 1 ? h instanceof d3_Hcl ? 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) : d3_hcl(+h, +c, +l);
};
function d3_hcl(h, c, l) {
return new d3_Hcl(h, c, l);
}
function d3_Hcl(h, c, l) {
this.h = h;
this.c = c;
this.l = l;
}
var d3_hclPrototype = d3_Hcl.prototype = new d3_Color();
d3_hclPrototype.brighter = function(k) {
return d3_hcl(this.h, this.c, Math.min(100, this.l + d3_lab_K * (arguments.length ? k : 1)));
};
d3_hclPrototype.darker = function(k) {
return 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) {
return d3_lab(l, Math.cos(h *= d3_radians) * c, Math.sin(h) * c);
}
d3.lab = function(l, a, b) {
return arguments.length === 1 ? l instanceof d3_Lab ? d3_lab(l.l, l.a, l.b) : l instanceof d3_Hcl ? d3_hcl_lab(l.l, l.c, l.h) : d3_rgb_lab((l = d3.rgb(l)).r, l.g, l.b) : d3_lab(+l, +a, +b);
};
function d3_lab(l, a, b) {
return new d3_Lab(l, a, b);
}
function d3_Lab(l, a, b) {
this.l = l;
this.a = a;
this.b = 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 d3_lab(Math.min(100, this.l + d3_lab_K * (arguments.length ? k : 1)), this.a, this.b);
};
d3_labPrototype.darker = function(k) {
return 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 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 d3_hcl(Math.atan2(b, a) / π * 180, Math.sqrt(a * a + b * b), 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));
}
function d3_selection(groups) {
d3_arraySubclass(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_selectRoot = d3_document.documentElement, d3_selectMatcher = d3_selectRoot.matchesSelector || d3_selectRoot.webkitMatchesSelector || d3_selectRoot.mozMatchesSelector || d3_selectRoot.msMatchesSelector || d3_selectRoot.oMatchesSelector, d3_selectMatches = function(n, s) {
return d3_selectMatcher.call(n, s);
};
if (typeof Sizzle === "function") {
d3_select = function(s, n) {
return Sizzle(s, n)[0] || null;
};
d3_selectAll = function(s, n) {
return Sizzle.uniqueSort(Sizzle(s, n));
};
d3_selectMatches = Sizzle.matchesSelector;
}
var d3_selectionPrototype = [];
d3.selection = function() {
return d3_selectionRoot;
};
d3.selection.prototype = d3_selectionPrototype;
d3_selectionPrototype.select = function(selector) {
var subgroups = [], subgroup, subnode, group, node;
if (typeof selector !== "function") 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));
if (subnode && "__data__" in node) subnode.__data__ = node.__data__;
} else {
subgroup.push(null);
}
}
}
return d3_selection(subgroups);
};
function d3_selection_selector(selector) {
return function() {
return d3_select(selector, this);
};
}
d3_selectionPrototype.selectAll = function(selector) {
var subgroups = [], subgroup, node;
if (typeof selector !== "function") 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)));
subgroup.parentNode = node;
}
}
}
return d3_selection(subgroups);
};
function d3_selection_selectorAll(selector) {
return function() {
return d3_selectAll(selector, this);
};
}
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;
}
d3_selectionPrototype.classed = function(name, value) {
if (arguments.length < 2) {
if (typeof name === "string") {
var node = this.node(), n = (name = name.trim().split(/^|\s+/g)).length, i = -1;
if (value = node.classList) {
while (++i < n) if (!value.contains(name[i])) return false;
} else {
value = node.className;
if (value.baseVal != null) value = value.baseVal;
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_classed(name, value) {
name = name.trim().split(/\s+/).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.className, cb = c.baseVal != null, cv = cb ? c.baseVal : c;
if (value) {
re.lastIndex = 0;
if (!re.test(cv)) {
cv = d3_collapse(cv + " " + name);
if (cb) c.baseVal = cv; else node.className = cv;
}
} else if (cv) {
cv = d3_collapse(cv.replace(re, " "));
if (cb) c.baseVal = cv; else node.className = cv;
}
};
}
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) return d3_window.getComputedStyle(this.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.ns.qualify(name);
function append() {
return this.appendChild(d3_document.createElementNS(this.namespaceURI, name));
}
function appendNS() {
return this.appendChild(d3_document.createElementNS(name.space, name.local));
}
return this.select(name.local ? appendNS : append);
};
d3_selectionPrototype.insert = function(name, before) {
name = d3.ns.qualify(name);
function insert() {
return this.insertBefore(d3_document.createElementNS(this.namespaceURI, name), d3_select(before, this));
}
function insertNS() {
return this.insertBefore(d3_document.createElementNS(name.space, name.local), d3_select(before, this));
}
return this.select(name.local ? insertNS : insert);
};
d3_selectionPrototype.remove = function() {
return this.each(function() {
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(), dataByKeyValue = new d3_Map(), keyValues = [], keyValue;
for (i = -1; ++i < n; ) {
keyValue = key.call(node = group[i], node.__data__, i);
if (nodeByKeyValue.has(keyValue)) {
exitNodes[i] = node;
} else {
nodeByKeyValue.set(keyValue, node);
}
keyValues.push(keyValue);
}
for (i = -1; ++i < m; ) {
keyValue = key.call(groupData, nodeData = groupData[i], i);
if (node = nodeByKeyValue.get(keyValue)) {
updateNodes[i] = node;
node.__data__ = nodeData;
} else if (!dataByKeyValue.has(keyValue)) {
enterNodes[i] = d3_selection_dataNode(nodeData);
}
dataByKeyValue.set(keyValue, nodeData);
nodeByKeyValue.remove(keyValue);
}
for (i = -1; ++i < n; ) {
if (nodeByKeyValue.has(keyValues[i])) {
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)) {
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__);
};
}
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(".");
if (i > 0) type = type.substring(0, i);
function onRemove() {
var wrapper = this[name];
if (wrapper) {
this.removeEventListener(type, wrapper, wrapper.$);
delete this[name];
}
}
function onAdd() {
var node = this, args = d3_array(arguments);
onRemove.call(this);
this.addEventListener(type, this[name] = wrapper, wrapper.$ = capture);
wrapper._ = listener;
function wrapper(e) {
var o = d3.event;
d3.event = e;
args[0] = node.__data__;
try {
listener.apply(node, args);
} finally {
d3.event = o;
}
}
}
return listener ? onAdd : onRemove;
}
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.transition = function() {
var id = d3_transitionInheritId || ++d3_transitionId, subgroups = [], subgroup, node, transition = Object.create(d3_transitionInherit);
transition.time = Date.now();
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, id, transition);
subgroup.push(node);
}
}
return d3_transition(subgroups, id);
};
var d3_selectionRoot = d3_selection([ [ d3_document ] ]);
d3_selectionRoot[0].parentNode = d3_selectRoot;
d3.select = function(selector) {
return typeof selector === "string" ? d3_selectionRoot.select(selector) : d3_selection([ [ selector ] ]);
};
d3.selectAll = function(selector) {
return typeof selector === "string" ? d3_selectionRoot.selectAll(selector) : d3_selection([ d3_array(selector) ]);
};
function d3_selection_enter(selection) {
d3_arraySubclass(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.insert = d3_selectionPrototype.insert;
d3_selection_enterPrototype.empty = d3_selectionPrototype.empty;
d3_selection_enterPrototype.node = d3_selectionPrototype.node;
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));
subnode.__data__ = node.__data__;
} else {
subgroup.push(null);
}
}
}
return d3_selection(subgroups);
};
function d3_transition(groups, id) {
d3_arraySubclass(groups, d3_transitionPrototype);
groups.id = id;
return groups;
}
var d3_transitionPrototype = [], d3_transitionId = 0, d3_transitionInheritId, d3_transitionInherit = {
ease: d3_ease_cubicInOut,
delay: 0,
duration: 250
};
d3_transitionPrototype.call = d3_selectionPrototype.call;
d3_transitionPrototype.empty = d3_selectionPrototype.empty;
d3_transitionPrototype.node = d3_selectionPrototype.node;
d3.transition = function(selection) {
return arguments.length ? d3_transitionInheritId ? selection.transition() : selection : d3_selectionRoot.transition();
};
d3.transition.prototype = d3_transitionPrototype;
function d3_transitionNode(node, i, id, inherit) {
var lock = node.__transition__ || (node.__transition__ = {
active: 0,
count: 0
}), transition = lock[id];
if (!transition) {
var time = inherit.time;
transition = lock[id] = {
tween: new d3_Map(),
event: d3.dispatch("start", "end"),
time: time,
ease: inherit.ease,
delay: inherit.delay,
duration: inherit.duration
};
++lock.count;
d3.timer(function(elapsed) {
var d = node.__data__, ease = transition.ease, event = transition.event, delay = transition.delay, duration = transition.duration, tweened = [];
return delay <= elapsed ? start(elapsed) : d3.timer(start, delay, time), 1;
function start(elapsed) {
if (lock.active > id) return stop();
lock.active = id;
event.start.call(node, d, i);
transition.tween.forEach(function(key, value) {
if (value = value.call(node, d, i)) {
tweened.push(value);
}
});
if (!tick(elapsed)) d3.timer(tick, 0, time);
return 1;
}
function tick(elapsed) {
if (lock.active !== id) return stop();
var t = (elapsed - delay) / duration, e = ease(t), n = tweened.length;
while (n > 0) {
tweened[--n].call(node, e);
}
if (t >= 1) {
stop();
event.end.call(node, d, i);
return 1;
}
}
function stop() {
if (--lock.count) delete lock[id]; else delete node.__transition__;
return 1;
}
}, 0, time);
return transition;
}
}
d3_transitionPrototype.select = function(selector) {
var id = this.id, subgroups = [], subgroup, subnode, node;
if (typeof selector !== "function") 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))) {
if ("__data__" in node) subnode.__data__ = node.__data__;
d3_transitionNode(subnode, i, id, node.__transition__[id]);
subgroup.push(subnode);
} else {
subgroup.push(null);
}
}
}
return d3_transition(subgroups, id);
};
d3_transitionPrototype.selectAll = function(selector) {
var id = this.id, subgroups = [], subgroup, subnodes, node, subnode, transition;
if (typeof selector !== "function") 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.__transition__[id];
subnodes = selector.call(node, node.__data__, i);
subgroups.push(subgroup = []);
for (var k = -1, o = subnodes.length; ++k < o; ) {
d3_transitionNode(subnode = subnodes[k], k, id, transition);
subgroup.push(subnode);
}
}
}
}
return d3_transition(subgroups, 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)) {
subgroup.push(node);
}
}
}
return d3_transition(subgroups, this.id, this.time).ease(this.ease());
};
d3_transitionPrototype.attr = function(nameNS, value) {
if (arguments.length < 2) {
for (value in nameNS) this.attr(value, nameNS[value]);
return this;
}
var interpolate = d3_interpolateByName(nameNS), name = d3.ns.qualify(nameNS);
function attrNull() {
this.removeAttribute(name);
}
function attrNullNS() {
this.removeAttributeNS(name.space, name.local);
}
return d3_transition_tween(this, "attr." + nameNS, value, function(b) {
function attrString() {
var a = this.getAttribute(name), i;
return a !== b && (i = interpolate(a, b), function(t) {
this.setAttribute(name, i(t));
});
}
function attrStringNS() {
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 b == null ? name.local ? attrNullNS : attrNull : (b += "", name.local ? attrStringNS : attrString);
});
};
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 = "";
}
var interpolate = d3_interpolateByName(name);
function styleNull() {
this.style.removeProperty(name);
}
return d3_transition_tween(this, "style." + name, value, function(b) {
function styleString() {
var a = d3_window.getComputedStyle(this, null).getPropertyValue(name), i;
return a !== b && (i = interpolate(a, b), function(t) {
this.style.setProperty(name, i(t), priority);
});
}
return b == null ? styleNull : (b += "", styleString);
});
};
d3_transitionPrototype.styleTween = function(name, tween, priority) {
if (arguments.length < 3) priority = "";
return this.tween("style." + name, function(d, i) {
var f = tween.call(this, d, i, d3_window.getComputedStyle(this, null).getPropertyValue(name));
return f && function(t) {
this.style.setProperty(name, f(t), priority);
};
});
};
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() {
return this.each("end.transition", function() {
var p;
if (!this.__transition__ && (p = this.parentNode)) p.removeChild(this);
});
};
d3_transitionPrototype.ease = function(value) {
var id = this.id;
if (arguments.length < 1) return this.node().__transition__[id].ease;
if (typeof value !== "function") value = d3.ease.apply(d3, arguments);
return d3_selection_each(this, function(node) {
node.__transition__[id].ease = value;
});
};
d3_transitionPrototype.delay = function(value) {
var id = this.id;
return d3_selection_each(this, typeof value === "function" ? function(node, i, j) {
node.__transition__[id].delay = value.call(node, node.__data__, i, j) | 0;
} : (value |= 0, function(node) {
node.__transition__[id].delay = value;
}));
};
d3_transitionPrototype.duration = function(value) {
var id = this.id;
return d3_selection_each(this, typeof value === "function" ? function(node, i, j) {
node.__transition__[id].duration = Math.max(1, value.call(node, node.__data__, i, j) | 0);
} : (value = Math.max(1, value | 0), function(node) {
node.__transition__[id].duration = value;
}));
};
d3_transitionPrototype.each = function(type, listener) {
var id = this.id;
if (arguments.length < 2) {
var inherit = d3_transitionInherit, inheritId = d3_transitionInheritId;
d3_transitionInheritId = id;
d3_selection_each(this, function(node, i, j) {
d3_transitionInherit = node.__transition__[id];
type.call(node, node.__data__, i, j);
});
d3_transitionInherit = inherit;
d3_transitionInheritId = inheritId;
} else {
d3_selection_each(this, function(node) {
node.__transition__[id].event.on(type, listener);
});
}
return this;
};
d3_transitionPrototype.transition = function() {
var id0 = this.id, id1 = ++d3_transitionId, 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 = Object.create(node.__transition__[id0]);
transition.delay += transition.duration;
d3_transitionNode(node, i, id1, transition);
}
subgroup.push(node);
}
}
return d3_transition(subgroups, id1);
};
d3_transitionPrototype.tween = function(name, tween) {
var id = this.id;
if (arguments.length < 2) return this.node().__transition__[id].tween.get(name);
return d3_selection_each(this, tween == null ? function(node) {
node.__transition__[id].tween.remove(name);
} : function(node) {
node.__transition__[id].tween.set(name, tween);
});
};
function d3_transition_tween(groups, name, value, tween) {
var id = groups.id;
return d3_selection_each(groups, typeof value === "function" ? function(node, i, j) {
node.__transition__[id].tween.set(name, tween(value.call(node, node.__data__, i, j)));
} : (value = tween(value), function(node) {
node.__transition__[id].tween.set(name, value);
}));
}
var d3_timer_id = 0, d3_timer_byId = {}, d3_timer_queue = null, d3_timer_interval, d3_timer_timeout;
d3.timer = function(callback, delay, then) {
if (arguments.length < 3) {
if (arguments.length < 2) delay = 0; else if (!isFinite(delay)) return;
then = Date.now();
}
var timer = d3_timer_byId[callback.id];
if (timer && timer.callback === callback) {
timer.then = then;
timer.delay = delay;
} else d3_timer_byId[callback.id = ++d3_timer_id] = d3_timer_queue = {
callback: callback,
then: then,
delay: delay,
next: d3_timer_queue
};
if (!d3_timer_interval) {
d3_timer_timeout = clearTimeout(d3_timer_timeout);
d3_timer_interval = 1;
d3_timer_frame(d3_timer_step);
}
};
function d3_timer_step() {
var elapsed, now = Date.now(), t1 = d3_timer_queue;
while (t1) {
elapsed = now - t1.then;
if (elapsed >= t1.delay) t1.flush = t1.callback(elapsed);
t1 = t1.next;
}
var delay = d3_timer_flush() - 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() {
var elapsed, now = Date.now(), t1 = d3_timer_queue;
while (t1) {
elapsed = now - t1.then;
if (!t1.delay) t1.flush = t1.callback(elapsed);
t1 = t1.next;
}
d3_timer_flush();
};
function d3_timer_flush() {
var t0 = null, t1 = d3_timer_queue, then = Infinity;
while (t1) {
if (t1.flush) {
delete d3_timer_byId[t1.callback.id];
t1 = t0 ? t0.next = t1.next : d3_timer_queue = t1.next;
} else {
then = Math.min(then, t1.then + t1.delay);
t1 = (t0 = t1).next;
}
}
return then;
}
var d3_timer_frame = d3_window.requestAnimationFrame || d3_window.webkitRequestAnimationFrame || d3_window.mozRequestAnimationFrame || d3_window.oRequestAnimationFrame || d3_window.msRequestAnimationFrame || function(callback) {
setTimeout(callback, 17);
};
d3.mouse = function(container) {
return d3_mousePoint(container, d3_eventSource());
};
var d3_mouse_bug44083 = /WebKit/.test(d3_window.navigator.userAgent) ? -1 : 0;
function d3_mousePoint(container, e) {
var svg = container.ownerSVGElement || container;
if (svg.createSVGPoint) {
var point = svg.createSVGPoint();
if (d3_mouse_bug44083 < 0 && (d3_window.scrollX || d3_window.scrollY)) {
svg = d3.select(d3_document.body).append("svg").style("position", "absolute").style("top", 0).style("left", 0);
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.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;
}) : [];
};
function d3_noop() {}
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_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;
}
if (nice = nice(x1 - x0)) {
domain[i0] = nice.floor(x0);
domain[i1] = nice.ceil(x1);
}
return domain;
}
function d3_scale_niceDefault() {
return Math;
}
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) {
return d3_scale_linearTickFormat(domain, m);
};
scale.nice = function() {
d3_scale_nice(domain, d3_scale_linearNice);
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(dx) {
dx = Math.pow(10, Math.round(Math.log(dx) / Math.LN10) - 1);
return dx && {
floor: function(x) {
return Math.floor(x / dx) * dx;
},
ceil: function(x) {
return Math.ceil(x / dx) * dx;
}
};
}
function d3_scale_linearTickRange(domain, m) {
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) {
return d3.format(",." + Math.max(0, -Math.floor(Math.log(d3_scale_linearTickRange(domain, m)[2]) / Math.LN10 + .01)) + "f");
}
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_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.log = function() {
return d3_scale_log(d3.scale.linear(), d3_scale_logp);
};
function d3_scale_log(linear, log) {
var pow = log.pow;
function scale(x) {
return linear(log(x));
}
scale.invert = function(x) {
return pow(linear.invert(x));
};
scale.domain = function(x) {
if (!arguments.length) return linear.domain().map(pow);
log = x[0] < 0 ? d3_scale_logn : d3_scale_logp;
pow = log.pow;
linear.domain(x.map(log));
return scale;
};
scale.nice = function() {
linear.domain(d3_scale_nice(linear.domain(), d3_scale_niceDefault));
return scale;
};
scale.ticks = function() {
var extent = d3_scaleExtent(linear.domain()), ticks = [];
if (extent.every(isFinite)) {
var i = Math.floor(extent[0]), j = Math.ceil(extent[1]), u = pow(extent[0]), v = pow(extent[1]);
if (log === d3_scale_logn) {
ticks.push(pow(i));
for (;i++ < j; ) for (var k = 9; k > 0; k--) ticks.push(pow(i) * k);
} else {
for (;i < j; i++) for (var k = 1; k < 10; k++) ticks.push(pow(i) * k);
ticks.push(pow(i));
}
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 < 2) format = d3_scale_logFormat;
if (!arguments.length) return format;
var k = Math.max(.1, n / scale.ticks().length), f = log === d3_scale_logn ? (e = -1e-12,
Math.floor) : (e = 1e-12, Math.ceil), e;
return function(d) {
return d / pow(f(log(d) + e)) <= k ? format(d) : "";
};
};
scale.copy = function() {
return d3_scale_log(linear.copy(), log);
};
return d3_scale_linearRebind(scale, linear);
}
var d3_scale_logFormat = d3.format(".0e");
function d3_scale_logp(x) {
return Math.log(x < 0 ? 0 : x) / Math.LN10;
}
function d3_scale_logn(x) {
return -Math.log(x > 0 ? 0 : -x) / Math.LN10;
}
d3_scale_logp.pow = function(x) {
return Math.pow(10, x);
};
d3_scale_logn.pow = function(x) {
return -Math.pow(10, -x);
};
d3.scale.pow = function() {
return d3_scale_pow(d3.scale.linear(), 1);
};
function d3_scale_pow(linear, exponent) {
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 linear.domain().map(powb);
linear.domain(x.map(powp));
return scale;
};
scale.ticks = function(m) {
return d3_scale_linearTicks(scale.domain(), m);
};
scale.tickFormat = function(m) {
return d3_scale_linearTickFormat(scale.domain(), m);
};
scale.nice = function() {
return scale.domain(d3_scale_nice(scale.domain(), d3_scale_linearNice));
};
scale.exponent = function(x) {
if (!arguments.length) return exponent;
var domain = scale.domain();
powp = d3_scale_powPow(exponent = x);
powb = d3_scale_powPow(1 / exponent);
return scale.domain(domain);
};
scale.copy = function() {
return d3_scale_pow(linear.copy(), exponent);
};
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) || index.set(x, domain.push(x))) - 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 = (stop - start) / (Math.max(1, domain.length - 1) + padding);
range = steps(domain.length < 2 ? (start + stop) / 2 : start + step * padding / 2, step);
rangeBand = 0;
ranger = {
t: "rangePoints",
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)), error = stop - start - (domain.length - padding) * step;
range = steps(start + Math.round(error / 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 = [ "#1f77b4", "#ff7f0e", "#2ca02c", "#d62728", "#9467bd", "#8c564b", "#e377c2", "#7f7f7f", "#bcbd22", "#17becf" ];
var d3_category20 = [ "#1f77b4", "#aec7e8", "#ff7f0e", "#ffbb78", "#2ca02c", "#98df8a", "#d62728", "#ff9896", "#9467bd", "#c5b0d5", "#8c564b", "#c49c94", "#e377c2", "#f7b6d2", "#7f7f7f", "#c7c7c7", "#bcbd22", "#dbdb8d", "#17becf", "#9edae5" ];
var d3_category20b = [ "#393b79", "#5254a3", "#6b6ecf", "#9c9ede", "#637939", "#8ca252", "#b5cf6b", "#cedb9c", "#8c6d31", "#bd9e39", "#e7ba52", "#e7cb94", "#843c39", "#ad494a", "#d6616b", "#e7969c", "#7b4173", "#a55194", "#ce6dbd", "#de9ed6" ];
var d3_category20c = [ "#3182bd", "#6baed6", "#9ecae1", "#c6dbef", "#e6550d", "#fd8d3c", "#fdae6b", "#fdd0a2", "#31a354", "#74c476", "#a1d99b", "#c7e9c0", "#756bb1", "#9e9ac8", "#bcbddc", "#dadaeb", "#636363", "#969696", "#bdbdbd", "#d9d9d9" ];
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 NaN;
return range[d3.bisect(thresholds, x)];
}
scale.domain = function(x) {
if (!arguments.length) return domain;
domain = x.filter(function(d) {
return !isNaN(d);
}).sort(d3.ascending);
return rescale();
};
scale.range = function(x) {
if (!arguments.length) return range;
range = x;
return rescale();
};
scale.quantiles = function() {
return thresholds;
};
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.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) {
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.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) {
return d3_scale_linearTickFormat(domain, m);
};
identity.copy = function() {
return d3_scale_identity(domain);
};
return identity;
}
d3.svg = {};
d3.svg.arc = function() {
var innerRadius = d3_svg_arcInnerRadius, outerRadius = d3_svg_arcOuterRadius, startAngle = d3_svg_arcStartAngle, endAngle = d3_svg_arcEndAngle;
function arc() {
var r0 = innerRadius.apply(this, arguments), r1 = outerRadius.apply(this, arguments), a0 = startAngle.apply(this, arguments) + d3_svg_arcOffset, a1 = endAngle.apply(this, arguments) + d3_svg_arcOffset, da = (a1 < a0 && (da = a0,
a0 = a1, a1 = da), a1 - a0), df = da < π ? "0" : "1", c0 = Math.cos(a0), s0 = Math.sin(a0), c1 = Math.cos(a1), s1 = Math.sin(a1);
return da >= d3_svg_arcMax ? r0 ? "M0," + r1 + "A" + r1 + "," + r1 + " 0 1,1 0," + -r1 + "A" + r1 + "," + r1 + " 0 1,1 0," + r1 + "M0," + r0 + "A" + r0 + "," + r0 + " 0 1,0 0," + -r0 + "A" + r0 + "," + r0 + " 0 1,0 0," + r0 + "Z" : "M0," + r1 + "A" + r1 + "," + r1 + " 0 1,1 0," + -r1 + "A" + r1 + "," + r1 + " 0 1,1 0," + r1 + "Z" : r0 ? "M" + r1 * c0 + "," + r1 * s0 + "A" + r1 + "," + r1 + " 0 " + df + ",1 " + r1 * c1 + "," + r1 * s1 + "L" + r0 * c1 + "," + r0 * s1 + "A" + r0 + "," + r0 + " 0 " + df + ",0 " + r0 * c0 + "," + r0 * s0 + "Z" : "M" + r1 * c0 + "," + r1 * s0 + "A" + r1 + "," + r1 + " 0 " + df + ",1 " + r1 * c1 + "," + r1 * s1 + "L0,0" + "Z";
}
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.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.centroid = function() {
var r = (innerRadius.apply(this, arguments) + outerRadius.apply(this, arguments)) / 2, a = (startAngle.apply(this, arguments) + endAngle.apply(this, arguments)) / 2 + d3_svg_arcOffset;
return [ Math.cos(a) * r, Math.sin(a) * r ];
};
return arc;
};
var d3_svg_arcOffset = -π / 2, d3_svg_arcMax = 2 * π - 1e-6;
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_line(projection) {
var x = d3_svg_lineX, y = d3_svg_lineY, 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);
};
function d3_svg_lineX(d) {
return d[0];
}
function d3_svg_lineY(d) {
return d[1];
}
var d3_svg_lineInterpolators = d3.map({
linear: d3_svg_lineLinear,
"linear-closed": d3_svg_lineLinearClosed,
"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.join("L");
}
function d3_svg_lineLinearClosed(points) {
return d3_svg_lineLinear(points) + "Z";
}
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, points.length - 1), d3_svg_lineCardinalTangents(points, tension));
}
function d3_svg_lineCardinalClosed(points, tension) {
return points.length < 3 ? d3_svg_lineLinear(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 ];
d3_svg_lineBasisBezier(path, px, py);
while (++i < n) {
pi = points[i];
px.shift();
px.push(pi[0]);
py.shift();
py.push(pi[1]);
d3_svg_lineBasisBezier(path, px, py);
}
i = -1;
while (++i < 2) {
px.shift();
px.push(pi[0]);
py.shift();
py.push(pi[1]);
d3_svg_lineBasisBezier(path, px, py);
}
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 (Math.abs(d) < 1e-6) {
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] + d3_svg_arcOffset;
point[0] = r * Math.cos(a);
point[1] = r * Math.sin(a);
}
return points;
}
function d3_svg_area(projection) {
var x0 = d3_svg_lineX, x1 = d3_svg_lineX, y0 = 0, y1 = d3_svg_lineY, 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) + d3_svg_arcOffset, a1 = endAngle.call(self, subgroup, i) + d3_svg_arcOffset;
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] + d3_svg_arcOffset;
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.svg.axis = function() {
var scale = d3.scale.linear(), orient = d3_svg_axisDefaultOrient, tickMajorSize = 6, tickMinorSize = 6, tickEndSize = 6, tickPadding = 3, tickArguments_ = [ 10 ], tickValues = null, tickFormat_, tickSubdivide = 0;
function axis(g) {
g.each(function() {
var g = d3.select(this);
var ticks = tickValues == null ? scale.ticks ? scale.ticks.apply(scale, tickArguments_) : scale.domain() : tickValues, tickFormat = tickFormat_ == null ? scale.tickFormat ? scale.tickFormat.apply(scale, tickArguments_) : String : tickFormat_;
var subticks = d3_svg_axisSubdivide(scale, ticks, tickSubdivide), subtick = g.selectAll(".tick.minor").data(subticks, String), subtickEnter = subtick.enter().insert("line", ".tick").attr("class", "tick minor").style("opacity", 1e-6), subtickExit = d3.transition(subtick.exit()).style("opacity", 1e-6).remove(), subtickUpdate = d3.transition(subtick).style("opacity", 1);
var tick = g.selectAll(".tick.major").data(ticks, String), tickEnter = tick.enter().insert("g", "path").attr("class", "tick major").style("opacity", 1e-6), tickExit = d3.transition(tick.exit()).style("opacity", 1e-6).remove(), tickUpdate = d3.transition(tick).style("opacity", 1), tickTransform;
var range = d3_scaleRange(scale), path = g.selectAll(".domain").data([ 0 ]), pathUpdate = (path.enter().append("path").attr("class", "domain"),
d3.transition(path));
var scale1 = scale.copy(), scale0 = this.__chart__ || scale1;
this.__chart__ = scale1;
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");
switch (orient) {
case "bottom":
{
tickTransform = d3_svg_axisX;
subtickEnter.attr("y2", tickMinorSize);
subtickUpdate.attr("x2", 0).attr("y2", tickMinorSize);
lineEnter.attr("y2", tickMajorSize);
textEnter.attr("y", Math.max(tickMajorSize, 0) + tickPadding);
lineUpdate.attr("x2", 0).attr("y2", tickMajorSize);
textUpdate.attr("x", 0).attr("y", Math.max(tickMajorSize, 0) + tickPadding);
text.attr("dy", ".71em").style("text-anchor", "middle");
pathUpdate.attr("d", "M" + range[0] + "," + tickEndSize + "V0H" + range[1] + "V" + tickEndSize);
break;
}
case "top":
{
tickTransform = d3_svg_axisX;
subtickEnter.attr("y2", -tickMinorSize);
subtickUpdate.attr("x2", 0).attr("y2", -tickMinorSize);
lineEnter.attr("y2", -tickMajorSize);
textEnter.attr("y", -(Math.max(tickMajorSize, 0) + tickPadding));
lineUpdate.attr("x2", 0).attr("y2", -tickMajorSize);
textUpdate.attr("x", 0).attr("y", -(Math.max(tickMajorSize, 0) + tickPadding));
text.attr("dy", "0em").style("text-anchor", "middle");
pathUpdate.attr("d", "M" + range[0] + "," + -tickEndSize + "V0H" + range[1] + "V" + -tickEndSize);
break;
}
case "left":
{
tickTransform = d3_svg_axisY;
subtickEnter.attr("x2", -tickMinorSize);
subtickUpdate.attr("x2", -tickMinorSize).attr("y2", 0);
lineEnter.attr("x2", -tickMajorSize);
textEnter.attr("x", -(Math.max(tickMajorSize, 0) + tickPadding));
lineUpdate.attr("x2", -tickMajorSize).attr("y2", 0);
textUpdate.attr("x", -(Math.max(tickMajorSize, 0) + tickPadding)).attr("y", 0);
text.attr("dy", ".32em").style("text-anchor", "end");
pathUpdate.attr("d", "M" + -tickEndSize + "," + range[0] + "H0V" + range[1] + "H" + -tickEndSize);
break;
}
case "right":
{
tickTransform = d3_svg_axisY;
subtickEnter.attr("x2", tickMinorSize);
subtickUpdate.attr("x2", tickMinorSize).attr("y2", 0);
lineEnter.attr("x2", tickMajorSize);
textEnter.attr("x", Math.max(tickMajorSize, 0) + tickPadding);
lineUpdate.attr("x2", tickMajorSize).attr("y2", 0);
textUpdate.attr("x", Math.max(tickMajorSize, 0) + tickPadding).attr("y", 0);
text.attr("dy", ".32em").style("text-anchor", "start");
pathUpdate.attr("d", "M" + tickEndSize + "," + range[0] + "H0V" + range[1] + "H" + tickEndSize);
break;
}
}
if (scale.ticks) {
tickEnter.call(tickTransform, scale0);
tickUpdate.call(tickTransform, scale1);
tickExit.call(tickTransform, scale1);
subtickEnter.call(tickTransform, scale0);
subtickUpdate.call(tickTransform, scale1);
subtickExit.call(tickTransform, scale1);
} else {
var dx = scale1.rangeBand() / 2, x = function(d) {
return scale1(d) + dx;
};
tickEnter.call(tickTransform, x);
tickUpdate.call(tickTransform, x);
}
});
}
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_ = 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, y) {
if (!arguments.length) return tickMajorSize;
var n = arguments.length - 1;
tickMajorSize = +x;
tickMinorSize = n > 1 ? +y : tickMajorSize;
tickEndSize = n > 0 ? +arguments[n] : tickMajorSize;
return axis;
};
axis.tickPadding = function(x) {
if (!arguments.length) return tickPadding;
tickPadding = +x;
return axis;
};
axis.tickSubdivide = function(x) {
if (!arguments.length) return tickSubdivide;
tickSubdivide = +x;
return axis;
};
return axis;
};
var d3_svg_axisDefaultOrient = "bottom", d3_svg_axisOrients = {
top: 1,
right: 1,
bottom: 1,
left: 1
};
function d3_svg_axisX(selection, x) {
selection.attr("transform", function(d) {
return "translate(" + x(d) + ",0)";
});
}
function d3_svg_axisY(selection, y) {
selection.attr("transform", function(d) {
return "translate(0," + y(d) + ")";
});
}
function d3_svg_axisSubdivide(scale, ticks, m) {
subticks = [];
if (m && ticks.length > 1) {
var extent = d3_scaleExtent(scale.domain()), subticks, i = -1, n = ticks.length, d = (ticks[1] - ticks[0]) / ++m, j, v;
while (++i < n) {
for (j = m; --j > 0; ) {
if ((v = +ticks[i] - j * d) >= extent[0]) {
subticks.push(v);
}
}
}
for (--i, j = 0; ++j < m && (v = +ticks[i] + j * d) < extent[1]; ) {
subticks.push(v);
}
}
return subticks;
}
d3.svg.brush = function() {
var event = d3_eventDispatch(brush, "brushstart", "brush", "brushend"), x = null, y = null, resizes = d3_svg_brushResizes[0], extent = [ [ 0, 0 ], [ 0, 0 ] ], extentDomain;
function brush(g) {
g.each(function() {
var g = d3.select(this), bg = g.selectAll(".background").data([ 0 ]), fg = g.selectAll(".extent").data([ 0 ]), tz = g.selectAll(".resize").data(resizes, String), e;
g.style("pointer-events", "all").on("mousedown.brush", brushstart).on("touchstart.brush", brushstart);
bg.enter().append("rect").attr("class", "background").style("visibility", "hidden").style("cursor", "crosshair");
fg.enter().append("rect").attr("class", "extent").style("cursor", "move");
tz.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");
tz.style("display", brush.empty() ? "none" : null);
tz.exit().remove();
if (x) {
e = d3_scaleRange(x);
bg.attr("x", e[0]).attr("width", e[1] - e[0]);
redrawX(g);
}
if (y) {
e = d3_scaleRange(y);
bg.attr("y", e[0]).attr("height", e[1] - e[0]);
redrawY(g);
}
redraw(g);
});
}
function redraw(g) {
g.selectAll(".resize").attr("transform", function(d) {
return "translate(" + extent[+/e$/.test(d)][0] + "," + extent[+/^s/.test(d)][1] + ")";
});
}
function redrawX(g) {
g.select(".extent").attr("x", extent[0][0]);
g.selectAll(".extent,.n>rect,.s>rect").attr("width", extent[1][0] - extent[0][0]);
}
function redrawY(g) {
g.select(".extent").attr("y", extent[0][1]);
g.selectAll(".extent,.e>rect,.w>rect").attr("height", extent[1][1] - extent[0][1]);
}
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"), center, origin = mouse(), offset;
var w = d3.select(d3_window).on("mousemove.brush", brushmove).on("mouseup.brush", brushend).on("touchmove.brush", brushmove).on("touchend.brush", brushend).on("keydown.brush", keydown).on("keyup.brush", keyup);
if (dragging) {
origin[0] = extent[0][0] - origin[0];
origin[1] = extent[0][1] - origin[1];
} else if (resizing) {
var ex = +/w$/.test(resizing), ey = +/^n/.test(resizing);
offset = [ extent[1 - ex][0] - origin[0], extent[1 - ey][1] - origin[1] ];
origin[0] = extent[ex][0];
origin[1] = extent[ey][1];
} 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();
d3_eventCancel();
function mouse() {
var touches = d3.event.changedTouches;
return touches ? d3.touches(target, touches)[0] : d3.mouse(target);
}
function keydown() {
if (d3.event.keyCode == 32) {
if (!dragging) {
center = null;
origin[0] -= extent[1][0];
origin[1] -= extent[1][1];
dragging = 2;
}
d3_eventCancel();
}
}
function keyup() {
if (d3.event.keyCode == 32 && dragging == 2) {
origin[0] += extent[1][0];
origin[1] += extent[1][1];
dragging = 0;
d3_eventCancel();
}
}
function brushmove() {
var point = mouse(), moved = false;
if (offset) {
point[0] += offset[0];
point[1] += offset[1];
}
if (!dragging) {
if (d3.event.altKey) {
if (!center) center = [ (extent[0][0] + extent[1][0]) / 2, (extent[0][1] + extent[1][1]) / 2 ];
origin[0] = extent[+(point[0] < center[0])][0];
origin[1] = extent[+(point[1] < center[1])][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], size = extent[1][i] - extent[0][i], min, max;
if (dragging) {
r0 -= position;
r1 -= size + position;
}
min = Math.max(r0, Math.min(r1, 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][i] !== min || extent[1][i] !== max) {
extentDomain = null;
extent[0][i] = min;
extent[1][i] = 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);
event_({
type: "brushend"
});
d3_eventCancel();
}
}
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.extent = function(z) {
var x0, x1, y0, y1, t;
if (!arguments.length) {
z = extentDomain || extent;
if (x) {
x0 = z[0][0], x1 = z[1][0];
if (!extentDomain) {
x0 = extent[0][0], x1 = extent[1][0];
if (x.invert) x0 = x.invert(x0), x1 = x.invert(x1);
if (x1 < x0) t = x0, x0 = x1, x1 = t;
}
}
if (y) {
y0 = z[0][1], y1 = z[1][1];
if (!extentDomain) {
y0 = extent[0][1], y1 = extent[1][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 ];
}
extentDomain = [ [ 0, 0 ], [ 0, 0 ] ];
if (x) {
x0 = z[0], x1 = z[1];
if (y) x0 = x0[0], x1 = x1[0];
extentDomain[0][0] = x0, extentDomain[1][0] = x1;
if (x.invert) x0 = x(x0), x1 = x(x1);
if (x1 < x0) t = x0, x0 = x1, x1 = t;
extent[0][0] = x0 | 0, extent[1][0] = x1 | 0;
}
if (y) {
y0 = z[0], y1 = z[1];
if (x) y0 = y0[1], y1 = y1[1];
extentDomain[0][1] = y0, extentDomain[1][1] = y1;
if (y.invert) y0 = y(y0), y1 = y(y1);
if (y1 < y0) t = y0, y0 = y1, y1 = t;
extent[0][1] = y0 | 0, extent[1][1] = y1 | 0;
}
return brush;
};
brush.clear = function() {
extentDomain = null;
extent[0][0] = extent[0][1] = extent[1][0] = extent[1][1] = 0;
return brush;
};
brush.empty = function() {
return x && extent[0][0] === extent[1][0] || y && extent[0][1] === extent[1][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" ], [] ];
d3.behavior = {};
d3.behavior.drag = function() {
var event = d3_eventDispatch(drag, "drag", "dragstart", "dragend"), origin = null;
function drag() {
this.on("mousedown.drag", mousedown).on("touchstart.drag", mousedown);
}
function mousedown() {
var target = this, event_ = event.of(target, arguments), eventTarget = d3.event.target, touchId = d3.event.touches ? d3.event.changedTouches[0].identifier : null, offset, origin_ = point(), moved = 0;
var w = d3.select(d3_window).on(touchId != null ? "touchmove.drag-" + touchId : "mousemove.drag", dragmove).on(touchId != null ? "touchend.drag-" + touchId : "mouseup.drag", dragend, true);
if (origin) {
offset = origin.apply(target, arguments);
offset = [ offset.x - origin_[0], offset.y - origin_[1] ];
} else {
offset = [ 0, 0 ];
}
if (touchId == null) d3_eventCancel();
event_({
type: "dragstart"
});
function point() {
var p = target.parentNode;
return touchId != null ? d3.touches(p).filter(function(p) {
return p.identifier === touchId;
})[0] : d3.mouse(p);
}
function dragmove() {
if (!target.parentNode) return dragend();
var p = point(), dx = p[0] - origin_[0], dy = p[1] - origin_[1];
moved |= dx | dy;
origin_ = p;
d3_eventCancel();
event_({
type: "drag",
x: p[0] + offset[0],
y: p[1] + offset[1],
dx: dx,
dy: dy
});
}
function dragend() {
event_({
type: "dragend"
});
if (moved) {
d3_eventCancel();
if (d3.event.target === eventTarget) w.on("click.drag", click, true);
}
w.on(touchId != null ? "touchmove.drag-" + touchId : "mousemove.drag", null).on(touchId != null ? "touchend.drag-" + touchId : "mouseup.drag", null);
}
function click() {
d3_eventCancel();
w.on("click.drag", null);
}
}
drag.origin = function(x) {
if (!arguments.length) return origin;
origin = x;
return drag;
};
return d3.rebind(drag, event, "on");
};
d3.behavior.zoom = function() {
var translate = [ 0, 0 ], translate0, scale = 1, scale0, scaleExtent = d3_behavior_zoomInfinity, event = d3_eventDispatch(zoom, "zoom"), x0, x1, y0, y1, touchtime;
function zoom() {
this.on("mousedown.zoom", mousedown).on("mousemove.zoom", mousemove).on(d3_behavior_zoomWheel + ".zoom", mousewheel).on("dblclick.zoom", dblclick).on("touchstart.zoom", touchstart).on("touchmove.zoom", touchmove).on("touchend.zoom", touchstart);
}
zoom.translate = function(x) {
if (!arguments.length) return translate;
translate = x.map(Number);
rescale();
return zoom;
};
zoom.scale = function(x) {
if (!arguments.length) return scale;
scale = +x;
rescale();
return zoom;
};
zoom.scaleExtent = function(x) {
if (!arguments.length) return scaleExtent;
scaleExtent = x == null ? d3_behavior_zoomInfinity : x.map(Number);
return zoom;
};
zoom.x = function(z) {
if (!arguments.length) return x1;
x1 = z;
x0 = z.copy();
translate = [ 0, 0 ];
scale = 1;
return zoom;
};
zoom.y = function(z) {
if (!arguments.length) return y1;
y1 = z;
y0 = z.copy();
translate = [ 0, 0 ];
scale = 1;
return zoom;
};
function location(p) {
return [ (p[0] - translate[0]) / scale, (p[1] - translate[1]) / scale ];
}
function point(l) {
return [ l[0] * scale + translate[0], l[1] * scale + translate[1] ];
}
function scaleTo(s) {
scale = Math.max(scaleExtent[0], Math.min(scaleExtent[1], s));
}
function translateTo(p, l) {
l = point(l);
translate[0] += p[0] - l[0];
translate[1] += p[1] - l[1];
}
function rescale() {
if (x1) x1.domain(x0.range().map(function(x) {
return (x - translate[0]) / scale;
}).map(x0.invert));
if (y1) y1.domain(y0.range().map(function(y) {
return (y - translate[1]) / scale;
}).map(y0.invert));
}
function dispatch(event) {
rescale();
d3.event.preventDefault();
event({
type: "zoom",
scale: scale,
translate: translate
});
}
function mousedown() {
var target = this, event_ = event.of(target, arguments), eventTarget = d3.event.target, moved = 0, w = d3.select(d3_window).on("mousemove.zoom", mousemove).on("mouseup.zoom", mouseup), l = location(d3.mouse(target));
d3_window.focus();
d3_eventCancel();
function mousemove() {
moved = 1;
translateTo(d3.mouse(target), l);
dispatch(event_);
}
function mouseup() {
if (moved) d3_eventCancel();
w.on("mousemove.zoom", null).on("mouseup.zoom", null);
if (moved && d3.event.target === eventTarget) w.on("click.zoom", click, true);
}
function click() {
d3_eventCancel();
w.on("click.zoom", null);
}
}
function mousewheel() {
if (!translate0) translate0 = location(d3.mouse(this));
scaleTo(Math.pow(2, d3_behavior_zoomDelta() * .002) * scale);
translateTo(d3.mouse(this), translate0);
dispatch(event.of(this, arguments));
}
function mousemove() {
translate0 = null;
}
function dblclick() {
var p = d3.mouse(this), l = location(p), k = Math.log(scale) / Math.LN2;
scaleTo(Math.pow(2, d3.event.shiftKey ? Math.ceil(k) - 1 : Math.floor(k) + 1));
translateTo(p, l);
dispatch(event.of(this, arguments));
}
function touchstart() {
var touches = d3.touches(this), now = Date.now();
scale0 = scale;
translate0 = {};
touches.forEach(function(t) {
translate0[t.identifier] = location(t);
});
d3_eventCancel();
if (touches.length === 1) {
if (now - touchtime < 500) {
var p = touches[0], l = location(touches[0]);
scaleTo(scale * 2);
translateTo(p, l);
dispatch(event.of(this, arguments));
}
touchtime = now;
}
}
function touchmove() {
var touches = d3.touches(this), p0 = touches[0], l0 = translate0[p0.identifier];
if (p1 = touches[1]) {
var p1, l1 = translate0[p1.identifier];
p0 = [ (p0[0] + p1[0]) / 2, (p0[1] + p1[1]) / 2 ];
l0 = [ (l0[0] + l1[0]) / 2, (l0[1] + l1[1]) / 2 ];
scaleTo(d3.event.scale * scale0);
}
translateTo(p0, l0);
touchtime = null;
dispatch(event.of(this, arguments));
}
return d3.rebind(zoom, event, "on");
};
var d3_behavior_zoomInfinity = [ 0, Infinity ];
var d3_behavior_zoomDelta, d3_behavior_zoomWheel = "onwheel" in document ? (d3_behavior_zoomDelta = function() {
return -d3.event.deltaY * (d3.event.deltaMode ? 120 : 1);
}, "wheel") : "onmousewheel" in document ? (d3_behavior_zoomDelta = function() {
return d3.event.wheelDelta;
}, "mousewheel") : (d3_behavior_zoomDelta = function() {
return -d3.event.detail;
}, "MozMousePixelScroll");
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 = (2 * π - 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: (x - x0) / k
};
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"), size = [ 1, 1 ], drag, alpha, friction = .9, linkDistance = d3_layout_forceLinkDistance, linkStrength = d3_layout_forceLinkStrength, charge = -30, gravity = .1, theta = .8, 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, dn = 1 / Math.sqrt(dx * dx + dy * dy);
if ((x2 - x1) * dn < theta) {
var k = quad.charge * dn * dn;
node.px -= dx * k;
node.py -= dy * k;
return true;
}
if (quad.point && isFinite(dn)) {
var k = quad.pointCharge * dn * dn;
node.px -= dx * k;
node.py -= dy * k;
}
}
return !quad.charge;
};
}
force.tick = function() {
if ((alpha *= .99) < .005) {
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));
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.gravity = function(x) {
if (!arguments.length) return gravity;
gravity = +x;
return force;
};
force.theta = function(x) {
if (!arguments.length) return theta;
theta = +x;
return force;
};
force.alpha = function(x) {
if (!arguments.length) return alpha;
x = +x;
if (alpha) {
if (x > 0) alpha = x; else alpha = 0;
} else if (x > 0) {
event.start({
type: "start",
alpha: alpha = x
});
d3.timer(force.tick);
}
return force;
};
force.start = function() {
var i, j, 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) {
var neighbors = neighbor(i), j = -1, m = neighbors.length, x;
while (++j < m) if (!isNaN(x = neighbors[j][dimension])) return x;
return Math.random() * size;
}
function neighbor() {
if (!neighbors) {
neighbors = [];
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);
}
}
return neighbors[i];
}
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.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 = 2 * π;
function pie(data) {
var values = data.map(function(d, i) {
return +value.call(pie, d, i);
});
var a = +(typeof startAngle === "function" ? startAngle.apply(this, arguments) : startAngle);
var k = ((typeof endAngle === "function" ? endAngle.apply(this, arguments) : endAngle) - startAngle) / d3.sum(values);
var index = d3.range(data.length);
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]);
});
var arcs = [];
index.forEach(function(i) {
var d;
arcs[i] = {
data: data[i],
value: d = values[i],
startAngle: a,
endAngle: a += d * k
};
});
return arcs;
}
pie.value = function(x) {
if (!arguments.length) return value;
value = x;
return pie;
};
pie.sort = function(x) {
if (!arguments.length) return sort;
sort = x;
return pie;
};
pie.startAngle = function(x) {
if (!arguments.length) return startAngle;
startAngle = x;
return pie;
};
pie.endAngle = function(x) {
if (!arguments.length) return endAngle;
endAngle = x;
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) {
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 n = series.length, m = series[0].length, 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.hierarchy = function() {
var sort = d3_layout_hierarchySort, children = d3_layout_hierarchyChildren, value = d3_layout_hierarchyValue;
function recurse(node, depth, nodes) {
var childs = children.call(hierarchy, node, depth);
node.depth = depth;
nodes.push(node);
if (childs && (n = childs.length)) {
var i = -1, n, c = node.children = [], v = 0, j = depth + 1, d;
while (++i < n) {
d = recurse(childs[i], j, nodes);
d.parent = node;
c.push(d);
v += d.value;
}
if (sort) c.sort(sort);
if (value) node.value = v;
} else if (value) {
node.value = +value.call(hierarchy, node, depth) || 0;
}
return node;
}
function revalue(node, depth) {
var children = node.children, v = 0;
if (children && (n = children.length)) {
var i = -1, n, j = depth + 1;
while (++i < n) v += revalue(children[i], j);
} else if (value) {
v = +value.call(hierarchy, node, depth) || 0;
}
if (value) node.value = v;
return v;
}
function hierarchy(d) {
var nodes = [];
recurse(d, 0, nodes);
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) {
revalue(root, 0);
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_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.pack = function() {
var hierarchy = d3.layout.hierarchy().sort(d3_layout_packSort), padding = 0, size = [ 1, 1 ];
function pack(d, i) {
var nodes = hierarchy.call(this, d, i), root = nodes[0];
root.x = 0;
root.y = 0;
d3_layout_treeVisitAfter(root, function(d) {
d.r = Math.sqrt(d.value);
});
d3_layout_treeVisitAfter(root, d3_layout_packSiblings);
var w = size[0], h = size[1], k = Math.max(2 * root.r / w, 2 * root.r / h);
if (padding > 0) {
var dr = padding * k / 2;
d3_layout_treeVisitAfter(root, function(d) {
d.r += dr;
});
d3_layout_treeVisitAfter(root, d3_layout_packSiblings);
d3_layout_treeVisitAfter(root, function(d) {
d.r -= dr;
});
k = Math.max(2 * root.r / w, 2 * root.r / h);
}
d3_layout_packTransform(root, w / 2, h / 2, 1 / k);
return nodes;
}
pack.size = function(x) {
if (!arguments.length) return size;
size = x;
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 dr * dr - dx * dx - dy * dy > .001;
}
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.cluster = function() {
var hierarchy = d3.layout.hierarchy().sort(null).value(null), separation = d3_layout_treeSeparation, size = [ 1, 1 ];
function cluster(d, i) {
var nodes = hierarchy.call(this, d, i), root = nodes[0], previousNode, x = 0;
d3_layout_treeVisitAfter(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_treeVisitAfter(root, 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 size;
size = x;
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.tree = function() {
var hierarchy = d3.layout.hierarchy().sort(null).value(null), separation = d3_layout_treeSeparation, size = [ 1, 1 ];
function tree(d, i) {
var nodes = hierarchy.call(this, d, i), root = nodes[0];
function firstWalk(node, previousSibling) {
var children = node.children, layout = node._tree;
if (children && (n = children.length)) {
var n, firstChild = children[0], previousChild, ancestor = firstChild, child, i = -1;
while (++i < n) {
child = children[i];
firstWalk(child, previousChild);
ancestor = apportion(child, previousChild, ancestor);
previousChild = child;
}
d3_layout_treeShift(node);
var midpoint = .5 * (firstChild._tree.prelim + child._tree.prelim);
if (previousSibling) {
layout.prelim = previousSibling._tree.prelim + separation(node, previousSibling);
layout.mod = layout.prelim - midpoint;
} else {
layout.prelim = midpoint;
}
} else {
if (previousSibling) {
layout.prelim = previousSibling._tree.prelim + separation(node, previousSibling);
}
}
}
function secondWalk(node, x) {
node.x = node._tree.prelim + x;
var children = node.children;
if (children && (n = children.length)) {
var i = -1, n;
x += node._tree.mod;
while (++i < n) {
secondWalk(children[i], x);
}
}
}
function apportion(node, previousSibling, ancestor) {
if (previousSibling) {
var vip = node, vop = node, vim = previousSibling, vom = node.parent.children[0], sip = vip._tree.mod, sop = vop._tree.mod, sim = vim._tree.mod, som = vom._tree.mod, 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._tree.ancestor = node;
shift = vim._tree.prelim + sim - vip._tree.prelim - sip + separation(vim, vip);
if (shift > 0) {
d3_layout_treeMove(d3_layout_treeAncestor(vim, node, ancestor), node, shift);
sip += shift;
sop += shift;
}
sim += vim._tree.mod;
sip += vip._tree.mod;
som += vom._tree.mod;
sop += vop._tree.mod;
}
if (vim && !d3_layout_treeRight(vop)) {
vop._tree.thread = vim;
vop._tree.mod += sim - sop;
}
if (vip && !d3_layout_treeLeft(vom)) {
vom._tree.thread = vip;
vom._tree.mod += sip - som;
ancestor = node;
}
}
return ancestor;
}
d3_layout_treeVisitAfter(root, function(node, previousSibling) {
node._tree = {
ancestor: node,
prelim: 0,
mod: 0,
change: 0,
shift: 0,
number: previousSibling ? previousSibling._tree.number + 1 : 0
};
});
firstWalk(root);
secondWalk(root, -root._tree.prelim);
var left = d3_layout_treeSearch(root, d3_layout_treeLeftmost), right = d3_layout_treeSearch(root, d3_layout_treeRightmost), deep = d3_layout_treeSearch(root, d3_layout_treeDeepest), x0 = left.x - separation(left, right) / 2, x1 = right.x + separation(right, left) / 2, y1 = deep.depth || 1;
d3_layout_treeVisitAfter(root, function(node) {
node.x = (node.x - x0) / (x1 - x0) * size[0];
node.y = node.depth / y1 * size[1];
delete node._tree;
});
return nodes;
}
tree.separation = function(x) {
if (!arguments.length) return separation;
separation = x;
return tree;
};
tree.size = function(x) {
if (!arguments.length) return size;
size = x;
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(node) {
var children = node.children;
return children && children.length ? children[0] : node._tree.thread;
}
function d3_layout_treeRight(node) {
var children = node.children, n;
return children && (n = children.length) ? children[n - 1] : node._tree.thread;
}
function d3_layout_treeSearch(node, compare) {
var children = node.children;
if (children && (n = children.length)) {
var child, n, i = -1;
while (++i < n) {
if (compare(child = d3_layout_treeSearch(children[i], compare), node) > 0) {
node = child;
}
}
}
return node;
}
function d3_layout_treeRightmost(a, b) {
return a.x - b.x;
}
function d3_layout_treeLeftmost(a, b) {
return b.x - a.x;
}
function d3_layout_treeDeepest(a, b) {
return a.depth - b.depth;
}
function d3_layout_treeVisitAfter(node, callback) {
function visit(node, previousSibling) {
var children = node.children;
if (children && (n = children.length)) {
var child, previousChild = null, i = -1, n;
while (++i < n) {
child = children[i];
visit(child, previousChild);
previousChild = child;
}
}
callback(node, previousSibling);
}
visit(node, null);
}
function d3_layout_treeShift(node) {
var shift = 0, change = 0, children = node.children, i = children.length, child;
while (--i >= 0) {
child = children[i]._tree;
child.prelim += shift;
child.mod += shift;
shift += child.shift + (change += child.change);
}
}
function d3_layout_treeMove(ancestor, node, shift) {
ancestor = ancestor._tree;
node = node._tree;
var change = shift / (node.number - ancestor.number);
ancestor.change += change;
node.change -= change;
node.shift += shift;
node.prelim += shift;
node.mod += shift;
}
function d3_layout_treeAncestor(vim, node, ancestor) {
return vim._tree.ancestor.parent == node.parent ? vim._tree.ancestor : ancestor;
}
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 = 0;
root.y = 0;
root.dx = size[0];
root.dy = size[1];
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
};
}
function d3_dsv(delimiter, mimeType) {
var reFormat = new RegExp('["' + delimiter + "\n]"), delimiterCode = delimiter.charCodeAt(0);
function dsv(url, callback) {
return d3.xhr(url, mimeType, callback).response(response);
}
function response(request) {
return dsv.parse(request.responseText);
}
dsv.parse = function(text) {
var o;
return dsv.parseRows(text, function(row) {
if (o) return o(row);
o = new Function("d", "return {" + row.map(function(name, i) {
return JSON.stringify(name) + ": d[" + i + "]";
}).join(",") + "}");
});
};
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.substring(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.substring(j, I - k);
}
return text.substring(j);
}
while ((t = token()) !== EOF) {
var a = [];
while (t !== EOL && t !== EOF) {
a.push(t);
t = token();
}
if (f && !(a = f(a, n++))) continue;
rows.push(a);
}
return rows;
};
dsv.format = 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");
d3.geo = {};
d3.geo.stream = function(object, listener) {
if (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 (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) {
var coordinate = object.coordinates;
listener.point(coordinate[0], coordinate[1]);
},
MultiPoint: function(object, listener) {
var coordinates = object.coordinates, i = -1, n = coordinates.length, coordinate;
while (++i < n) coordinate = coordinates[i], listener.point(coordinate[0], coordinate[1]);
},
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]);
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();
}
function d3_geo_spherical(cartesian) {
return [ Math.atan2(cartesian[1], cartesian[0]), Math.asin(Math.max(-1, Math.min(1, cartesian[2]))) ];
}
function d3_geo_sphericalEqual(a, b) {
return Math.abs(a[0] - b[0]) < ε && Math.abs(a[1] - b[1]) < ε;
}
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_resample(project) {
var δ2 = .5, maxDepth = 16;
function resample(stream) {
var λ0, x0, y0, a0, b0, c0;
var resample = {
point: point,
lineStart: lineStart,
lineEnd: lineEnd,
polygonStart: function() {
stream.polygonStart();
resample.lineStart = polygonLineStart;
},
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 polygonLineStart() {
var λ00, φ00, x00, y00, a00, b00, c00;
lineStart();
resample.point = function(λ, φ) {
linePoint(λ00 = λ, φ00 = φ), x00 = x0, y00 = y0, a00 = a0, b00 = b0, c00 = c0;
resample.point = linePoint;
};
resample.lineEnd = function() {
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 = Math.abs(Math.abs(c) - 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 || Math.abs((dx * dx2 + dy * dy2) / d2 - .5) > .3) {
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.albersUsa = function() {
var lower48 = d3.geo.albers();
var alaska = d3.geo.albers().rotate([ 160, 0 ]).center([ 0, 60 ]).parallels([ 55, 65 ]);
var hawaii = d3.geo.albers().rotate([ 160, 0 ]).center([ 0, 20 ]).parallels([ 8, 18 ]);
var puertoRico = d3.geo.albers().rotate([ 60, 0 ]).center([ 0, 10 ]).parallels([ 8, 18 ]);
function albersUsa(coordinates) {
return projection(coordinates)(coordinates);
}
function projection(point) {
var lon = point[0], lat = point[1];
return lat > 50 ? alaska : lon < -140 ? hawaii : lat < 21 ? puertoRico : lower48;
}
albersUsa.scale = function(x) {
if (!arguments.length) return lower48.scale();
lower48.scale(x);
alaska.scale(x * .6);
hawaii.scale(x);
puertoRico.scale(x * 1.5);
return albersUsa.translate(lower48.translate());
};
albersUsa.translate = function(x) {
if (!arguments.length) return lower48.translate();
var dz = lower48.scale(), dx = x[0], dy = x[1];
lower48.translate(x);
alaska.translate([ dx - .4 * dz, dy + .17 * dz ]);
hawaii.translate([ dx - .19 * dz, dy + .2 * dz ]);
puertoRico.translate([ dx + .58 * dz, dy + .43 * dz ]);
return albersUsa;
};
return albersUsa.scale(lower48.scale());
};
function d3_geo_albers(φ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 albers(λ, φ) {
var ρ = Math.sqrt(C - 2 * n * Math.sin(φ)) / n;
return [ ρ * Math.sin(λ *= n), ρ0 - ρ * Math.cos(λ) ];
}
albers.invert = function(x, y) {
var ρ0_y = ρ0 - y;
return [ Math.atan2(x, ρ0_y) / n, Math.asin((C - (x * x + ρ0_y * ρ0_y) * n * n) / (2 * n)) ];
};
return albers;
}
(d3.geo.albers = function() {
var φ0 = 29.5 * d3_radians, φ1 = 45.5 * d3_radians, m = d3_geo_projectionMutator(d3_geo_albers), p = m(φ0, φ1);
p.parallels = function(_) {
if (!arguments.length) return [ φ0 * d3_degrees, φ1 * d3_degrees ];
return m(φ0 = _[0] * d3_radians, φ1 = _[1] * d3_radians);
};
return p.rotate([ 98, 0 ]).center([ 0, 38 ]).scale(1e3);
}).raw = d3_geo_albers;
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;
d3.geo.bounds = d3_geo_bounds(d3_identity);
function d3_geo_bounds(projectStream) {
var x0, y0, x1, y1;
var bound = {
point: boundPoint,
lineStart: d3_noop,
lineEnd: d3_noop,
polygonStart: function() {
bound.lineEnd = boundPolygonLineEnd;
},
polygonEnd: function() {
bound.point = boundPoint;
}
};
function boundPoint(x, y) {
if (x < x0) x0 = x;
if (x > x1) x1 = x;
if (y < y0) y0 = y;
if (y > y1) y1 = y;
}
function boundPolygonLineEnd() {
bound.point = bound.lineEnd = d3_noop;
}
return function(feature) {
y1 = x1 = -(x0 = y0 = Infinity);
d3.geo.stream(feature, projectStream(bound));
return [ [ x0, y0 ], [ x1, y1 ] ];
};
}
d3.geo.centroid = function(object) {
d3_geo_centroidDimension = d3_geo_centroidW = d3_geo_centroidX = d3_geo_centroidY = d3_geo_centroidZ = 0;
d3.geo.stream(object, d3_geo_centroid);
var m;
if (d3_geo_centroidW && Math.abs(m = Math.sqrt(d3_geo_centroidX * d3_geo_centroidX + d3_geo_centroidY * d3_geo_centroidY + d3_geo_centroidZ * d3_geo_centroidZ)) > ε) {
return [ Math.atan2(d3_geo_centroidY, d3_geo_centroidX) * d3_degrees, Math.asin(Math.max(-1, Math.min(1, d3_geo_centroidZ / m))) * d3_degrees ];
}
};
var d3_geo_centroidDimension, d3_geo_centroidW, d3_geo_centroidX, d3_geo_centroidY, d3_geo_centroidZ;
var d3_geo_centroid = {
sphere: function() {
if (d3_geo_centroidDimension < 2) {
d3_geo_centroidDimension = 2;
d3_geo_centroidW = d3_geo_centroidX = d3_geo_centroidY = d3_geo_centroidZ = 0;
}
},
point: d3_geo_centroidPoint,
lineStart: d3_geo_centroidLineStart,
lineEnd: d3_geo_centroidLineEnd,
polygonStart: function() {
if (d3_geo_centroidDimension < 2) {
d3_geo_centroidDimension = 2;
d3_geo_centroidW = d3_geo_centroidX = d3_geo_centroidY = d3_geo_centroidZ = 0;
}
d3_geo_centroid.lineStart = d3_geo_centroidRingStart;
},
polygonEnd: function() {
d3_geo_centroid.lineStart = d3_geo_centroidLineStart;
}
};
function d3_geo_centroidPoint(λ, φ) {
if (d3_geo_centroidDimension) return;
++d3_geo_centroidW;
λ *= d3_radians;
var cosφ = Math.cos(φ *= d3_radians);
d3_geo_centroidX += (cosφ * Math.cos(λ) - d3_geo_centroidX) / d3_geo_centroidW;
d3_geo_centroidY += (cosφ * Math.sin(λ) - d3_geo_centroidY) / d3_geo_centroidW;
d3_geo_centroidZ += (Math.sin(φ) - d3_geo_centroidZ) / d3_geo_centroidW;
}
function d3_geo_centroidRingStart() {
var λ00, φ00;
d3_geo_centroidDimension = 1;
d3_geo_centroidLineStart();
d3_geo_centroidDimension = 2;
var linePoint = d3_geo_centroid.point;
d3_geo_centroid.point = function(λ, φ) {
linePoint(λ00 = λ, φ00 = φ);
};
d3_geo_centroid.lineEnd = function() {
d3_geo_centroid.point(λ00, φ00);
d3_geo_centroidLineEnd();
d3_geo_centroid.lineEnd = d3_geo_centroidLineEnd;
};
}
function d3_geo_centroidLineStart() {
var x0, y0, z0;
if (d3_geo_centroidDimension > 1) return;
if (d3_geo_centroidDimension < 1) {
d3_geo_centroidDimension = 1;
d3_geo_centroidW = d3_geo_centroidX = d3_geo_centroidY = d3_geo_centroidZ = 0;
}
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;
};
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_centroidW += w;
d3_geo_centroidX += w * (x0 + (x0 = x));
d3_geo_centroidY += w * (y0 + (y0 = y));
d3_geo_centroidZ += w * (z0 + (z0 = z));
}
}
function d3_geo_centroidLineEnd() {
d3_geo_centroid.point = d3_geo_centroidPoint;
}
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(radians, precision) {
var cr = Math.cos(radians), sr = Math.sin(radians);
return function(from, to, direction, listener) {
if (from != null) {
from = d3_geo_circleAngle(cr, from);
to = d3_geo_circleAngle(cr, to);
if (direction > 0 ? from < to : from > to) from += direction * 2 * π;
} else {
from = radians + direction * 2 * π;
to = radians;
}
var point;
for (var step = direction * precision, 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 = Math.acos(Math.max(-1, Math.min(1, -a[1])));
return ((-a[2] < 0 ? -angle : angle) + 2 * Math.PI - ε) % (2 * Math.PI);
}
function d3_geo_clip(pointVisible, clipLine, interpolate) {
return function(listener) {
var line = clipLine(listener);
var clip = {
point: point,
lineStart: lineStart,
lineEnd: lineEnd,
polygonStart: function() {
clip.point = pointRing;
clip.lineStart = ringStart;
clip.lineEnd = ringEnd;
invisible = false;
invisibleArea = visibleArea = 0;
segments = [];
listener.polygonStart();
},
polygonEnd: function() {
clip.point = point;
clip.lineStart = lineStart;
clip.lineEnd = lineEnd;
segments = d3.merge(segments);
if (segments.length) {
d3_geo_clipPolygon(segments, interpolate, listener);
} else if (visibleArea < -ε || invisible && invisibleArea < -ε) {
listener.lineStart();
interpolate(null, null, 1, listener);
listener.lineEnd();
}
listener.polygonEnd();
segments = null;
},
sphere: function() {
listener.polygonStart();
listener.lineStart();
interpolate(null, null, 1, listener);
listener.lineEnd();
listener.polygonEnd();
}
};
function point(λ, φ) {
if (pointVisible(λ, φ)) listener.point(λ, φ);
}
function pointLine(λ, φ) {
line.point(λ, φ);
}
function lineStart() {
clip.point = pointLine;
line.lineStart();
}
function lineEnd() {
clip.point = point;
line.lineEnd();
}
var segments, visibleArea, invisibleArea, invisible;
var buffer = d3_geo_clipBufferListener(), ringListener = clipLine(buffer), ring;
function pointRing(λ, φ) {
ringListener.point(λ, φ);
ring.push([ λ, φ ]);
}
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;
if (!n) {
invisible = true;
invisibleArea += d3_geo_clipAreaRing(ring, -1);
ring = null;
return;
}
ring = null;
if (clean & 1) {
segment = ringSegments[0];
visibleArea += d3_geo_clipAreaRing(segment, 1);
var n = segment.length - 1, i = -1, point;
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_clipPolygon(segments, interpolate, listener) {
var subject = [], clip = [];
segments.forEach(function(segment) {
var n = segment.length;
if (n <= 1) return;
var p0 = segment[0], p1 = segment[n - 1], a = {
point: p0,
points: segment,
other: null,
visited: false,
entry: true,
subject: true
}, b = {
point: p0,
points: [ p0 ],
other: a,
visited: false,
entry: false,
subject: false
};
a.other = b;
subject.push(a);
clip.push(b);
a = {
point: p1,
points: [ p1 ],
other: null,
visited: false,
entry: false,
subject: true
};
b = {
point: p1,
points: [ p1 ],
other: a,
visited: false,
entry: true,
subject: false
};
a.other = b;
subject.push(a);
clip.push(b);
});
clip.sort(d3_geo_clipSort);
d3_geo_clipLinkCircular(subject);
d3_geo_clipLinkCircular(clip);
if (!subject.length) return;
var start = subject[0], current, points, point;
while (1) {
current = start;
while (current.visited) if ((current = current.next) === start) return;
points = current.points;
listener.lineStart();
do {
current.visited = current.other.visited = true;
if (current.entry) {
if (current.subject) {
for (var i = 0; i < points.length; i++) listener.point((point = points[i])[0], point[1]);
} else {
interpolate(current.point, current.next.point, 1, listener);
}
current = current.next;
} else {
if (current.subject) {
points = current.prev.points;
for (var i = points.length; --i >= 0; ) listener.point((point = points[i])[0], point[1]);
} else {
interpolate(current.point, current.prev.point, -1, listener);
}
current = current.prev;
}
current = current.other;
points = current.points;
} while (!current.visited);
listener.lineEnd();
}
}
function d3_geo_clipLinkCircular(array) {
if (!(n = array.length)) return;
var n, i = 0, a = array[0], b;
while (++i < n) {
a.next = b = array[i];
b.prev = a;
a = b;
}
a.next = b = array[0];
b.prev = a;
}
function d3_geo_clipSort(a, b) {
return ((a = a.point)[0] < 0 ? a[1] - π / 2 - ε : π / 2 - a[1]) - ((b = b.point)[0] < 0 ? b[1] - π / 2 - ε : π / 2 - b[1]);
}
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;
}
};
}
function d3_geo_clipAreaRing(ring, invisible) {
if (!(n = ring.length)) return 0;
var n, i = 0, area = 0, p = ring[0], λ = p[0], φ = p[1], cosφ = Math.cos(φ), x0 = Math.atan2(invisible * Math.sin(λ) * cosφ, Math.sin(φ)), y0 = 1 - invisible * Math.cos(λ) * cosφ, x1 = x0, x, y;
while (++i < n) {
p = ring[i];
cosφ = Math.cos(φ = p[1]);
x = Math.atan2(invisible * Math.sin(λ = p[0]) * cosφ, Math.sin(φ));
y = 1 - invisible * Math.cos(λ) * cosφ;
if (Math.abs(y0 - 2) < ε && Math.abs(y - 2) < ε) continue;
if (Math.abs(y) < ε || Math.abs(y0) < ε) {} else if (Math.abs(Math.abs(x - x0) - π) < ε) {
if (y + y0 > 2) area += 4 * (x - x0);
} else if (Math.abs(y0 - 2) < ε) area += 4 * (x - x1); else area += ((3 * π + x - x0) % (2 * π) - π) * (y0 + y);
x1 = x0, x0 = x, y0 = y;
}
return area;
}
var d3_geo_clipAntimeridian = d3_geo_clip(d3_true, d3_geo_clipAntimeridianLine, d3_geo_clipAntimeridianInterpolate);
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 ? π : -π, = Math.abs(λ1 - λ0);
if (Math.abs( - π) < ε) {
listener.point(λ0, φ0 = (φ0 + φ1) / 2 > 0 ? π / 2 : -π / 2);
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 && >= π) {
if (Math.abs(λ0 - sλ0) < ε) λ0 -= sλ0 * ε;
if (Math.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 Math.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 * π / 2;
listener.point(-π, φ);
listener.point(0, φ);
listener.point(π, φ);
listener.point(π, 0);
listener.point(π, -φ);
listener.point(0, -φ);
listener.point(-π, -φ);
listener.point(-π, 0);
listener.point(-π, φ);
} else if (Math.abs(from[0] - to[0]) > ε) {
var s = (from[0] < to[0] ? 1 : -1) * π;
φ = direction * s / 2;
listener.point(-s, φ);
listener.point(0, φ);
listener.point(s, φ);
} else {
listener.point(to[0], to[1]);
}
}
function d3_geo_clipCircle(degrees) {
var radians = degrees * d3_radians, cr = Math.cos(radians), interpolate = d3_geo_circleInterpolate(radians, 6 * d3_radians);
return d3_geo_clip(visible, clipLine, interpolate);
function visible(λ, φ) {
return Math.cos(λ) * Math.cos(φ) > cr;
}
function clipLine(listener) {
var point0, v0, v00, clean;
return {
lineStart: function() {
v00 = v0 = false;
clean = 1;
},
point: function(λ, φ) {
var point1 = [ λ, φ ], point2, v = visible(λ, φ);
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 (v0 = 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;
}
if (v && (!point0 || !d3_geo_sphericalEqual(point0, point1))) listener.point(point1[0], point1[1]);
point0 = point1;
},
lineEnd: function() {
if (v0) listener.lineEnd();
point0 = null;
},
clean: function() {
return clean | (v00 && v0) << 1;
}
};
}
function intersect(a, b) {
var pa = d3_geo_cartesian(a, 0), pb = d3_geo_cartesian(b, 0);
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 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), t = Math.sqrt(w * w - uu * (d3_geo_cartesianDot(A, A) - 1)), q = d3_geo_cartesianScale(u, (-w - t) / uu);
d3_geo_cartesianAdd(q, A);
return d3_geo_spherical(q);
}
}
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_geo_equirectangular(λ, φ) {
return [ λ, φ ];
}
(d3.geo.equirectangular = function() {
return d3_geo_projection(d3_geo_equirectangular).scale(250 / π);
}).raw = d3_geo_equirectangular.invert = d3_geo_equirectangular;
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;
d3.geo.graticule = function() {
var x1, x0, y1, y0, dx = 22.5, dy = dx, 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));
}
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 [ [ 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 [ dx, dy ];
dx = +_[0], dy = +_[1];
return graticule;
};
graticule.precision = function(_) {
if (!arguments.length) return precision;
precision = +_;
x = d3_geo_graticuleX(y0, y1, precision);
y = d3_geo_graticuleY(x0, x1, precision);
return graticule;
};
return graticule.extent([ [ -180 + ε, -90 + ε ], [ 180 - ε, 90 - ε ] ]);
};
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 ];
});
};
}
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 = Math.acos(Math.max(-1, Math.min(1, sy0 * sy1 + cy0 * cy1 * Math.cos(x1 - x0)))), k = 1 / Math.sin(d);
function interpolate(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_radians, Math.atan2(z, Math.sqrt(x * x + y * y)) / d3_radians ];
}
interpolate.distance = d;
return interpolate;
}
d3.geo.greatArc = function() {
var source = d3_source, source_, target = d3_target, target_, precision = 6 * d3_radians, interpolate;
function greatArc() {
var p0 = source_ || source.apply(this, arguments), p1 = target_ || target.apply(this, arguments), i = interpolate || d3.geo.interpolate(p0, p1), t = 0, dt = precision / i.distance, coordinates = [ p0 ];
while ((t += dt) < 1) coordinates.push(i(t));
coordinates.push(p1);
return {
type: "LineString",
coordinates: coordinates
};
}
greatArc.distance = function() {
return (interpolate || d3.geo.interpolate(source_ || source.apply(this, arguments), target_ || target.apply(this, arguments))).distance;
};
greatArc.source = function(_) {
if (!arguments.length) return source;
source = _, source_ = typeof _ === "function" ? null : _;
interpolate = source_ && target_ ? d3.geo.interpolate(source_, target_) : null;
return greatArc;
};
greatArc.target = function(_) {
if (!arguments.length) return target;
target = _, target_ = typeof _ === "function" ? null : _;
interpolate = source_ && target_ ? d3.geo.interpolate(source_, target_) : null;
return greatArc;
};
greatArc.precision = function(_) {
if (!arguments.length) return precision / d3_radians;
precision = _ * d3_radians;
return greatArc;
};
return greatArc;
};
function d3_geo_mercator(λ, φ) {
return [ λ / (2 * π), Math.max(-.5, Math.min(+.5, Math.log(Math.tan(π / 4 + φ / 2)) / (2 * π))) ];
}
d3_geo_mercator.invert = function(x, y) {
return [ 2 * π * x, 2 * Math.atan(Math.exp(2 * π * y)) - π / 2 ];
};
(d3.geo.mercator = function() {
return d3_geo_projection(d3_geo_mercator).scale(500);
}).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;
d3.geo.path = function() {
var pointRadius = 4.5, projection, context, projectStream, contextStream;
function path(object) {
if (object) d3.geo.stream(object, projectStream(contextStream.pointRadius(typeof pointRadius === "function" ? +pointRadius.apply(this, arguments) : pointRadius)));
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_centroidDimension = d3_geo_centroidX = d3_geo_centroidY = d3_geo_centroidZ = 0;
d3.geo.stream(object, projectStream(d3_geo_pathCentroid));
return d3_geo_centroidZ ? [ d3_geo_centroidX / d3_geo_centroidZ, d3_geo_centroidY / d3_geo_centroidZ ] : undefined;
};
path.bounds = function(object) {
return d3_geo_bounds(projectStream)(object);
};
path.projection = function(_) {
if (!arguments.length) return projection;
projectStream = (projection = _) ? _.stream || d3_geo_pathProjectStream(_) : d3_identity;
return path;
};
path.context = function(_) {
if (!arguments.length) return context;
contextStream = (context = _) == null ? new d3_geo_pathBuffer() : new d3_geo_pathContext(_);
return path;
};
path.pointRadius = function(_) {
if (!arguments.length) return pointRadius;
pointRadius = typeof _ === "function" ? _ : +_;
return path;
};
return path.projection(d3.geo.albersUsa()).context(null);
};
function d3_geo_pathCircle(radius) {
return "m0," + radius + "a" + radius + "," + radius + " 0 1,1 0," + -2 * radius + "a" + radius + "," + radius + " 0 1,1 0," + +2 * radius + "z";
}
function d3_geo_pathProjectStream(project) {
var resample = d3_geo_resample(function(λ, φ) {
return project([ λ * d3_degrees, φ * d3_degrees ]);
});
return function(stream) {
stream = resample(stream);
return {
point: function(λ, φ) {
stream.point(λ * d3_radians, φ * d3_radians);
},
sphere: function() {
stream.sphere();
},
lineStart: function() {
stream.lineStart();
},
lineEnd: function() {
stream.lineEnd();
},
polygonStart: function() {
stream.polygonStart();
},
polygonEnd: function() {
stream.polygonEnd();
}
};
};
}
function d3_geo_pathBuffer() {
var pointCircle = d3_geo_pathCircle(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_pathCircle(_);
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_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, y);
context.arc(x, y, pointRadius, 0, 2 * π);
}
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;
}
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 += Math.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_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) {
if (d3_geo_centroidDimension) return;
d3_geo_centroidX += x;
d3_geo_centroidY += y;
++d3_geo_centroidZ;
}
function d3_geo_pathCentroidLineStart() {
var x0, y0;
if (d3_geo_centroidDimension !== 1) {
if (d3_geo_centroidDimension < 1) {
d3_geo_centroidDimension = 1;
d3_geo_centroidX = d3_geo_centroidY = d3_geo_centroidZ = 0;
} else return;
}
d3_geo_pathCentroid.point = function(x, y) {
d3_geo_pathCentroid.point = nextPoint;
x0 = x, y0 = y;
};
function nextPoint(x, y) {
var dx = x - x0, dy = y - y0, z = Math.sqrt(dx * dx + dy * dy);
d3_geo_centroidX += z * (x0 + x) / 2;
d3_geo_centroidY += z * (y0 + y) / 2;
d3_geo_centroidZ += z;
x0 = x, y0 = y;
}
}
function d3_geo_pathCentroidLineEnd() {
d3_geo_pathCentroid.point = d3_geo_pathCentroidPoint;
}
function d3_geo_pathCentroidRingStart() {
var x00, y00, x0, y0;
if (d3_geo_centroidDimension < 2) {
d3_geo_centroidDimension = 2;
d3_geo_centroidX = d3_geo_centroidY = d3_geo_centroidZ = 0;
}
d3_geo_pathCentroid.point = function(x, y) {
d3_geo_pathCentroid.point = nextPoint;
x00 = x0 = x, y00 = y0 = y;
};
function nextPoint(x, y) {
var z = y0 * x - x0 * y;
d3_geo_centroidX += z * (x0 + x);
d3_geo_centroidY += z * (y0 + y);
d3_geo_centroidZ += z * 3;
x0 = x, y0 = y;
}
d3_geo_pathCentroid.lineEnd = function() {
nextPoint(x00, y00);
};
}
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_areaRingU, d3_geo_areaRingV;
var d3_geo_area = {
sphere: function() {
d3_geo_areaSum += 4 * π;
},
point: d3_noop,
lineStart: d3_noop,
lineEnd: d3_noop,
polygonStart: function() {
d3_geo_areaRingU = 1, d3_geo_areaRingV = 0;
d3_geo_area.lineStart = d3_geo_areaRingStart;
},
polygonEnd: function() {
var area = 2 * Math.atan2(d3_geo_areaRingV, d3_geo_areaRingU);
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 = λ - λ0, cosφ = Math.cos(φ), sinφ = Math.sin(φ), k = sinφ0 * sinφ, u0 = d3_geo_areaRingU, v0 = d3_geo_areaRingV, u = cosφ0 * cosφ + k * Math.cos(), v = k * Math.sin();
d3_geo_areaRingU = u0 * u - v0 * v;
d3_geo_areaRingV = v0 * u + u0 * v;
λ0 = λ, cosφ0 = cosφ, sinφ0 = sinφ;
}
d3_geo_area.lineEnd = function() {
nextPoint(λ00, φ00);
};
}
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, clip = d3_geo_clipAntimeridian, clipAngle = null;
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(stream) {
return d3_geo_projectionRadiansRotate(rotate, clip(projectResample(stream)));
};
projection.clipAngle = function(_) {
if (!arguments.length) return clipAngle;
clip = _ == null ? (clipAngle = _, d3_geo_clipAntimeridian) : d3_geo_clipCircle(clipAngle = +_);
return projection;
};
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 projection;
}
return function() {
project = projectAt.apply(this, arguments);
projection.invert = project.invert && invert;
return reset();
};
}
function d3_geo_projectionRadiansRotate(rotate, stream) {
return {
point: function(x, y) {
y = rotate(x * d3_radians, y * d3_radians), x = y[0];
stream.point(x > π ? x - 2 * π : x < -π ? x + 2 * π : x, y[1]);
},
sphere: function() {
stream.sphere();
},
lineStart: function() {
stream.lineStart();
},
lineEnd: function() {
stream.lineEnd();
},
polygonStart: function() {
stream.polygonStart();
},
polygonEnd: function() {
stream.polygonEnd();
}
};
}
function d3_geo_rotation(δλ, δφ, δγ) {
return δλ ? δφ || δγ ? d3_geo_compose(d3_geo_rotationλ(δλ), d3_geo_rotationφγ(δφ, δγ)) : d3_geo_rotationλ(δλ) : δφ || δγ ? d3_geo_rotationφγ(δφ, δγ) : d3_geo_equirectangular;
}
function d3_geo_forwardRotationλ(δλ) {
return function(λ, φ) {
return λ += δλ, [ λ > π ? λ - 2 * π : λ < -π ? λ + 2 * π : λ, φ ];
};
}
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δφ), Math.asin(Math.max(-1, Math.min(1, 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δφ), Math.asin(Math.max(-1, Math.min(1, k * cosδφ - x * sinδφ))) ];
};
return rotation;
}
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_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;
}
d3.geom = {};
d3.geom.hull = function(vertices) {
if (vertices.length < 3) return [];
var len = vertices.length, plen = len - 1, points = [], stack = [], i, j, h = 0, x1, y1, x2, y2, u, v, a, sp;
for (i = 1; i < len; ++i) {
if (vertices[i][1] < vertices[h][1]) {
h = i;
} else if (vertices[i][1] == vertices[h][1]) {
h = vertices[i][0] < vertices[h][0] ? i : h;
}
}
for (i = 0; i < len; ++i) {
if (i === h) continue;
y1 = vertices[i][1] - vertices[h][1];
x1 = vertices[i][0] - vertices[h][0];
points.push({
angle: Math.atan2(y1, x1),
index: i
});
}
points.sort(function(a, b) {
return a.angle - b.angle;
});
a = points[0].angle;
v = points[0].index;
u = 0;
for (i = 1; i < plen; ++i) {
j = points[i].index;
if (a == points[i].angle) {
x1 = vertices[v][0] - vertices[h][0];
y1 = vertices[v][1] - vertices[h][1];
x2 = vertices[j][0] - vertices[h][0];
y2 = vertices[j][1] - vertices[h][1];
if (x1 * x1 + y1 * y1 >= x2 * x2 + y2 * y2) {
points[i].index = -1;
} else {
points[u].index = -1;
a = points[i].angle;
u = i;
v = j;
}
} else {
a = points[i].angle;
u = i;
v = j;
}
}
stack.push(h);
for (i = 0, j = 0; i < 2; ++j) {
if (points[j].index !== -1) {
stack.push(points[j].index);
i++;
}
}
sp = stack.length;
for (;j < plen; ++j) {
if (points[j].index === -1) continue;
while (!d3_geom_hullCCW(stack[sp - 2], stack[sp - 1], points[j].index, vertices)) {
--sp;
}
stack[sp++] = points[j].index;
}
var poly = [];
for (i = 0; i < sp; ++i) {
poly.push(vertices[stack[i]]);
}
return poly;
};
function d3_geom_hullCCW(i1, i2, i3, v) {
var t, a, b, c, d, e, f;
t = v[i1];
a = t[0];
b = t[1];
t = v[i2];
c = t[0];
d = t[1];
t = v[i3];
e = t[0];
f = t[1];
return (f - b) * (c - a) - (d - b) * (e - a) > 0;
}
d3.geom.polygon = function(coordinates) {
coordinates.area = function() {
var i = 0, n = coordinates.length, area = coordinates[n - 1][1] * coordinates[0][0] - coordinates[n - 1][0] * coordinates[0][1];
while (++i < n) {
area += coordinates[i - 1][1] * coordinates[i][0] - coordinates[i - 1][0] * coordinates[i][1];
}
return area * .5;
};
coordinates.centroid = function(k) {
var i = -1, n = coordinates.length, x = 0, y = 0, a, b = coordinates[n - 1], c;
if (!arguments.length) k = -1 / (6 * coordinates.area());
while (++i < n) {
a = b;
b = coordinates[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 ];
};
coordinates.clip = function(subject) {
var input, i = -1, n = coordinates.length, j, m, a = coordinates[n - 1], b, c, d;
while (++i < n) {
input = subject.slice();
subject.length = 0;
b = coordinates[i];
c = input[(m = input.length) - 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;
}
a = b;
}
return subject;
};
return coordinates;
};
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 ];
}
d3.geom.voronoi = function(vertices) {
var polygons = vertices.map(function() {
return [];
}), Z = 1e6;
d3_voronoi_tessellate(vertices, function(e) {
var s1, s2, x1, x2, y1, y2;
if (e.a === 1 && e.b >= 0) {
s1 = e.ep.r;
s2 = e.ep.l;
} else {
s1 = e.ep.l;
s2 = e.ep.r;
}
if (e.a === 1) {
y1 = s1 ? s1.y : -Z;
x1 = e.c - e.b * y1;
y2 = s2 ? s2.y : Z;
x2 = e.c - e.b * y2;
} else {
x1 = s1 ? s1.x : -Z;
y1 = e.c - e.a * x1;
x2 = s2 ? s2.x : Z;
y2 = e.c - e.a * x2;
}
var v1 = [ x1, y1 ], v2 = [ x2, y2 ];
polygons[e.region.l.index].push(v1, v2);
polygons[e.region.r.index].push(v1, v2);
});
polygons = polygons.map(function(polygon, i) {
var cx = vertices[i][0], cy = vertices[i][1], angle = polygon.map(function(v) {
return Math.atan2(v[0] - cx, v[1] - cy);
}), order = d3.range(polygon.length).sort(function(a, b) {
return angle[a] - angle[b];
});
return order.filter(function(d, i) {
return !i || angle[d] - angle[order[i - 1]] > ε;
}).map(function(d) {
return polygon[d];
});
});
polygons.forEach(function(polygon, i) {
var n = polygon.length;
if (!n) return polygon.push([ -Z, -Z ], [ -Z, Z ], [ Z, Z ], [ Z, -Z ]);
if (n > 2) return;
var p0 = vertices[i], p1 = polygon[0], p2 = polygon[1], x0 = p0[0], y0 = p0[1], x1 = p1[0], y1 = p1[1], x2 = p2[0], y2 = p2[1], dx = Math.abs(x2 - x1), dy = y2 - y1;
if (Math.abs(dy) < ε) {
var y = y0 < y1 ? -Z : Z;
polygon.push([ -Z, y ], [ Z, y ]);
} else if (dx < ε) {
var x = x0 < x1 ? -Z : Z;
polygon.push([ x, -Z ], [ x, Z ]);
} else {
var y = (x2 - x1) * (y1 - y0) < (x1 - x0) * (y2 - y1) ? Z : -Z, z = Math.abs(dy) - dx;
if (Math.abs(z) < ε) {
polygon.push([ dy < 0 ? y : -y, y ]);
} else {
if (z > 0) y *= -1;
polygon.push([ -Z, y ], [ Z, y ]);
}
}
});
return polygons;
};
var d3_voronoi_opposite = {
l: "r",
r: "l"
};
function d3_voronoi_tessellate(vertices, callback) {
var Sites = {
list: vertices.map(function(v, i) {
return {
index: i,
x: v[0],
y: v[1]
};
}).sort(function(a, b) {
return a.y < b.y ? -1 : a.y > b.y ? 1 : a.x < b.x ? -1 : a.x > b.x ? 1 : 0;
}),
bottomSite: null
};
var EdgeList = {
list: [],
leftEnd: null,
rightEnd: null,
init: function() {
EdgeList.leftEnd = EdgeList.createHalfEdge(null, "l");
EdgeList.rightEnd = EdgeList.createHalfEdge(null, "l");
EdgeList.leftEnd.r = EdgeList.rightEnd;
EdgeList.rightEnd.l = EdgeList.leftEnd;
EdgeList.list.unshift(EdgeList.leftEnd, EdgeList.rightEnd);
},
createHalfEdge: function(edge, side) {
return {
edge: edge,
side: side,
vertex: null,
l: null,
r: null
};
},
insert: function(lb, he) {
he.l = lb;
he.r = lb.r;
lb.r.l = he;
lb.r = he;
},
leftBound: function(p) {
var he = EdgeList.leftEnd;
do {
he = he.r;
} while (he != EdgeList.rightEnd && Geom.rightOf(he, p));
he = he.l;
return he;
},
del: function(he) {
he.l.r = he.r;
he.r.l = he.l;
he.edge = null;
},
right: function(he) {
return he.r;
},
left: function(he) {
return he.l;
},
leftRegion: function(he) {
return he.edge == null ? Sites.bottomSite : he.edge.region[he.side];
},
rightRegion: function(he) {
return he.edge == null ? Sites.bottomSite : he.edge.region[d3_voronoi_opposite[he.side]];
}
};
var Geom = {
bisect: function(s1, s2) {
var newEdge = {
region: {
l: s1,
r: s2
},
ep: {
l: null,
r: null
}
};
var dx = s2.x - s1.x, dy = s2.y - s1.y, adx = dx > 0 ? dx : -dx, ady = dy > 0 ? dy : -dy;
newEdge.c = s1.x * dx + s1.y * dy + (dx * dx + dy * dy) * .5;
if (adx > ady) {
newEdge.a = 1;
newEdge.b = dy / dx;
newEdge.c /= dx;
} else {
newEdge.b = 1;
newEdge.a = dx / dy;
newEdge.c /= dy;
}
return newEdge;
},
intersect: function(el1, el2) {
var e1 = el1.edge, e2 = el2.edge;
if (!e1 || !e2 || e1.region.r == e2.region.r) {
return null;
}
var d = e1.a * e2.b - e1.b * e2.a;
if (Math.abs(d) < 1e-10) {
return null;
}
var xint = (e1.c * e2.b - e2.c * e1.b) / d, yint = (e2.c * e1.a - e1.c * e2.a) / d, e1r = e1.region.r, e2r = e2.region.r, el, e;
if (e1r.y < e2r.y || e1r.y == e2r.y && e1r.x < e2r.x) {
el = el1;
e = e1;
} else {
el = el2;
e = e2;
}
var rightOfSite = xint >= e.region.r.x;
if (rightOfSite && el.side === "l" || !rightOfSite && el.side === "r") {
return null;
}
return {
x: xint,
y: yint
};
},
rightOf: function(he, p) {
var e = he.edge, topsite = e.region.r, rightOfSite = p.x > topsite.x;
if (rightOfSite && he.side === "l") {
return 1;
}
if (!rightOfSite && he.side === "r") {
return 0;
}
if (e.a === 1) {
var dyp = p.y - topsite.y, dxp = p.x - topsite.x, fast = 0, above = 0;
if (!rightOfSite && e.b < 0 || rightOfSite && e.b >= 0) {
above = fast = dyp >= e.b * dxp;
} else {
above = p.x + p.y * e.b > e.c;
if (e.b < 0) {
above = !above;
}
if (!above) {
fast = 1;
}
}
if (!fast) {
var dxs = topsite.x - e.region.l.x;
above = e.b * (dxp * dxp - dyp * dyp) < dxs * dyp * (1 + 2 * dxp / dxs + e.b * e.b);
if (e.b < 0) {
above = !above;
}
}
} else {
var yl = e.c - e.a * p.x, t1 = p.y - yl, t2 = p.x - topsite.x, t3 = yl - topsite.y;
above = t1 * t1 > t2 * t2 + t3 * t3;
}
return he.side === "l" ? above : !above;
},
endPoint: function(edge, side, site) {
edge.ep[side] = site;
if (!edge.ep[d3_voronoi_opposite[side]]) return;
callback(edge);
},
distance: function(s, t) {
var dx = s.x - t.x, dy = s.y - t.y;
return Math.sqrt(dx * dx + dy * dy);
}
};
var EventQueue = {
list: [],
insert: function(he, site, offset) {
he.vertex = site;
he.ystar = site.y + offset;
for (var i = 0, list = EventQueue.list, l = list.length; i < l; i++) {
var next = list[i];
if (he.ystar > next.ystar || he.ystar == next.ystar && site.x > next.vertex.x) {
continue;
} else {
break;
}
}
list.splice(i, 0, he);
},
del: function(he) {
for (var i = 0, ls = EventQueue.list, l = ls.length; i < l && ls[i] != he; ++i) {}
ls.splice(i, 1);
},
empty: function() {
return EventQueue.list.length === 0;
},
nextEvent: function(he) {
for (var i = 0, ls = EventQueue.list, l = ls.length; i < l; ++i) {
if (ls[i] == he) return ls[i + 1];
}
return null;
},
min: function() {
var elem = EventQueue.list[0];
return {
x: elem.vertex.x,
y: elem.ystar
};
},
extractMin: function() {
return EventQueue.list.shift();
}
};
EdgeList.init();
Sites.bottomSite = Sites.list.shift();
var newSite = Sites.list.shift(), newIntStar;
var lbnd, rbnd, llbnd, rrbnd, bisector;
var bot, top, temp, p, v;
var e, pm;
while (true) {
if (!EventQueue.empty()) {
newIntStar = EventQueue.min();
}
if (newSite && (EventQueue.empty() || newSite.y < newIntStar.y || newSite.y == newIntStar.y && newSite.x < newIntStar.x)) {
lbnd = EdgeList.leftBound(newSite);
rbnd = EdgeList.right(lbnd);
bot = EdgeList.rightRegion(lbnd);
e = Geom.bisect(bot, newSite);
bisector = EdgeList.createHalfEdge(e, "l");
EdgeList.insert(lbnd, bisector);
p = Geom.intersect(lbnd, bisector);
if (p) {
EventQueue.del(lbnd);
EventQueue.insert(lbnd, p, Geom.distance(p, newSite));
}
lbnd = bisector;
bisector = EdgeList.createHalfEdge(e, "r");
EdgeList.insert(lbnd, bisector);
p = Geom.intersect(bisector, rbnd);
if (p) {
EventQueue.insert(bisector, p, Geom.distance(p, newSite));
}
newSite = Sites.list.shift();
} else if (!EventQueue.empty()) {
lbnd = EventQueue.extractMin();
llbnd = EdgeList.left(lbnd);
rbnd = EdgeList.right(lbnd);
rrbnd = EdgeList.right(rbnd);
bot = EdgeList.leftRegion(lbnd);
top = EdgeList.rightRegion(rbnd);
v = lbnd.vertex;
Geom.endPoint(lbnd.edge, lbnd.side, v);
Geom.endPoint(rbnd.edge, rbnd.side, v);
EdgeList.del(lbnd);
EventQueue.del(rbnd);
EdgeList.del(rbnd);
pm = "l";
if (bot.y > top.y) {
temp = bot;
bot = top;
top = temp;
pm = "r";
}
e = Geom.bisect(bot, top);
bisector = EdgeList.createHalfEdge(e, pm);
EdgeList.insert(llbnd, bisector);
Geom.endPoint(e, d3_voronoi_opposite[pm], v);
p = Geom.intersect(llbnd, bisector);
if (p) {
EventQueue.del(llbnd);
EventQueue.insert(llbnd, p, Geom.distance(p, bot));
}
p = Geom.intersect(bisector, rrbnd);
if (p) {
EventQueue.insert(bisector, p, Geom.distance(p, bot));
}
} else {
break;
}
}
for (lbnd = EdgeList.right(EdgeList.leftEnd); lbnd != EdgeList.rightEnd; lbnd = EdgeList.right(lbnd)) {
callback(lbnd.edge);
}
}
d3.geom.delaunay = function(vertices) {
var edges = vertices.map(function() {
return [];
}), triangles = [];
d3_voronoi_tessellate(vertices, function(e) {
edges[e.region.l.index].push(vertices[e.region.r.index]);
});
edges.forEach(function(edge, i) {
var v = vertices[i], cx = v[0], cy = v[1];
edge.forEach(function(v) {
v.angle = Math.atan2(v[0] - cx, v[1] - cy);
});
edge.sort(function(a, b) {
return a.angle - b.angle;
});
for (var j = 0, m = edge.length - 1; j < m; j++) {
triangles.push([ v, edge[j], edge[j + 1] ]);
}
});
return triangles;
};
d3.geom.quadtree = function(points, x1, y1, x2, y2) {
var p, i = -1, n = points.length;
if (arguments.length < 5) {
if (arguments.length === 3) {
y2 = y1;
x2 = x1;
y1 = x1 = 0;
} else {
x1 = y1 = Infinity;
x2 = y2 = -Infinity;
while (++i < n) {
p = points[i];
if (p.x < x1) x1 = p.x;
if (p.y < y1) y1 = p.y;
if (p.x > x2) x2 = p.x;
if (p.y > y2) y2 = p.y;
}
}
}
var dx = x2 - x1, dy = y2 - y1;
if (dx > dy) y2 = y1 + dx; else x2 = x1 + dy;
function insert(n, p, x1, y1, x2, y2) {
if (isNaN(p.x) || isNaN(p.y)) return;
if (n.leaf) {
var v = n.point;
if (v) {
if (Math.abs(v.x - p.x) + Math.abs(v.y - p.y) < .01) {
insertChild(n, p, x1, y1, x2, y2);
} else {
n.point = null;
insertChild(n, v, x1, y1, x2, y2);
insertChild(n, p, x1, y1, x2, y2);
}
} else {
n.point = p;
}
} else {
insertChild(n, p, x1, y1, x2, y2);
}
}
function insertChild(n, p, x1, y1, x2, y2) {
var sx = (x1 + x2) * .5, sy = (y1 + y2) * .5, right = p.x >= sx, bottom = p.y >= sy, i = (bottom << 1) + right;
n.leaf = false;
n = n.nodes[i] || (n.nodes[i] = d3_geom_quadtreeNode());
if (right) x1 = sx; else x2 = sx;
if (bottom) y1 = sy; else y2 = sy;
insert(n, p, x1, y1, x2, y2);
}
var root = d3_geom_quadtreeNode();
root.add = function(p) {
insert(root, p, x1, y1, x2, y2);
};
root.visit = function(f) {
d3_geom_quadtreeVisit(f, root, x1, y1, x2, y2);
};
points.forEach(root.add);
return root;
};
function d3_geom_quadtreeNode() {
return {
leaf: true,
nodes: [],
point: 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);
}
}
d3.time = {};
var d3_time = Date, d3_time_daySymbols = [ "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday" ];
function d3_time_utc() {
this._ = new Date(arguments.length > 1 ? Date.UTC.apply(this, arguments) : arguments[0]);
}
d3_time_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;
var d3_time_formatDateTime = "%a %b %e %X %Y", d3_time_formatDate = "%m/%d/%Y", d3_time_formatTime = "%H:%M:%S";
var d3_time_days = [ "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday" ], d3_time_dayAbbreviations = [ "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" ], d3_time_months = [ "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December" ], d3_time_monthAbbreviations = [ "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec" ];
d3.time.format = function(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.substring(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.substring(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
}, 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 date = new d3_time();
date.setFullYear(d.y, d.m, d.d);
date.setHours(d.H, d.M, d.S, d.L);
return date;
};
format.toString = function() {
return template;
};
return format;
};
function d3_time_parse(date, template, string, j) {
var c, p, i = 0, n = template.length, m = string.length;
while (i < n) {
if (j >= m) return -1;
c = template.charCodeAt(i++);
if (c === 37) {
p = d3_time_parsers[template.charAt(i++)];
if (!p || (j = p(date, string, j)) < 0) return -1;
} else if (c != string.charCodeAt(j++)) {
return -1;
}
}
return j;
}
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_formatPad(value, fill, width) {
value += "";
var length = value.length;
return length < width ? new Array(width - length + 1).join(fill) + value : value;
}
var d3_time_dayRe = d3_time_formatRe(d3_time_days), d3_time_dayAbbrevRe = d3_time_formatRe(d3_time_dayAbbreviations), d3_time_monthRe = d3_time_formatRe(d3_time_months), d3_time_monthLookup = d3_time_formatLookup(d3_time_months), d3_time_monthAbbrevRe = d3_time_formatRe(d3_time_monthAbbreviations), d3_time_monthAbbrevLookup = d3_time_formatLookup(d3_time_monthAbbreviations);
var d3_time_formatPads = {
"-": "",
_: " ",
"0": "0"
};
var d3_time_formats = {
a: function(d) {
return d3_time_dayAbbreviations[d.getDay()];
},
A: function(d) {
return d3_time_days[d.getDay()];
},
b: function(d) {
return d3_time_monthAbbreviations[d.getMonth()];
},
B: function(d) {
return d3_time_months[d.getMonth()];
},
c: d3.time.format(d3_time_formatDateTime),
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 d.getHours() >= 12 ? "PM" : "AM";
},
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(d3_time_formatDate),
X: d3.time.format(d3_time_formatTime),
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,
L: d3_time_parseMilliseconds,
m: d3_time_parseMonthNumber,
M: d3_time_parseMinutes,
p: d3_time_parseAmPm,
S: d3_time_parseSeconds,
x: d3_time_parseLocaleDate,
X: d3_time_parseLocaleTime,
y: d3_time_parseYear,
Y: d3_time_parseFullYear
};
function d3_time_parseWeekdayAbbrev(date, string, i) {
d3_time_dayAbbrevRe.lastIndex = 0;
var n = d3_time_dayAbbrevRe.exec(string.substring(i));
return n ? i += n[0].length : -1;
}
function d3_time_parseWeekday(date, string, i) {
d3_time_dayRe.lastIndex = 0;
var n = d3_time_dayRe.exec(string.substring(i));
return n ? i += n[0].length : -1;
}
function d3_time_parseMonthAbbrev(date, string, i) {
d3_time_monthAbbrevRe.lastIndex = 0;
var n = d3_time_monthAbbrevRe.exec(string.substring(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.substring(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_parseFullYear(date, string, i) {
d3_time_numberRe.lastIndex = 0;
var n = d3_time_numberRe.exec(string.substring(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.substring(i, i + 2));
return n ? (date.y = d3_time_expandYear(+n[0]), i += n[0].length) : -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.substring(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.substring(i, i + 2));
return n ? (date.d = +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.substring(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.substring(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.substring(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.substring(i, i + 3));
return n ? (date.L = +n[0], i += n[0].length) : -1;
}
var d3_time_numberRe = /^\s*\d+/;
function d3_time_parseAmPm(date, string, i) {
var n = d3_time_amPmLookup.get(string.substring(i, i += 2).toLowerCase());
return n == null ? -1 : (date.p = n, i);
}
var d3_time_amPmLookup = d3.map({
am: 0,
pm: 1
});
function d3_time_zone(d) {
var z = d.getTimezoneOffset(), zs = z > 0 ? "-" : "+", zh = ~~(Math.abs(z) / 60), zm = Math.abs(z) % 60;
return zs + d3_time_formatPad(zh, "0", 2) + d3_time_formatPad(zm, "0", 2);
}
d3.time.format.utc = function(template) {
var local = d3.time.format(template);
function format(date) {
try {
d3_time = d3_time_utc;
var utc = new d3_time();
utc._ = date;
return local(utc);
} finally {
d3_time = Date;
}
}
format.parse = function(string) {
try {
d3_time = d3_time_utc;
var date = local.parse(string);
return date && date._;
} finally {
d3_time = Date;
}
};
format.toString = local.toString;
return format;
};
var d3_time_formatIso = d3.time.format.utc("%Y-%m-%dT%H:%M:%S.%LZ");
d3.time.format.iso = Date.prototype.toISOString ? 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;
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_time(date - 1)), 1);
return date;
}
function offset(date, k) {
step(date = new d3_time(+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_time = d3_time_utc;
var utc = new d3_time_utc();
utc._ = t0;
return range(utc, t1, dt);
} finally {
d3_time = 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_time = d3_time_utc;
var utc = new d3_time_utc();
utc._ = date;
return method(utc, k)._;
} finally {
d3_time = Date;
}
};
}
d3.time.second = d3_time_interval(function(date) {
return new d3_time(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_time(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_time((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.day = d3_time_interval(function(date) {
var day = new d3_time(1970, 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);
};
d3_time_daySymbols.forEach(function(day, i) {
day = day.toLowerCase();
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;
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;
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;
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;
};
scale.nice = function(m) {
return scale.domain(d3_scale_nice(scale.domain(), function() {
return m;
}));
};
scale.ticks = function(m, k) {
var extent = d3_time_scaleExtent(scale.domain());
if (typeof m !== "function") {
var span = extent[1] - extent[0], target = span / m, i = d3.bisect(d3_time_scaleSteps, target);
if (i == d3_time_scaleSteps.length) return methods.year(extent, m);
if (!i) return linear.ticks(m).map(d3_time_scaleDate);
if (Math.log(target / d3_time_scaleSteps[i - 1]) < Math.log(d3_time_scaleSteps[i] / target)) --i;
m = methods[i];
k = m[1];
m = m[0].range;
}
return m(extent[0], new Date(+extent[1] + 1), k);
};
scale.tickFormat = function() {
return format;
};
scale.copy = function() {
return d3_time_scale(linear.copy(), methods, format);
};
return d3.rebind(scale, linear, "range", "rangeRound", "interpolate", "clamp");
}
function d3_time_scaleExtent(domain) {
var start = domain[0], stop = domain[domain.length - 1];
return start < stop ? [ start, stop ] : [ stop, start ];
}
function d3_time_scaleDate(t) {
return new Date(t);
}
function d3_time_scaleFormat(formats) {
return function(date) {
var i = formats.length - 1, f = formats[i];
while (!f[1](date)) f = formats[--i];
return f[0](date);
};
}
function d3_time_scaleSetYear(y) {
var d = new Date(y, 0, 1);
d.setFullYear(y);
return d;
}
function d3_time_scaleGetYear(d) {
var y = d.getFullYear(), d0 = d3_time_scaleSetYear(y), d1 = d3_time_scaleSetYear(y + 1);
return y + (d - d0) / (d1 - d0);
}
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_scaleLocalFormats = [ [ d3.time.format("%Y"), d3_true ], [ d3.time.format("%B"), function(d) {
return d.getMonth();
} ], [ d3.time.format("%b %d"), function(d) {
return d.getDate() != 1;
} ], [ d3.time.format("%a %d"), function(d) {
return d.getDay() && d.getDate() != 1;
} ], [ d3.time.format("%I %p"), function(d) {
return d.getHours();
} ], [ d3.time.format("%I:%M"), function(d) {
return d.getMinutes();
} ], [ d3.time.format(":%S"), function(d) {
return d.getSeconds();
} ], [ d3.time.format(".%L"), function(d) {
return d.getMilliseconds();
} ] ];
var d3_time_scaleLinear = d3.scale.linear(), d3_time_scaleLocalFormat = d3_time_scaleFormat(d3_time_scaleLocalFormats);
d3_time_scaleLocalMethods.year = function(extent, m) {
return d3_time_scaleLinear.domain(extent.map(d3_time_scaleGetYear)).ticks(m).map(d3_time_scaleSetYear);
};
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_scaleUTCFormats = [ [ d3.time.format.utc("%Y"), d3_true ], [ d3.time.format.utc("%B"), function(d) {
return d.getUTCMonth();
} ], [ d3.time.format.utc("%b %d"), function(d) {
return d.getUTCDate() != 1;
} ], [ d3.time.format.utc("%a %d"), function(d) {
return d.getUTCDay() && d.getUTCDate() != 1;
} ], [ d3.time.format.utc("%I %p"), function(d) {
return d.getUTCHours();
} ], [ d3.time.format.utc("%I:%M"), function(d) {
return d.getUTCMinutes();
} ], [ d3.time.format.utc(":%S"), function(d) {
return d.getUTCSeconds();
} ], [ d3.time.format.utc(".%L"), function(d) {
return d.getUTCMilliseconds();
} ] ];
var d3_time_scaleUTCFormat = d3_time_scaleFormat(d3_time_scaleUTCFormats);
function d3_time_scaleUTCSetYear(y) {
var d = new Date(Date.UTC(y, 0, 1));
d.setUTCFullYear(y);
return d;
}
function d3_time_scaleUTCGetYear(d) {
var y = d.getUTCFullYear(), d0 = d3_time_scaleUTCSetYear(y), d1 = d3_time_scaleUTCSetYear(y + 1);
return y + (d - d0) / (d1 - d0);
}
d3_time_scaleUTCMethods.year = function(extent, m) {
return d3_time_scaleLinear.domain(extent.map(d3_time_scaleUTCGetYear)).ticks(m).map(d3_time_scaleUTCSetYear);
};
d3.time.scale.utc = function() {
return d3_time_scale(d3.scale.linear(), d3_time_scaleUTCMethods, d3_time_scaleUTCFormat);
};
return d3;
}();
colour x y PANEL fill
#F8766D 0.547039768419602 0.629976966107272 1 #F8766D
#F8766D 0.501033841064167 0.490577043884053 1 #F8766D
#F8766D 0.570301192363361 0.469487570672171 1 #F8766D
#F8766D 0.634399338341719 0.464103024320201 1 #F8766D
#F8766D 0.436935695085809 0.418932663256454 1 #F8766D
#F8766D 0.634743952029775 0.358655658260791 1 #F8766D
#F8766D 0.641463918946861 0.419530946184451 1 #F8766D
#F8766D 0.525673719760149 0.505833258547967 1 #F8766D
#F8766D 0.705562064925219 0.416240390080469 1 #F8766D
#F8766D 0.723481976704115 0.504487121959975 1 #F8766D
#F8766D 0.447274105727479 0.473376409704149 1 #F8766D
#F8766D 0.597181060031704 0.39829190224057 1 #F8766D
#F8766D 0.474326280239851 0.764889766370517 1 #F8766D
#F8766D 0.591667241022813 0.504487121959975 1 #F8766D
#F8766D 0.686952925770212 0.533055131771815 1 #F8766D
#F8766D 0.58236267144531 0.474423404828143 1 #F8766D
#00BFC4 0.323213178027431 0.509123814651949 1 #00BFC4
#00BFC4 0.392480529326625 0.359403511920787 1 #00BFC4
#F8766D 0.412812736921911 0.31961769720901 1 #F8766D
#F8766D 0.532565993521263 0.553247180591702 1 #F8766D
#00BFC4 0.58391343304156 0.6070926441114 1 #00BFC4
#F8766D 0.551002825832242 0.485192497532083 1 #F8766D
#F8766D 0.588910331518368 0.515405785395914 1 #F8766D
#F8766D 0.533082914053346 0.510170809775943 1 #F8766D
#F8766D 0.690571369494796 0.665873941787071 1 #F8766D
#F8766D 0.669205320835344 0.555939453767687 1 #F8766D
#F8766D 0.428148046040389 0.511516946363935 1 #F8766D
#F8766D 0.616824040250879 0.48564120972808 1 #F8766D
#F8766D 0.629230133020884 0.303314487421101 1 #F8766D
#F8766D 0.682989868357571 0.534251697627808 1 #F8766D
#F8766D 0.488972361982218 0.755616380986568 1 #F8766D
#F8766D 0.653697704872838 0.50897424391995 1 #F8766D
#F8766D 0.450375628919981 0.750830117562595 1 #F8766D
#F8766D 0.409883520573437 0.706407610158844 1 #F8766D
#F8766D 0.756047970225377 0.503739268299979 1 #F8766D
#F8766D 0.558756633813495 0.485042926800084 1 #F8766D
#00BFC4 0.589599558894479 0.381390409524664 1 #00BFC4
#F8766D 0.700220552760356 0.322908253312992 1 #F8766D
#F8766D 0.728306568336894 0.401283316880553 1 #F8766D
#F8766D 0.348197670411469 0.329938077716952 1 #F8766D
#F8766D 0.454855606864705 0.489081336564061 1 #F8766D
#F8766D 0.631470121993246 0.462607317000209 1 #F8766D
#F8766D 0.538596733062237 0.659891112507105 1 #F8766D
#F8766D 0.577193466124474 0.63925035149122 1 #F8766D
#F8766D 0.475532428148046 0.713287863830806 1 #F8766D
#F8766D 0.665242263422703 0.550106195219719 1 #F8766D
#F8766D 0.586498035701978 0.536196117143797 1 #F8766D
#F8766D 0.660245364945896 0.567456400131622 1 #F8766D
#F8766D 0.481390860844993 0.710894732118819 1 #F8766D
#F8766D 0.573230408711834 0.686365132070956 1 #F8766D
#F8766D 0.612344062306155 0.573439229411589 1 #F8766D
#F8766D 0.563753532290303 0.500747853659996 1 #F8766D
#F8766D 0.540147494658488 0.516602351251907 1 #F8766D
#F8766D 0.49517540836722 0.579122917227557 1 #F8766D
#F8766D 0.657316148597422 0.495363307308026 1 #F8766D
#F8766D 0.657833069129506 0.304511053277095 1 #F8766D
#F8766D 0.707112826521469 0.345942146040863 1 #F8766D
#F8766D 0.388517471913984 0.464850877980197 1 #F8766D
#F8766D 0.392308222482597 0.431047892548386 1 #F8766D
#F8766D 0.667826866083121 0.462009034072213 1 #F8766D
#F8766D 0.283410297056999 0.287160848365192 1 #F8766D
#F8766D 0.439692604590254 0.462756887732209 1 #F8766D
#F8766D 0.547039768419602 0.637904214903228 1 #F8766D
#F8766D 0.705562064925219 0.475171258488139 1 #F8766D
#F8766D 0.601661037976428 0.44824852672829 1 #F8766D
#F8766D 0.630263974085051 0.474273834096144 1 #F8766D
#F8766D 0.727961954648839 0.543225941547758 1 #F8766D
#F8766D 0.694189813219381 0.593780848963475 1 #F8766D
#F8766D 0.262216555241574 0.53739268299979 1 #F8766D
#F8766D 0.691260596870908 0.40173202907655 1 #F8766D
#F8766D 0.284444138121166 0.468889287744174 1 #F8766D
#F8766D 0.49362464677097 0.662284244219091 1 #F8766D
#F8766D 0.292887173478531 0.358805228992791 1 #F8766D
#F8766D 0.670756082431594 0.460962038948219 1 #F8766D
#F8766D 0.679026810944931 0.531858565915821 1 #F8766D
#F8766D 0.493969260459025 0.551601902539711 1 #F8766D
#F8766D 0.653870011716865 0.502393131711987 1 #F8766D
#F8766D 0.314770142670067 0.575234078195579 1 #F8766D
#F8766D 0.281687228616721 0.608289209967394 1 #F8766D
#F8766D 0.360431456337446 0.407714858356517 1 #F8766D
#F8766D 0.65748845544145 0.421624936432439 1 #F8766D
#F8766D 0.454510993176649 0.492671034132041 1 #F8766D
#F8766D 0.594768764215315 0.516602351251907 1 #F8766D
#F8766D 0.481390860844993 0.666322653983069 1 #F8766D
#F8766D 0.46881246123096 0.386027102216638 1 #F8766D
#F8766D 0.629402439864911 0.524679170779862 1 #F8766D
#F8766D 0.194499965538631 0.440769990128332 1 #F8766D
#F8766D 0.194672272382659 0.509871668311945 1 #F8766D
#F8766D 0.364222206906058 0.432244458404379 1 #F8766D
#F8766D 0.695395961127576 0.269810643453289 1 #F8766D
#F8766D 0.611827141774071 0.618160878279338 1 #F8766D
#F8766D 0.299434833551589 0.5 1 #F8766D
#F8766D 0.556688951685161 0.698330790630889 1 #F8766D
#F8766D 0.616996347094907 0.635211941727243 1 #F8766D
#F8766D 0.576848852436419 0.624891561219301 1 #F8766D
#F8766D 0.251016610379764 0.652263005175147 1 #F8766D
#F8766D 0.306154800468675 0.517499775643902 1 #F8766D
#F8766D 0.415569646426356 0.42312064375243 1 #F8766D
#F8766D 0.467434006478737 0.460214185288223 1 #F8766D
#F8766D 0.543765938383073 0.488333482904065 1 #F8766D
#F8766D 0.565821214418637 0.530662000059828 1 #F8766D
#F8766D 0.553932042180715 0.595276556283466 1 #F8766D
#F8766D 0.275656489075746 0.384381824164647 1 #F8766D
#F8766D 0.386966710317734 0.447500673068294 1 #F8766D
#F8766D 0.586498035701978 0.821577073798199 1 #F8766D
#F8766D 0.52636294713626 0.528717580543839 1 #F8766D
#F8766D 0.488627748294162 0.478013102396123 1 #F8766D
#F8766D 0.664553036046592 0.425812916928415 1 #F8766D
#F8766D 0.156937073540561 0.461709892608214 1 #F8766D
#F8766D 0.792749328003308 0.405770438840528 1 #F8766D
#F8766D 0.427975739196361 0.268015794669299 1 #F8766D
#F8766D 0.371631401199256 0.39829190224057 1 #F8766D
#F8766D 0.35284995520022 0.45168865356427 1 #F8766D
#F8766D 0.314942449514095 0.440620419396332 1 #F8766D
#F8766D 0.38248673237301 0.471581560920159 1 #F8766D
#F8766D 0.598387207939899 0.575084507463579 1 #F8766D
#F8766D 0.430560341856779 0.64104520027521 1 #F8766D
#F8766D 0.621820938727686 0.669314068623052 1 #F8766D
#F8766D 0.379557516024537 0.543525083011756 1 #F8766D
#F8766D 0.424357295471776 0.552349756199707 1 #F8766D
#F8766D 0.665931490798815 0.448996380388286 1 #F8766D
#F8766D 0.663002274450341 0.56252056597565 1 #F8766D
#F8766D 0.636983941002137 0.635810224655239 1 #F8766D
#F8766D 0.590633399958646 0.597669687995453 1 #F8766D
#F8766D 0.680922186229237 0.495512878040025 1 #F8766D
#F8766D 0.603211799572679 0.535597834215801 1 #F8766D
#F8766D 0.535495209869736 0.497906009752012 1 #F8766D
#F8766D 0.395409745675098 0.387223668072631 1 #F8766D
#F8766D 0.747604934868013 0.452137365760268 1 #F8766D
#F8766D 0.635260872561858 0.406667863232523 1 #F8766D
#F8766D 0.718485078227307 0.328292799664961 1 #F8766D
#F8766D 0.647839272175891 0.515106643931915 1 #F8766D
#F8766D 0.642842373699083 0.357608663136797 1 #F8766D
#F8766D 0.548418223171824 0.526025307367854 1 #F8766D
#F8766D 0.644393135295334 0.384381824164647 1 #F8766D
#F8766D 0.755875663381349 0.414744682760477 1 #F8766D
#F8766D 0.40402508787649 0.401582458344551 1 #F8766D
#F8766D 0.564442759666414 0.530213287863831 1 #F8766D
#F8766D 0.662829967606313 0.529315863471836 1 #F8766D
#F8766D 0.587187263078089 0.461111609680218 1 #F8766D
#F8766D 0.527741401888483 0.449744234048281 1 #F8766D
#F8766D 0.396443586739265 0.460513326752221 1 #F8766D
#F8766D 0.561858157005996 0.497606868288013 1 #F8766D
#F8766D 0.402129712592184 0.547862634239732 1 #F8766D
#F8766D 0.55513819008891 0.549059200095725 1 #F8766D
#F8766D 0.642497760011028 0.402479882736546 1 #F8766D
#F8766D 0.280825694396581 0.437030721828353 1 #F8766D
#F8766D 0.542732097318905 0.538589248855784 1 #F8766D
#F8766D 0.647666965331863 0.434039307188369 1 #F8766D
#F8766D 0.553070507960576 0.45707319991624 1 #F8766D
#F8766D 0.635260872561858 0.498504292680008 1 #F8766D
#F8766D 0.438314149838032 0.820679649406204 1 #F8766D
#F8766D 0.485526225101661 0.490726614616052 1 #F8766D
#F8766D 0.450547935764009 0.693694097938915 1 #F8766D
#F8766D 0.525846026604177 0.522286039067875 1 #F8766D
#F8766D 0.727961954648839 0.530811570791827 1 #F8766D
#F8766D 0.642670066855055 0.811256693290257 1 #F8766D
#F8766D 0.60476256116893 0.737667893146669 1 #F8766D
#F8766D 0.56875043076711 0.546217356187741 1 #F8766D
#F8766D 0.691605210558963 0.321711687456998 1 #F8766D
#F8766D 0.702977462264801 0.461111609680218 1 #F8766D
#F8766D 0.699531325384244 0.357010380208801 1 #F8766D
#F8766D 0.534289061961541 0.606943073379401 1 #F8766D
#F8766D 0.609242539113654 0.629229112447276 1 #F8766D
#F8766D 0.600454890068234 0.761748780998534 1 #F8766D
#F8766D 0.613894823902405 0.787774088366388 1 #F8766D
#F8766D 0.56237507753808 0.483696790212091 1 #F8766D
#F8766D 0.495347715211248 0.598716683119447 1 #F8766D
#F8766D 0.600971810600317 0.464103024320201 1 #F8766D
#F8766D 0.594941071059342 0.576580214783571 1 #F8766D
#F8766D 0.666620718174926 0.533802985431811 1 #F8766D
#F8766D 0.627334757736577 0.53754225373179 1 #F8766D
#F8766D 0.736577296850231 0.392309072960603 1 #F8766D
#F8766D 0.710731270246054 0.501196565855993 1 #F8766D
#F8766D 0.552553587428493 0.74454814681863 1 #F8766D
#F8766D 0.664380729202564 0.543076370815759 1 #F8766D
#F8766D 0.634054724653663 0.33577133626492 1 #F8766D
#F8766D 0.727789647804811 0.563118848903646 1 #F8766D
#F8766D 0.175546212695568 0.553995034251697 1 #F8766D
#F8766D 0.332000827072851 0.405172155912531 1 #F8766D
#F8766D 0.581845750913226 0.593780848963475 1 #F8766D
#F8766D 0.88217658005376 0.501346136587992 1 #F8766D
#F8766D 0.77345096147219 0.496111160968022 1 #F8766D
#F8766D 0.707457440209525 0.701920488198869 1 #F8766D
#F8766D 0.670756082431594 0.543076370815759 1 #F8766D
#F8766D 0.632503963057413 0.553845463519698 1 #F8766D
#F8766D 0.559101247501551 0.508226390259954 1 #F8766D
#F8766D 0.719174305603419 0.458120195040234 1 #F8766D
#F8766D 0.696429802191743 0.466496156032188 1 #F8766D
#F8766D 0.551347439520298 0.478461814592121 1 #F8766D
#F8766D 0.44486180991109 0.518995482963894 1 #F8766D
#F8766D 0.328726997036322 0.422971073020431 1 #F8766D
#F8766D 0.330622372320629 0.590490292859493 1 #F8766D
#F8766D 0.355779171548694 0.50358969756798 1 #F8766D
#F8766D 0.379212902336481 0.392608214424601 1 #F8766D
#F8766D 0.542732097318905 0.819931795746208 1 #F8766D
#F8766D 0.762767937142463 0.581216907475545 1 #F8766D
#F8766D 0.190364601281963 0.390663794908612 1 #F8766D
#F8766D 0.295471776138948 0.53395255616381 1 #F8766D
#F8766D 0.558928940657523 0.557883873283676 1 #F8766D
#F8766D 0.253428906196154 0.398890185168566 1 #F8766D
#F8766D 0.676614515128541 0.612776331927368 1 #F8766D
#F8766D 0.586153422013922 0.515555356127913 1 #F8766D
#F8766D 0.664036115514508 0.402928594932544 1 #F8766D
#F8766D 0.616824040250879 0.606494361183403 1 #F8766D
#F8766D 0.533255220897374 0.346689999700858 1 #F8766D
#F8766D 0.326142394375905 0.32500224356098 1 #F8766D
#F8766D 0.561168929629885 0.607391785575399 1 #F8766D
#F8766D 0.545144393135295 0.39455263394059 1 #F8766D
#F8766D 0.514301468054311 0.508226390259954 1 #F8766D
#F8766D 0.516196843338617 0.492371892668043 1 #F8766D
#F8766D 0.548590530015852 0.635511083191241 1 #F8766D
#F8766D 0.669205320835344 0.481453229232104 1 #F8766D
#F8766D 0.675752980908402 0.356262526548805 1 #F8766D
#F8766D 0.628885519332828 0.55534117083969 1 #F8766D
#F8766D 0.307705562064925 0.652562146639145 1 #F8766D
#F8766D 0.517919911778896 0.495064165844028 1 #F8766D
#F8766D 0.643531601075195 0.503140985371982 1 #F8766D
#F8766D 0.643359294231167 0.462308175536211 1 #F8766D
#F8766D 0.5136122406782 0.55534117083969 1 #F8766D
#F8766D 0.518092218622924 0.6606389661671 1 #F8766D
#F8766D 0.470535529671239 0.550704478147716 1 #F8766D
#F8766D 0.538596733062237 0.504636692691974 1 #F8766D
#F8766D 0.549968984768075 0.737967034610667 1 #F8766D
#F8766D 0.533944448273485 0.671258488139041 1 #F8766D
#F8766D 0.287717968157695 0.655104849083131 1 #F8766D
#F8766D 0.580984216693087 0.577776780639564 1 #F8766D
#F8766D 0.504307671100696 0.611280624607377 1 #F8766D
#F8766D 0.771555586187883 0.59108857578749 1 #F8766D
#00BFC4 0.677303742504652 0.624741990487301 1 #00BFC4
#F8766D 0.616996347094907 0.506581112207963 1 #F8766D
#F8766D 0.748811082776208 0.640297346615214 1 #F8766D
#F8766D 0.491040044110552 0.549807053755721 1 #F8766D
#F8766D 0.615617892342684 0.550854048879715 1 #F8766D
#F8766D 0.782583224205665 0.388719375392623 1 #F8766D
#F8766D 0.561341236473913 0.362993209488767 1 #F8766D
#F8766D 0.71262664553036 0.615019892907356 1 #F8766D
#F8766D 0.327003928596044 0.494017170720033 1 #F8766D
#F8766D 0.599248742160039 0.520042478087888 1 #F8766D
#F8766D 0.622165552415742 0.424466780340423 1 #F8766D
#F8766D 0.683679095733683 0.545319931795746 1 #F8766D
#F8766D 0.546695154731546 0.4107062729965 1 #F8766D
#F8766D 0.646116203735612 0.408013999820515 1 #F8766D
#F8766D 0.301502515679923 0.292545394717162 1 #F8766D
#F8766D 0.787407815838445 0.411603697388495 1 #F8766D
#F8766D 0.619753256599352 0.552499326931706 1 #F8766D
#F8766D 0.642497760011028 0.553995034251697 1 #F8766D
#F8766D 0.626817837204494 0.448547668192288 1 #F8766D
#00BFC4 0.35526225101661 0.404723443716533 1 #00BFC4
#F8766D 0.607519470673375 0.451987795028269 1 #F8766D
#F8766D 0.612344062306155 0.664079093003081 1 #F8766D
#F8766D 0.482941622441243 0.638053785635227 1 #F8766D
#F8766D 0.660762285477979 0.47322683897215 1 #F8766D
#F8766D 0.629057826176856 0.466346585300188 1 #F8766D
#F8766D 0.596319525811565 0.745595141942625 1 #F8766D
#F8766D 0.565131987042525 0.50179484878399 1 #F8766D
#F8766D 0.639740850506582 0.39470220467259 1 #F8766D
#F8766D 0.695568267971604 0.343399443596877 1 #F8766D
#F8766D 0.623544007167965 0.4820515121601 1 #F8766D
#F8766D 0.529809084016817 0.513162224415926 1 #F8766D
#F8766D 0.637156247846164 0.59108857578749 1 #F8766D
#F8766D 0.236715142325453 0.456923629184241 1 #F8766D
#F8766D 0.331656213384796 0.570746956235604 1 #F8766D
#F8766D 0.376628299676063 0.336967902120913 1 #F8766D
#F8766D 0.416258873802467 0.527072302491848 1 #F8766D
#F8766D 0.396788200427321 0.430000897424392 1 #F8766D
#F8766D 0.587876490454201 0.342950731400879 1 #F8766D
#F8766D 0.528602936108622 0.541431092763768 1 #F8766D
#F8766D 0.29529946929492 0.40352687786054 1 #F8766D
#F8766D 0.264456544213936 0.508824673187951 1 #F8766D
#F8766D 0.257391963608795 0.507478536599958 1 #F8766D
#F8766D 0.42642497760011 0.335472194800921 1 #F8766D
#F8766D 0.486904679853884 0.622199288043316 1 #F8766D
#F8766D 0.770004824591633 0.474423404828143 1 #F8766D
#F8766D 0.393342063546764 0.405920009572527 1 #F8766D
#F8766D 0.709697429181887 0.504786263423973 1 #F8766D
#F8766D 0.443311048314839 0.48923090729606 1 #F8766D
#F8766D 0.363877593218003 0.42685991205241 1 #F8766D
#F8766D 0.40006203046385 0.327694516736965 1 #F8766D
#F8766D 0.326831621752016 0.428654760836399 1 #F8766D
#F8766D 0.628368598800744 0.524080887851865 1 #F8766D
#F8766D 0.243090495554483 0.539486673247779 1 #F8766D
#F8766D 0.253945826728238 0.612178048999372 1 #F8766D
#F8766D 0.715211248190778 0.603951658739418 1 #F8766D
#F8766D 0.335791577641464 0.455128780400251 1 #F8766D
#F8766D 0.380591357088704 0.422522360824434 1 #F8766D
#F8766D 0.714349713970639 0.495363307308026 1 #F8766D
#F8766D 0.585981115169894 0.683224146698974 1 #F8766D
#F8766D 0.375939072299952 0.386027102216638 1 #F8766D
#F8766D 0.638879316286443 0.560127434263663 1 #F8766D
#F8766D 0.632331656213385 0.52318346345987 1 #F8766D
#F8766D 0.772244813563995 0.502841843907984 1 #F8766D
#F8766D 0.369908332758977 0.389915941248616 1 #F8766D
#F8766D 0.649217726928114 0.547114780579736 1 #F8766D
#F8766D 0.212592184161555 0.538140536659786 1 #F8766D
#F8766D 0.39609897305121 0.400385892488558 1 #F8766D
#F8766D 0.790681645874974 0.632519668551258 1 #F8766D
#F8766D 0.386277482941622 0.372117024140716 1 #F8766D
#00BFC4 0.773795575160245 0.463504741392204 1 #00BFC4
#F8766D 0.630608587773106 0.364788058272757 1 #F8766D
#F8766D 0.642325453167 0.744249005354632 1 #F8766D
#F8766D 0.277379557516024 0.532606419575817 1 #F8766D
#F8766D 0.657660762285478 0.453184360884262 1 #F8766D
#F8766D 0.239816665517954 0.519892907355889 1 #F8766D
#F8766D 0.716762009787029 0.320066409405008 1 #F8766D
#F8766D 0.683506788889655 0.479807951180113 1 #F8766D
#F8766D 0.917154869391412 0.439124712076341 1 #F8766D
#F8766D 0.802915431800951 0.645681892967184 1 #F8766D
#F8766D 0.387139017161762 0.364040204612761 1 #F8766D
#F8766D 0.401095871528017 0.415043824224476 1 #F8766D
#F8766D 0.445378730443173 0.368377755840737 1 #F8766D
#F8766D 0.390412847198291 0.326946663076969 1 #F8766D
#F8766D 0.377834447584258 0.42491549253642 1 #F8766D
#F8766D 0.624922461920188 0.670510634479045 1 #F8766D
#F8766D 0.181749259080571 0.404723443716533 1 #F8766D
#F8766D 0.651457715900476 0.597819258727452 1 #F8766D
#F8766D 0.554965883244882 0.416389960812468 1 #F8766D
#F8766D 0.385760562409539 0.576580214783571 1 #F8766D
#F8766D 0.359569922117306 0.46245774626821 1 #F8766D
#F8766D 0.713660486594528 0.576580214783571 1 #F8766D
#F8766D 0.653697704872838 0.471880702384157 1 #F8766D
#F8766D 0.194672272382659 0.485491638996081 1 #F8766D
#F8766D 0.30891170997312 0.444509258428311 1 #F8766D
#F8766D 0.659211523881729 0.484444643872087 1 #F8766D
#F8766D 0.56478737335447 0.5714948098956 1 #F8766D
#F8766D 0.342166930870494 0.418483951060456 1 #F8766D
#00BFC4 0.232579778068785 0.562071853779652 1 #00BFC4
#F8766D 0.260321179957268 0.476966107272129 1 #F8766D
#F8766D 0.25377351988421 0.422372790092435 1 #F8766D
#F8766D 0.507064580605142 0.526474019563852 1 #F8766D
#F8766D 0.692294437935075 0.460214185288223 1 #F8766D
#F8766D 0.345268454062995 0.298079511801131 1 #F8766D
#F8766D 0.447101798883452 0.4820515121601 1 #F8766D
#F8766D 0.655593080157144 0.552349756199707 1 #F8766D
#00BFC4 0.397305120959404 0.46963714140417 1 #00BFC4
#F8766D 0.39127438141843 0.453782643812259 1 #F8766D
#F8766D 0.26256116892963 0.376305004636693 1 #F8766D
#F8766D 0.309945551037287 0.475320829220138 1 #F8766D
#F8766D 0.559618168033634 0.861961171437973 1 #F8766D
#00BFC4 0.435040319801502 0.209384067725627 1 #00BFC4
#F8766D 0.664036115514508 0.619507014867331 1 #F8766D
#00BFC4 0.296505617203115 0.60170809775943 1 #00BFC4
#00BFC4 0.513784547522228 0.372864877800712 1 #00BFC4
#F8766D 0.715383555034806 0.476218253612133 1 #F8766D
#F8766D 0.248259700875319 0.378099853420683 1 #F8766D
#F8766D 0.333379281825074 0.592733853839481 1 #F8766D
#F8766D 0.395409745675098 0.524828741511861 1 #F8766D
#F8766D 0.486215452477772 0.792111639594364 1 #F8766D
#F8766D 0.459507891653457 0.27848574590924 1 #F8766D
#F8766D 0.408160452133159 0.438227287684346 1 #F8766D
#F8766D 0.413329657453994 0.360300936312782 1 #F8766D
#F8766D 0.494830794679165 0.621152292919321 1 #F8766D
#F8766D 0.650940795368392 0.516602351251907 1 #F8766D
#F8766D 0.550658212144186 0.813500254270244 1 #F8766D
#F8766D 0.372148321731339 0.328143228932962 1 #F8766D
#F8766D 0.637673168378248 0.49102575608005 1 #F8766D
#F8766D 0.276690330139913 0.359553082652786 1 #F8766D
#F8766D 0.630780894617134 0.48399593167609 1 #F8766D
#F8766D 0.641119305258805 0.552050614735708 1 #F8766D
#F8766D 0.385760562409539 0.508226390259954 1 #F8766D
#F8766D 0.641636225790888 0.531110712255826 1 #F8766D
#F8766D 0.486732373009856 0.641643483203207 1 #F8766D
#F8766D 0.433834171893308 0.795701337162344 1 #F8766D
#F8766D 0.561858157005996 0.57672978551557 1 #F8766D
#F8766D 0.509649183265559 0.257396272697359 1 #F8766D
#F8766D 0.376800606520091 0.530811570791827 1 #F8766D
#F8766D 0.425391136535943 0.413398546172485 1 #F8766D
#F8766D 0.37369908332759 0.481303658500105 1 #F8766D
#F8766D 0.133503342752774 0.586302312363517 1 #F8766D
#F8766D 0.354745330484527 0.355813814352807 1 #F8766D
#F8766D 0.725205045144393 0.430150468156391 1 #F8766D
#F8766D 0.776552484664691 0.381539980256663 1 #F8766D
#F8766D 0.546867461575574 0.42312064375243 1 #F8766D
#F8766D 0.574436556620029 0.454231356008256 1 #F8766D
#F8766D 0.452615617892343 0.387373238804631 1 #F8766D
#F8766D 0.667137638707009 0.468739717012175 1 #F8766D
#F8766D 0.697980563787994 0.442116126716324 1 #F8766D
#F8766D 0.438486456682059 0.444060546232313 1 #F8766D
#F8766D 0.443483355158867 0.648673307607167 1 #F8766D
#F8766D 0.416431180646495 0.33756618504891 1 #F8766D
#F8766D 0.6559376938452 0.497307726824015 1 #F8766D
#F8766D 0.694879040595493 0.594827844087469 1 #F8766D
#F8766D 0.229995175408367 0.528418439079841 1 #F8766D
#F8766D 0.626645530360466 0.528717580543839 1 #F8766D
#F8766D 0.268247294782549 0.567157258667624 1 #F8766D
#F8766D 0.678854504100903 0.430599180352389 1 #F8766D
#F8766D 0.746054173271762 0.459466331628227 1 #F8766D
#F8766D 0.396960507271349 0.538738819587783 1 #F8766D
#F8766D 0.64628851057964 0.485940351192079 1 #F8766D
#F8766D 0.363016058997863 0.377351999760687 1 #F8766D
#F8766D 0.465194017506375 0.446603248676299 1 #F8766D
#F8766D 0.325453166999793 0.444808399892309 1 #F8766D
#F8766D 0.289613343442001 0.397992760776571 1 #F8766D
#F8766D 0.742780343235233 0.360300936312782 1 #F8766D
#F8766D 0.542042869942794 0.475470399952137 1 #F8766D
#F8766D 0.65266386380867 0.636558078315235 1 #F8766D
#F8766D 0.557895099593356 0.621002722187322 1 #F8766D
#F8766D 0.500172306844028 0.260387687337342 1 #F8766D
#F8766D 0.430388035012751 0.439573424272338 1 #F8766D
#F8766D 0.35526225101661 0.381839121720662 1 #F8766D
#F8766D 0.359914535805362 0.251563014149391 1 #F8766D
#F8766D 0.407643531601075 0.532008136647821 1 #F8766D
#F8766D 0.509132262733476 0.48040623410811 1 #F8766D
#F8766D 0.376628299676063 0.479658380448114 1 #F8766D
#F8766D 0.586153422013922 0.637605073439229 1 #F8766D
#F8766D 0.654903852781032 0.507777678063956 1 #F8766D
#F8766D 0.674029912468123 0.301519638637111 1 #F8766D
#F8766D 0.607864084361431 0.502692273175985 1 #F8766D
#F8766D 0.548245916327797 0.549657483023722 2 #F8766D
#00BFC4 0.576331931904335 0.511217804899937 2 #00BFC4
#00BFC4 0.467778620166793 0.808414849382273 2 #00BFC4
#00BFC4 0.629230133020884 0.619806156331329 2 #00BFC4
#F8766D 0.410745054793576 0.667668790571061 2 #F8766D
#00BFC4 0.627851678268661 0.60170809775943 2 #00BFC4
#00BFC4 0.431077262388862 0.397544048580574 2 #00BFC4
#F8766D 0.607174856985319 0.606494361183403 2 #F8766D
#F8766D 0.443311048314839 0.576430644051572 2 #F8766D
#00BFC4 0.534461368805569 0.629976966107272 2 #00BFC4
#F8766D 0.572541181335723 0.654506566155135 2 #F8766D
#F8766D 0.616996347094907 0.56790511232762 2 #F8766D
#00BFC4 0.585119580949755 0.588097161147507 2 #00BFC4
#00BFC4 0.701599007512578 0.790915073738371 2 #00BFC4
#00BFC4 0.598387207939899 0.569251248915612 2 #00BFC4
#F8766D 0.6151009718106 0.632370097819259 2 #F8766D
#00BFC4 0.598214901095871 0.688608693050944 2 #00BFC4
#F8766D 0.500861534220139 0.437629004756349 2 #F8766D
#00BFC4 0.485009304569577 0.381988692452661 2 #00BFC4
#00BFC4 0.270659590598939 0.43030003888839 2 #00BFC4
#F8766D 0.577021159280447 0.373612731460708 2 #F8766D
#00BFC4 0.259804259425184 0.40173202907655 2 #00BFC4
#00BFC4 0.193983045006548 0.645681892967184 2 #00BFC4
#F8766D 0.640774691570749 0.425513775464417 2 #F8766D
#00BFC4 0.540319801502516 0.689356546710939 2 #00BFC4
#00BFC4 0.364394513750086 0.506581112207963 2 #00BFC4
#F8766D 0.603039492728651 0.486837775584074 2 #F8766D
#00BFC4 0.289613343442001 0.462906458464208 2 #00BFC4
#00BFC4 0.569956578675305 0.714783571150797 2 #00BFC4
#F8766D 0.590116479426563 0.494166741452033 2 #F8766D
#00BFC4 0.620614790819491 0.48040623410811 2 #00BFC4
#00BFC4 0.451064856296092 0.563866702563642 2 #00BFC4
#F8766D 0.644565442139362 0.459167190164229 2 #F8766D
#00BFC4 0.227582879591977 0.481154087768105 2 #00BFC4
#F8766D 0.505858432696947 0.581964761135541 2 #F8766D
#00BFC4 0.467434006478737 0.463504741392204 2 #00BFC4
#F8766D 0.690743676338824 0.548012204971731 2 #F8766D
#00BFC4 0.467434006478737 0.600062819707439 2 #00BFC4
#F8766D 0.593218002619064 0.53933710251578 2 #F8766D
#00BFC4 0.302708663588118 0.616964312423345 2 #00BFC4
#00BFC4 0.274967261699635 0.550554907415717 2 #00BFC4
#F8766D 0.614756358122545 0.513012653683927 2 #F8766D
#00BFC4 0.550658212144186 0.547114780579736 2 #00BFC4
#F8766D 0.521882969191536 0.655254419815131 2 #F8766D
#F8766D 0.444344889379006 0.611280624607377 2 #F8766D
#00BFC4 0.457957130057206 0.471880702384157 2 #00BFC4
#00BFC4 0.356985319456889 0.839824703102097 2 #00BFC4
#00BFC4 0.702460541732718 0.390514224176613 2 #00BFC4
#F8766D 0.672134537183817 0.491624039008047 2 #F8766D
#F8766D 0.532049072989179 0.544272936671752 2 #F8766D
#F8766D 0.497070783651527 0.521239043943881 2 #F8766D
#00BFC4 0.361292990557585 0.432394029136379 2 #00BFC4
#00BFC4 0.559618168033634 0.463355170660205 2 #00BFC4
#F8766D 0.530326004548901 0.501944419515989 2 #F8766D
#00BFC4 0.418843476462885 0.42147536570044 2 #00BFC4
#00BFC4 0.207767592528775 0.504337551227976 2 #00BFC4
#00BFC4 0.622165552415742 0.546965209847737 2 #00BFC4
#00BFC4 0.286856433937556 0.412650692512489 2 #00BFC4
#00BFC4 0.440381831966366 0.662134673487092 2 #00BFC4
#00BFC4 0.220862912674891 0.47502168775614 2 #00BFC4
#00BFC4 0.348714590943552 0.581366478207544 2 #00BFC4
#00BFC4 0.636467020470053 0.456325346256245 2 #00BFC4
#00BFC4 0.537907505686126 0.665724371055072 2 #00BFC4
#00BFC4 0.260493486801296 0.664378234467079 2 #00BFC4
#00BFC4 0.502239988972362 0.396048341260582 2 #00BFC4
#00BFC4 0.369908332758977 0.475619970684136 2 #00BFC4
#00BFC4 0.376800606520091 0.552499326931706 2 #00BFC4
#00BFC4 0.525501412916121 0.635810224655239 2 #00BFC4
#00BFC4 0.581501137225171 0.603652517275419 2 #00BFC4
#00BFC4 0.317182438486457 0.339510604564899 2 #00BFC4
#F8766D 0.329588531256461 0.445257112088307 2 #F8766D
#00BFC4 0.535839823557792 0.597220975799456 2 #00BFC4
#00BFC4 0.457957130057206 0.61606688803135 2 #00BFC4
#00BFC4 0.423668068095665 0.386924526608633 2 #00BFC4
#00BFC4 0.568233510235027 0.59288342457148 2 #00BFC4
#00BFC4 0.511544558549866 0.584956175775524 2 #00BFC4
#00BFC4 0.252567371976015 0.435385443776362 2 #00BFC4
#00BFC4 0.671789923495761 0.527969726883843 2 #00BFC4
#00BFC4 0.5439382452271 0.512563941487929 2 #00BFC4
#00BFC4 0.424529602315804 0.578823775763558 2 #00BFC4
#00BFC4 0.364739127438142 0.522286039067875 2 #00BFC4
#00BFC4 0.49121235095458 0.796150049358342 2 #00BFC4
#00BFC4 0.710386656557998 0.500598282927996 2 #00BFC4
#00BFC4 0.399717416775794 0.440620419396332 2 #00BFC4
#00BFC4 0.585808808325867 0.537990965927787 2 #00BFC4
#F8766D 0.282893376524916 0.330835502108947 2 #F8766D
#00BFC4 0.61751326762699 0.415043824224476 2 #00BFC4
#00BFC4 0.587187263078089 0.722860390678752 2 #00BFC4
#00BFC4 0.385760562409539 0.368826468036735 2 #00BFC4
#00BFC4 0.622854779791853 0.482948936552095 2 #00BFC4
#F8766D 0.458990971121373 0.518995482963894 2 #F8766D
#00BFC4 0.0900820180577572 0.558332585479673 2 #00BFC4
#F8766D 0.320800882211041 0.713886146758802 2 #F8766D
#00BFC4 0.207078365152664 0.598417541655449 2 #00BFC4
#00BFC4 0.470535529671239 0.504487121959975 2 #00BFC4
#00BFC4 0.526018333448204 0.597220975799456 2 #00BFC4
#00BFC4 0.559101247501551 0.533653414699811 2 #00BFC4
#00BFC4 0.327176235440072 0.518696341499895 2 #00BFC4
#00BFC4 0.314253222137983 0.417586526668461 2 #00BFC4
#F8766D 0.608381004893514 0.56611026354363 2 #F8766D
#00BFC4 0.451754083672203 0.59288342457148 2 #00BFC4
#00BFC4 0.577021159280447 0.579272487959556 2 #00BFC4
#F8766D 0.602867185884623 0.554593317179694 2 #F8766D
#00BFC4 0.221896753739058 0.567007687935625 2 #00BFC4
#F8766D 0.252567371976015 0.522286039067875 2 #F8766D
#F8766D 0.624405541388104 0.516303209787909 2 #F8766D
#00BFC4 0.394031290922875 0.390813365640611 2 #00BFC4
#F8766D 0.847370597560135 0.482500224356098 2 #F8766D
#F8766D 0.535495209869736 0.480107092644111 2 #F8766D
#F8766D 0.580294989316976 0.649421161267163 2 #F8766D
#F8766D 0.569611964987249 0.449594663316282 2 #F8766D
#F8766D 0.440898752498449 0.730039785814712 2 #F8766D
#F8766D 0.52239988972362 0.567157258667624 2 #F8766D
#00BFC4 0.607864084361431 0.522585180531873 2 #00BFC4
#00BFC4 0.599076435316011 0.523781746387867 2 #00BFC4
#F8766D 0.635433179405886 0.444060546232313 2 #F8766D
#F8766D 0.510683024329726 0.642391336863202 2 #F8766D
#00BFC4 0.531359845613068 0.686065990606958 2 #00BFC4
#00BFC4 0.326831621752016 0.54098238056777 2 #00BFC4
#F8766D 0.566165828106692 0.616665170959347 2 #F8766D
#00BFC4 0.352677648356193 0.474124263364145 2 #00BFC4
#00BFC4 0.573919636087945 0.621750575847318 2 #00BFC4
#00BFC4 0.386105176097595 0.679185736934996 2 #00BFC4
#00BFC4 0.414018884830105 0.605596936791408 2 #00BFC4
#00BFC4 0.268074987938521 0.514508361003919 2 #00BFC4
#F8766D 0.453477152112482 0.546815639115738 2 #F8766D
#00BFC4 0.649390033772141 0.503888839031978 2 #00BFC4
#00BFC4 0.176752360603763 0.533204702503814 2 #00BFC4
#00BFC4 0.379729822868564 0.722112537018756 2 #00BFC4
#00BFC4 0.267213453718382 0.559678722067666 2 #00BFC4
#00BFC4 0.436246467709697 0.458269765772234 2 #00BFC4
#00BFC4 0.450547935764009 0.443761404768315 2 #00BFC4
#00BFC4 0.652836170652698 0.617413024619342 2 #00BFC4
#00BFC4 0.37524984492384 0.446752819408298 2 #00BFC4
#00BFC4 0.499138465779861 0.495961590236023 2 #00BFC4
#00BFC4 0.764491005582742 0.418932663256454 2 #00BFC4
#00BFC4 0.626128609828382 0.47322683897215 2 #00BFC4
#00BFC4 0.432972637673168 0.558332585479673 2 #00BFC4
#00BFC4 0.660417671789923 0.386176672948637 2 #00BFC4
#00BFC4 0.581156523537115 0.435834155972359 2 #00BFC4
#00BFC4 0.305982493624647 0.414894253492477 2 #00BFC4
#F8766D 0.251188917223792 0.419231804720452 2 #F8766D
#00BFC4 0.616479426562823 0.39111250710461 2 #00BFC4
#00BFC4 0.634916258873802 0.182760477429777 2 #00BFC4
#00BFC4 0.452615617892343 0.342352448472883 2 #00BFC4
#F8766D 0.624577848232132 0.356262526548805 2 #F8766D
#00BFC4 0.458301743745262 0.431347034012384 2 #00BFC4
#00BFC4 0.503446136880557 0.40711657542852 2 #00BFC4
#00BFC4 0.431077262388862 0.372416165604714 2 #00BFC4
#00BFC4 0.292197946102419 0.321262975261001 2 #00BFC4
#00BFC4 0.259804259425184 0.470235424332167 2 #00BFC4
#00BFC4 0.408160452133159 0.536794400071794 2 #00BFC4
#00BFC4 0.432283410297057 0.400834604684555 2 #00BFC4
#00BFC4 0.404542008408574 0.70536061503485 2 #00BFC4
#00BFC4 0.34251154455855 0.535896975679799 2 #00BFC4
#F8766D 0.535495209869736 0.372266594872715 2 #F8766D
#00BFC4 0.441760286718588 0.481602799964103 2 #00BFC4
#00BFC4 0.527913708732511 0.569400819647611 2 #00BFC4
#00BFC4 0.389379006134124 0.487136917048072 2 #00BFC4
#00BFC4 0.326659314907988 0.574486224535583 2 #00BFC4
#00BFC4 0.479150871872631 0.57493493673158 2 #00BFC4
#00BFC4 0.572885795023778 0.506132400011966 2 #00BFC4
#00BFC4 0.423840374939693 0.629079541715277 2 #00BFC4
#00BFC4 0.252739678820043 0.686365132070956 2 #00BFC4
#00BFC4 0.333206974981046 0.51061952197194 2 #00BFC4
#00BFC4 0.600799503756289 0.478312243860121 2 #00BFC4
#00BFC4 0.368185264318699 0.405471297376529 2 #00BFC4
#00BFC4 0.579605761940864 0.534251697627808 2 #00BFC4
#00BFC4 0.187090771245434 0.564165844027641 2 #00BFC4
#00BFC4 0.375939072299952 0.521239043943881 2 #00BFC4
#00BFC4 0.528258322420567 0.420278799844446 2 #00BFC4
#00BFC4 0.310807085257426 0.375407580244698 2 #00BFC4
#00BFC4 0.361292990557585 0.635959795387238 2 #00BFC4
#00BFC4 0.541009028878627 0.400834604684555 2 #00BFC4
#00BFC4 0.427286511820249 0.488034341440067 2 #00BFC4
#00BFC4 0.554276655868771 0.410556702264501 2 #00BFC4
#00BFC4 0.532049072989179 0.601558527027431 2 #00BFC4
#00BFC4 0.341994624026466 0.302417063029106 2 #00BFC4
#00BFC4 0.45520022055276 0.616366029495348 2 #00BFC4
#00BFC4 0.376455992832035 0.431795746208382 2 #00BFC4
#00BFC4 0.64870080639603 0.45886804870023 2 #00BFC4
#00BFC4 0.528947549796678 0.418334380328457 2 #00BFC4
#00BFC4 0.43124956923289 0.364788058272757 2 #00BFC4
#00BFC4 0.478117030808464 0.443910975500314 2 #00BFC4
#00BFC4 0.151940175063753 0.492970175596039 2 #00BFC4
#00BFC4 0.37766214074023 0.427906907176404 2 #00BFC4
#00BFC4 0.471741677579433 0.491474468276048 2 #00BFC4
#00BFC4 0.671617616651733 0.480705375572108 2 #00BFC4
#00BFC4 0.437452615617892 0.426261629124413 2 #00BFC4
#00BFC4 0.0873251085533117 0.616964312423345 2 #00BFC4
#00BFC4 0.238265903921704 0.533204702503814 2 #00BFC4
#00BFC4 0.577710386656558 0.543225941547758 2 #00BFC4
#00BFC4 0.641291612102833 0.393655209548595 2 #00BFC4
#00BFC4 0.544282858915156 0.35536510215681 2 #00BFC4
#00BFC4 0.539458267282376 0.35536510215681 2 #00BFC4
#00BFC4 0.243607416086567 0.593481707499476 2 #00BFC4
#00BFC4 0.294782548762837 0.459466331628227 2 #00BFC4
#00BFC4 0.452271004204287 0.475320829220138 2 #00BFC4
#00BFC4 0.658349989661589 0.446752819408298 2 #00BFC4
#00BFC4 0.347336136191329 0.485940351192079 2 #00BFC4
#00BFC4 0.398683575711627 0.607840497771396 2 #00BFC4
#00BFC4 0.560479702253774 0.578375063567561 2 #00BFC4
#00BFC4 0.416431180646495 0.603203805079422 2 #00BFC4
#00BFC4 0.41367427114205 0.520042478087888 2 #00BFC4
#00BFC4 0.0619960024812185 0.413996829100482 2 #00BFC4
#00BFC4 0.396960507271349 0.650617727123156 2 #00BFC4
#00BFC4 0.29616100351506 0.671557629603039 2 #00BFC4
#00BFC4 0.52636294713626 0.53215770737982 2 #00BFC4
#00BFC4 0.522227582879592 0.638352927099225 2 #00BFC4
#00BFC4 0.300985595147839 0.490876185348051 2 #00BFC4
#00BFC4 0.648011579019919 0.560576146459661 2 #00BFC4
#00BFC4 0.554621269556827 0.546067785455742 2 #00BFC4
#00BFC4 0.34492384037494 0.514508361003919 2 #00BFC4
#00BFC4 0.469157074919016 0.495064165844028 2 #00BFC4
#00BFC4 0.594941071059342 0.548610487899728 2 #00BFC4
#00BFC4 0.417292714866634 0.502841843907984 2 #00BFC4
#00BFC4 0.73985112688676 0.617113883155344 2 #00BFC4
#00BFC4 0.550313598456131 0.558631726943672 2 #00BFC4
#00BFC4 0.390585154042319 0.478162673128122 2 #00BFC4
#00BFC4 0.480873940312909 0.464103024320201 2 #00BFC4
#00BFC4 0.247570473499207 0.334126058212929 2 #00BFC4
#00BFC4 0.484492384037494 0.584806605043525 2 #00BFC4
#00BFC4 0.453994072644565 0.673801190583027 2 #00BFC4
#00BFC4 0.485870838789717 0.498354721948009 2 #00BFC4
#00BFC4 0.560996622785857 0.462906458464208 2 #00BFC4
#00BFC4 0.611310221241988 0.482500224356098 2 #00BFC4
#00BFC4 0.585981115169894 0.500299141463998 2 #00BFC4
#00BFC4 0.313047074229788 0.600960244099434 2 #00BFC4
#00BFC4 0.531532152457096 0.556687307427682 2 #00BFC4
#00BFC4 0.359742228961334 0.51435879027192 2 #00BFC4
#00BFC4 0.47122475704735 0.609186634359388 2 #00BFC4
#00BFC4 0.293404094010614 0.749633551706602 2 #00BFC4
#00BFC4 0.365083741126198 0.460513326752221 2 #00BFC4
#00BFC4 0.342339237714522 0.579122917227557 2 #00BFC4
#00BFC4 0.576159625060307 0.384980107092644 2 #00BFC4
#00BFC4 0.374216003859673 0.58749887821951 2 #00BFC4
#00BFC4 0.382314425528982 0.456026204792246 2 #00BFC4
#00BFC4 0.149872492935419 0.695339375990906 2 #00BFC4
#00BFC4 0.3137363016059 0.515854497591911 2 #00BFC4
#00BFC4 0.422289613343442 0.557285590355679 2 #00BFC4
#F8766D 0.178475429044042 0.45527835113225 2 #F8766D
#00BFC4 0.309600937349231 0.542029375691765 2 #00BFC4
#00BFC4 0.308050175752981 0.475171258488139 2 #00BFC4
#00BFC4 0.562719691226136 0.503888839031978 2 #00BFC4
#00BFC4 0.223275208491281 0.347587424092853 2 #00BFC4
#00BFC4 0.304431732028396 0.519145053695893 2 #00BFC4
#00BFC4 0.184333861740988 0.463355170660205 2 #00BFC4
#00BFC4 0.544110552071128 0.427757336444405 2 #00BFC4
#00BFC4 0.410400441105521 0.475171258488139 2 #00BFC4
#00BFC4 0.569784271831277 0.53918753178378 2 #00BFC4
#00BFC4 0.346129988283135 0.584507463579527 2 #00BFC4
#00BFC4 0.580811909849059 0.790466361542373 2 #00BFC4
#00BFC4 0.614411744434489 0.427906907176404 2 #00BFC4
#00BFC4 0.66386380867048 0.491324897544049 2 #00BFC4
#00BFC4 0.557033565373217 0.392309072960603 2 #00BFC4
#00BFC4 0.473292439175684 0.478910526788118 2 #00BFC4
#00BFC4 0.721931215107864 0.536196117143797 2 #00BFC4
#00BFC4 0.654214625404921 0.468590146280176 2 #00BFC4
#00BFC4 0.453477152112482 0.569400819647611 2 #00BFC4
#00BFC4 0.618891722379213 0.628331688055281 2 #00BFC4
#00BFC4 0.499655386311944 0.406518292500523 2 #00BFC4
#00BFC4 0.731580398373423 0.618160878279338 2 #00BFC4
#00BFC4 0.360259149493418 0.404274731520536 2 #00BFC4
#00BFC4 0.66627610448687 0.419231804720452 2 #00BFC4
#00BFC4 0.333206974981046 0.424167638876425 2 #00BFC4
#00BFC4 0.618202495003102 0.621601005115319 2 #00BFC4
#00BFC4 0.111792680405266 0.395898770528583 2 #00BFC4
#00BFC4 0.370425253291061 0.517948487839899 2 #00BFC4
#00BFC4 0.382659039217038 0.617263453887343 2 #00BFC4
#00BFC4 0.296333310359087 0.446902390140297 2 #00BFC4
#00BFC4 0.488972361982218 0.731385922402704 2 #00BFC4
#00BFC4 0.531532152457096 0.515256214663915 2 #00BFC4
#00BFC4 0.384726721345372 0.36074964850878 2 #00BFC4
#00BFC4 0.328726997036322 0.592135570911484 2 #00BFC4
#00BFC4 0.568922737611138 0.459615902360226 2 #00BFC4
#00BFC4 0.472086291267489 0.513910078075922 2 #00BFC4
#00BFC4 0.529119856640706 0.456774058452242 2 #00BFC4
#00BFC4 0.385760562409539 0.431646175476383 2 #00BFC4
#00BFC4 0.368357571162727 0.656002273475126 2 #00BFC4
#00BFC4 0.435040319801502 0.386326243680637 2 #00BFC4
#00BFC4 0.554965883244882 0.579571629423554 2 #00BFC4
#00BFC4 0.510510717485699 0.671707200335038 2 #00BFC4
#00BFC4 0.708491281273692 0.499102575608005 2 #00BFC4
#00BFC4 0.487593907229995 0.548610487899728 2 #00BFC4
#00BFC4 0.267041146874354 0.541730234227766 2 #00BFC4
#00BFC4 0.399028189399683 0.469936282868168 2 #00BFC4
#00BFC4 0.557378179061272 0.524828741511861 2 #00BFC4
#00BFC4 0.417292714866634 0.635810224655239 2 #00BFC4
#00BFC4 0.382831346061066 0.437629004756349 2 #00BFC4
#00BFC4 0.17623544007168 0.614421609979359 2 #00BFC4
#00BFC4 0.337514646081742 0.437180292560352 2 #00BFC4
#00BFC4 0.337342339237715 0.486389063388076 2 #00BFC4
#00BFC4 0.385760562409539 0.455128780400251 2 #00BFC4
#00BFC4 0.459335584809429 0.579122917227557 2 #00BFC4
#00BFC4 0.112137294093321 0.48040623410811 2 #00BFC4
#00BFC4 0.57753807981253 0.517051063447904 2 #00BFC4
#00BFC4 0.418326555930802 0.542627658619761 2 #00BFC4
#00BFC4 0.554793576400855 0.458718477968231 2 #00BFC4
#00BFC4 0.400578950995934 0.324852672828981 2 #00BFC4
#00BFC4 0.469501688607071 0.522286039067875 2 #00BFC4
#00BFC4 0.701254393824523 0.45527835113225 2 #00BFC4
#00BFC4 0.549107450547936 0.518098058571899 2 #00BFC4
#00BFC4 0.495864635743332 0.234661521433486 2 #00BFC4
#00BFC4 0.59597491212351 0.490577043884053 2 #00BFC4
#00BFC4 0.388000551381901 0.449445092584283 2 #00BFC4
#00BFC4 0.264456544213936 0.530662000059828 2 #00BFC4
#00BFC4 0.266007305810187 0.593481707499476 2 #00BFC4
#00BFC4 0.448307946791647 0.500299141463998 2 #00BFC4
#00BFC4 0.388517471913984 0.473675551168147 2 #00BFC4
#00BFC4 0.62475015507616 0.647925453947171 2 #00BFC4
#00BFC4 0.387139017161762 0.31782284842502 2 #00BFC4
#00BFC4 0.606657936453236 0.431197463280385 2 #00BFC4
#00BFC4 0.556516644841133 0.719420263842771 2 #00BFC4
#00BFC4 0.435040319801502 0.632519668551258 2 #00BFC4
#00BFC4 0.553415121648632 0.63222052708726 2 #00BFC4
#00BFC4 0.369563719070921 0.442714409644321 2 #00BFC4
#00BFC4 0.324247019091598 0.447500673068294 2 #00BFC4
#00BFC4 0.195533806602798 0.460363756020222 2 #00BFC4
#00BFC4 0.596491832655593 0.449295521852284 2 #00BFC4
#00BFC4 0.472258598111517 0.603203805079422 2 #00BFC4
#00BFC4 0.352333034668137 0.526474019563852 2 #00BFC4
#00BFC4 0.229478254876284 0.695339375990906 2 #00BFC4
#00BFC4 0.536184437245847 0.644186185647192 2 #00BFC4
#00BFC4 0.338720793989937 0.504786263423973 2 #00BFC4
#00BFC4 0.337514646081742 0.715381854078794 2 #00BFC4
#F8766D 0.681094493073265 0.420877082772443 2 #F8766D
#00BFC4 0.338031566613826 0.449445092584283 2 #00BFC4
#00BFC4 0.358880694741195 0.604400370935415 2 #00BFC4
#00BFC4 0.609759459645737 0.680980585718986 2 #00BFC4
#00BFC4 0.760872561858157 0.454829638936253 2 #00BFC4
#00BFC4 0.532393686677235 0.546965209847737 2 #00BFC4
#00BFC4 0.192776897098353 0.476367824344132 2 #00BFC4
#F8766D 0.360431456337446 0.621002722187322 2 #F8766D
#00BFC4 0.30649941415673 0.443013551108319 2 #00BFC4
#F8766D 0.549107450547936 0.531559424451823 2 #F8766D
#00BFC4 0.51516300227445 0.432693170600377 2 #00BFC4
#00BFC4 0.37766214074023 0.548460917167728 2 #00BFC4
#00BFC4 0.605624095389069 0.432543599868378 2 #00BFC4
#00BFC4 0.516713763870701 0.695189805258907 2 #00BFC4
#00BFC4 0.638190088910332 0.51600406832391 2 #00BFC4
#00BFC4 0.509649183265559 0.359253941188788 2 #00BFC4
#00BFC4 0.407471224757047 0.689655688174938 2 #00BFC4
#00BFC4 0.726066579364532 0.31064345328906 2 #00BFC4
#00BFC4 0.465710938038459 0.33397648748093 2 #00BFC4
#00BFC4 0.376455992832035 0.664826946663077 2 #00BFC4
#00BFC4 0.477427803432352 0.613823327051363 2 #00BFC4
#00BFC4 0.36646219587842 0.595126985551467 2 #00BFC4
#00BFC4 0.624405541388104 0.551601902539711 2 #00BFC4
#00BFC4 0.250499689847681 0.405920009572527 2 #00BFC4
#00BFC4 0.284788751809222 0.543076370815759 2 #00BFC4
#00BFC4 0.43521262664553 0.620554009991325 2 #00BFC4
#00BFC4 0.284788751809222 0.535149122019803 2 #00BFC4
#00BFC4 0.301502515679923 0.466944868228185 2 #00BFC4
#00BFC4 0.383003652905093 0.769825600526489 2 #00BFC4
#00BFC4 0.474153973395823 0.805722576206288 2 #00BFC4
#00BFC4 0.42401268178372 0.417287385204463 2 #00BFC4
#00BFC4 0.394375904610931 0.625938556343295 2 #00BFC4
#00BFC4 0.405575849472741 0.446902390140297 2 #00BFC4
#00BFC4 0.446240264663312 0.662284244219091 2 #00BFC4
#00BFC4 0.606141015921152 0.757859941966556 2 #00BFC4
#00BFC4 0.178475429044042 0.582563044063538 2 #00BFC4
#00BFC4 0.479840099248742 0.572392234287595 2 #00BFC4
#00BFC4 0.406781997380936 0.412949833976487 2 #00BFC4
#00BFC4 0.435729547177614 0.397244907116575 2 #00BFC4
#00BFC4 0.513267626990144 0.685018995482964 2 #00BFC4
#00BFC4 0.299434833551589 0.659442400311107 2 #00BFC4
#00BFC4 0.408160452133159 0.496260731700021 2 #00BFC4
#00BFC4 0.451064856296092 0.635959795387238 2 #00BFC4
#00BFC4 0.542732097318905 0.496859014628018 2 #00BFC4
#00BFC4 0.353539182576332 0.588994585539501 2 #00BFC4
#00BFC4 0.484147770349438 0.817538664034222 2 #00BFC4
#00BFC4 0.365083741126198 0.693394956474917 2 #00BFC4
#00BFC4 0.308050175752981 0.770723024918484 2 #00BFC4
#00BFC4 0.254635054104349 0.678437883275001 2 #00BFC4
#00BFC4 0.558584326969467 0.597968829459451 2 #00BFC4
#00BFC4 0.520332207595286 0.531559424451823 2 #00BFC4
#00BFC4 0.364566820594114 0.66781836130306 2 #00BFC4
#00BFC4 0.550658212144186 0.619207873403332 2 #00BFC4
#00BFC4 0.47760011027638 0.443761404768315 2 #00BFC4
#00BFC4 0.553415121648632 0.527670585419845 2 #00BFC4
#00BFC4 0.374388310703701 0.589443297735499 2 #00BFC4
#00BFC4 0.46881246123096 0.415492536420473 2 #00BFC4
#00BFC4 0.563581225446275 0.383185258308654 2 #00BFC4
#00BFC4 0.0931835412502584 0.579721200155554 2 #00BFC4
#00BFC4 0.164518574677786 0.417137814472464 2 #00BFC4
#00BFC4 0.346819215659246 0.583759609919531 2 #00BFC4
#00BFC4 0.28254876283686 0.432394029136379 2 #00BFC4
#00BFC4 0.421600385967331 0.372715307068713 2 #00BFC4
#00BFC4 0.372148321731339 0.617712166083341 2 #00BFC4
#00BFC4 0.3712867875112 0.745296000478626 2 #00BFC4
#00BFC4 0.196739954510993 0.506431541475964 2 #00BFC4
#00BFC4 0.637328554690192 0.376454575368692 2 #00BFC4
#00BFC4 0.799124681232338 0.436282868168357 2 #00BFC4
#00BFC4 0.56237507753808 0.470384995064166 2 #00BFC4
#00BFC4 0.270831897442966 0.532905561039816 2 #00BFC4
#00BFC4 0.189503067061824 0.705659756498848 2 #00BFC4
#F8766D 0.625267075608243 0.700125639414879 2 #F8766D
#00BFC4 0.590461093114618 0.679036166202997 2 #00BFC4
#00BFC4 0.459680198497484 0.514059648807921 2 #00BFC4
#00BFC4 0.437452615617892 0.602455951419426 2 #00BFC4
#00BFC4 0.666448411330898 0.484594214604086 2 #00BFC4
#00BFC4 0.383348266593149 0.650767297855156 2 #00BFC4
#00BFC4 0.557378179061272 0.572541805019594 2 #00BFC4
#00BFC4 0.47760011027638 0.489978760956056 2 #00BFC4
#00BFC4 0.588048797298229 0.64104520027521 2 #00BFC4
#00BFC4 0.327176235440072 0.60170809775943 2 #00BFC4
#00BFC4 0.309256323661176 0.495512878040025 2 #00BFC4
#00BFC4 0.43366186504928 0.422671931556433 2 #00BFC4
#00BFC4 0.547212075263629 0.634314517335248 2 #00BFC4
#00BFC4 0.464332483286236 0.430599180352389 2 #00BFC4
#00BFC4 0.509821490109587 0.458120195040234 2 #00BFC4
#00BFC4 0.419532703838996 0.526474019563852 2 #00BFC4
#00BFC4 0.578055000344614 0.413548116904484 2 #00BFC4
#00BFC4 0.298056378799366 0.510021239043944 2 #00BFC4
#00BFC4 0.305120959404508 0.6606389661671 2 #00BFC4
#00BFC4 0.421428079123303 0.65719883933112 2 #00BFC4
#00BFC4 0.700565166448411 0.514957073199916 2 #00BFC4
#00BFC4 0.394375904610931 0.623395853899309 2 #00BFC4
#00BFC4 0.342683851402578 0.519294624427892 2 #00BFC4
#00BFC4 0.418671169618857 0.689954829638936 2 #00BFC4
#00BFC4 0.192776897098353 0.543973795207754 2 #00BFC4
#00BFC4 0.570473499207389 0.50897424391995 2 #00BFC4
#00BFC4 0.599421049004066 0.393804780280595 2 #00BFC4
#00BFC4 0.408332758977187 0.416539531544467 2 #00BFC4
#00BFC4 0.768970983527466 0.558482156211672 2 #00BFC4
#00BFC4 0.288062581845751 0.500747853659996 2 #00BFC4
#00BFC4 0.628196291956716 0.709399024798827 2 #00BFC4
#00BFC4 0.356813012612861 0.469337999940172 2 #00BFC4
#00BFC4 0.35284995520022 0.58211433186754 2 #00BFC4
#00BFC4 0.609587152801709 0.583610039187532 2 #00BFC4
#00BFC4 0.512406092770005 0.614122468515361 2 #00BFC4
#00BFC4 0.673340685092012 0.200708965269676 2 #00BFC4
#00BFC4 0.31132400578951 0.514957073199916 2 #00BFC4
#00BFC4 0.380763663932731 0.415492536420473 2 #00BFC4
#00BFC4 0.468984768074988 0.483696790212091 2 #00BFC4
#00BFC4 0.596664139499621 0.437629004756349 2 #00BFC4
#00BFC4 0.350954579915914 0.747389990726614 2 #00BFC4
#00BFC4 0.593734923151148 0.497307726824015 2 #00BFC4
#00BFC4 0.445034116755118 0.302267492297107 2 #00BFC4
#00BFC4 0.629230133020884 0.568054683059619 2 #00BFC4
#00BFC4 0.696774415879799 0.633417092943253 2 #00BFC4
#00BFC4 0.370425253291061 0.494465882916031 2 #00BFC4
#00BFC4 0.466227858570542 0.519743336623889 2 #00BFC4
#00BFC4 0.584947274105727 0.40532172664453 2 #00BFC4
#00BFC4 0.48242470190916 0.653310000299141 2 #00BFC4
#00BFC4 0.416431180646495 0.272353345897275 2 #00BFC4
#00BFC4 0.487766214074023 0.437629004756349 2 #00BFC4
#00BFC4 0.471052450203322 0.344446438720871 2 #00BFC4
#00BFC4 0.344234612998828 0.363142780220766 2 #00BFC4
#00BFC4 0.476738576056241 0.425364204732418 2 #00BFC4
#00BFC4 0.490867737266524 0.63027610757127 2 #00BFC4
#00BFC4 0.267385760562409 0.508675102455951 2 #00BFC4
#00BFC4 0.42246192018747 0.428056477908403 2 #00BFC4
#00BFC4 0.240505892894066 0.545170361063747 2 #00BFC4
#00BFC4 0.261355021021435 0.415043824224476 2 #00BFC4
#F8766D 0.509649183265559 0.252161297077388 2 #F8766D
#00BFC4 0.529636777172789 0.443611834036316 2 #00BFC4
#00BFC4 0.485870838789717 0.831448742110144 2 #00BFC4
#00BFC4 0.412123509545799 0.807517424990278 2 #00BFC4
#00BFC4 0.581845750913226 0.718373268718777 2 #00BFC4
#00BFC4 0.491040044110552 0.459765473092225 2 #00BFC4
#00BFC4 0.563408918602247 0.526623590295851 2 #00BFC4
#00BFC4 0.405231235784685 0.455577492596249 2 #00BFC4
#00BFC4 0.299262526707561 0.493119746328038 2 #00BFC4
#00BFC4 0.455717141084844 0.568952107451614 2 #00BFC4
#00BFC4 0.385932869253567 0.415941248616471 2 #00BFC4
#00BFC4 0.285994899717417 0.668117502767058 2 #00BFC4
#F8766D 0.361982217933696 0.541580663495767 2 #F8766D
#00BFC4 0.466744779102626 0.330237219180951 2 #00BFC4
#00BFC4 0.499827693155972 0.463205599928206 2 #00BFC4
#00BFC4 0.222758287959198 0.655852702743127 2 #00BFC4
#00BFC4 0.482941622441243 0.504038409763977 2 #00BFC4
#00BFC4 0.270142670066855 0.621601005115319 2 #00BFC4
#F8766D 0.417465021710662 0.406667863232523 2 #F8766D
#00BFC4 0.664897649734647 0.518995482963894 2 #00BFC4
#00BFC4 0.482597008753188 0.427458194980406 2 #00BFC4
#00BFC4 0.547556688951685 0.495213736576027 2 #00BFC4
#00BFC4 0.419188090150941 0.464103024320201 2 #00BFC4
#00BFC4 0.437108001929837 0.428056477908403 2 #00BFC4
#00BFC4 0.346819215659246 0.424466780340423 2 #00BFC4
#00BFC4 0.447101798883452 0.505234975619971 2 #00BFC4
#00BFC4 0.381625198152871 0.454530497472255 2 #00BFC4
#00BFC4 0.249982769315597 0.618609590475336 2 #00BFC4
#F8766D 0.537907505686126 0.412800263244488 2 #F8766D
#00BFC4 0.458474050589289 0.436282868168357 2 #00BFC4
#00BFC4 0.370425253291061 0.49820515121601 2 #00BFC4
#00BFC4 0.74708801433593 0.324852672828981 2 #00BFC4
#00BFC4 0.565476600730581 0.593182566035478 2 #00BFC4
#00BFC4 0.537045971465987 0.587798019683508 2 #00BFC4
#00BFC4 0.466917085946654 0.436731580364354 2 #00BFC4
#00BFC4 0.4424495140947 0.632370097819259 2 #00BFC4
#00BFC4 0.733131159969674 0.626237697807293 2 #00BFC4
#00BFC4 0.378179061272314 0.555789883035688 2 #00BFC4
#00BFC4 0.455027913708732 0.559080439139669 2 #00BFC4
#F8766D 0.489489282514301 0.386475814412636 2 #F8766D
#00BFC4 0.661623819698118 0.734078195578689 2 #00BFC4
#00BFC4 0.531015231925012 0.641942624667205 2 #00BFC4
#00BFC4 0.624405541388104 0.481901941428101 2 #00BFC4
#00BFC4 0.488972361982218 0.40532172664453 2 #00BFC4
#00BFC4 0.383865187125233 0.344296867988872 2 #00BFC4
#00BFC4 0.4152250327383 0.503888839031978 2 #00BFC4
#00BFC4 0.335791577641464 0.493269317060038 2 #00BFC4
#00BFC4 0.426769591288166 0.621601005115319 2 #00BFC4
#00BFC4 0.249810462471569 0.59288342457148 2 #00BFC4
#00BFC4 0.669377627679371 0.68382242962697 2 #00BFC4
#00BFC4 0.482941622441243 0.199213257949684 2 #00BFC4
#00BFC4 0.375766765455924 0.634314517335248 2 #00BFC4
#00BFC4 0.296505617203115 0.610233629483383 2 #00BFC4
#00BFC4 0.558928940657523 0.471132848724162 2 #00BFC4
#00BFC4 0.38644978978565 0.547413922043734 2 #00BFC4
#00BFC4 0.523089117099731 0.436881151096353 2 #00BFC4
#00BFC4 0.456406368460955 0.423868497412426 2 #00BFC4
#00BFC4 0.605451788545041 0.650617727123156 2 #00BFC4
#00BFC4 0.533772141429458 0.464103024320201 2 #00BFC4
#00BFC4 0.35284995520022 0.38931765832062 2 #00BFC4
#00BFC4 0.483803156661383 0.703266624786862 2 #00BFC4
#00BFC4 0.380419050244676 0.575682790391576 2 #00BFC4
#00BFC4 0.423668068095665 0.650468156391157 2 #00BFC4
#00BFC4 0.305465573092563 0.587199736755512 2 #00BFC4
#00BFC4 0.429871114480667 0.510021239043944 2 #00BFC4
#00BFC4 0.409711213729409 0.663779951539083 2 #00BFC4
#00BFC4 0.600454890068234 0.610383200215382 2 #00BFC4
#F8766D 0.597008753187677 0.493718029256035 3 #F8766D
#F8766D 0.388172858225929 0.263528672709324 3 #F8766D
#F8766D 0.565304293886553 0.307801609381076 3 #F8766D
#F8766D 0.53601213040182 0.461560321876215 3 #F8766D
#F8766D 0.548418223171824 0.388569804660624 3 #F8766D
#F8766D 0.498104624715694 0.516303209787909 3 #F8766D
#F8766D 0.432455717141085 0.446752819408298 3 #F8766D
#F8766D 0.635433179405886 0.43209488767238 3 #F8766D
#F8766D 0.529119856640706 0.612028478267372 3 #F8766D
#00BFC4 0.199669170859466 0.600361961171438 3 #00BFC4
#F8766D 0.538596733062237 0.545918214723743 3 #F8766D
#F8766D 0.46484940381832 0.572242663555595 3 #F8766D
#00BFC4 0.199152250327383 0.486089921924078 3 #00BFC4
#F8766D 0.582018057757254 0.620703580723324 3 #F8766D
#F8766D 0.502584602660418 0.492671034132041 3 #F8766D
#00BFC4 0.327520849128127 0.412800263244488 3 #00BFC4
#F8766D 0.73743883107037 0.358057375332795 3 #F8766D
#00BFC4 0.167275484182232 0.397394477848575 3 #00BFC4
#F8766D 0.570128885519333 0.384830536360645 3 #F8766D
#F8766D 0.574608863464057 0.421325794968441 3 #F8766D
#F8766D 0.166758563650148 0.617263453887343 3 #F8766D
#F8766D 0.582534978289338 0.581366478207544 3 #F8766D
#F8766D 0.30253635674409 0.370621316820724 3 #F8766D
#F8766D 0.352505341512165 0.497606868288013 3 #F8766D
#F8766D 0.551002825832242 0.501046995123994 3 #F8766D
#00BFC4 0.347336136191329 0.403975590056538 3 #00BFC4
#F8766D 0.304604038872424 0.520491190283885 3 #F8766D
#00BFC4 0.453821765800538 0.414146399832481 3 #00BFC4
#F8766D 0.522055276035564 0.550854048879715 3 #F8766D
#F8766D 0.505686125852919 0.54816177570373 3 #F8766D
#F8766D 0.57753807981253 0.413248975440486 3 #F8766D
#F8766D 0.176063133227652 0.459765473092225 3 #F8766D
#F8766D 0.630780894617134 0.437030721828353 3 #F8766D
#00BFC4 0.220001378454752 0.584956175775524 3 #00BFC4
#F8766D 0.669377627679371 0.429253043764396 3 #F8766D
#F8766D 0.679199117788959 0.450492087708277 3 #F8766D
#F8766D 0.439520297746226 0.349830985072841 3 #F8766D
#F8766D 0.649906954304225 0.507777678063956 3 #F8766D
#F8766D 0.307533255220897 0.574785365999581 3 #F8766D
#F8766D 0.635260872561858 0.358805228992791 3 #F8766D
#F8766D 0.515507615962506 0.658395405187113 3 #F8766D
#F8766D 0.36008684264939 0.656450985671124 3 #F8766D
#F8766D 0.312013233165621 0.46963714140417 3 #F8766D
#F8766D 0.506547660073058 0.455577492596249 3 #F8766D
#F8766D 0.373009855951478 0.446603248676299 3 #F8766D
#00BFC4 0.374732924391757 0.435086302312363 3 #00BFC4
#F8766D 0.531704459301123 0.569251248915612 3 #F8766D
#F8766D 0.499655386311944 0.29284453618116 3 #F8766D
#F8766D 0.726411193052588 0.298079511801131 3 #F8766D
#F8766D 0.6998759390723 0.537841395195788 3 #F8766D
#F8766D 0.714005100282583 0.324254389900984 3 #F8766D
#F8766D 0.874250465228479 0.134149989530049 3 #F8766D
#F8766D 0.652146943276587 0.402031170540549 3 #F8766D
#F8766D 0.570818112895444 0.619058302671333 3 #F8766D
#F8766D 0.509476876421531 0.444210116964312 3 #F8766D
#F8766D 0.740884967950927 0.352224116784828 3 #F8766D
#F8766D 0.44641257150734 0.210131921385623 3 #F8766D
#F8766D 0.433317251361224 0.573289658679589 3 #F8766D
#F8766D 0.784650906334 0.206990936013641 3 #F8766D
#F8766D 0.410055827417465 0.439423853540339 3 #F8766D
#00BFC4 0.36008684264939 0.543824224475755 3 #00BFC4
#00BFC4 0.362843752153835 0.388868946124622 3 #00BFC4
#F8766D 0.490350816734441 0.593481707499476 3 #F8766D
#F8766D 0.608553311737542 0.556836878159682 3 #F8766D
#00BFC4 0.255668895168516 0.491474468276048 3 #00BFC4
#F8766D 0.340788476118271 0.494914595112028 3 #F8766D
#F8766D 0.583051898821421 0.608289209967394 3 #F8766D
#00BFC4 0.644393135295334 0.475470399952137 3 #00BFC4
#F8766D 0.722103521951892 0.47143199018816 3 #F8766D
#F8766D 0.521193741815425 0.502393131711987 3 #F8766D
#F8766D 0.663174581294369 0.410855843728499 3 #F8766D
#F8766D 0.73347577365773 0.238999072661462 3 #F8766D
#F8766D 0.606141015921152 0.390364653444614 3 #F8766D
#F8766D 0.673168378247984 0.295387238625146 3 #F8766D
#F8766D 0.709869736025915 0.338912321636902 3 #F8766D
#F8766D 0.543593631539045 0.491324897544049 3 #F8766D
#00BFC4 0.456750982149011 0.699676927218882 3 #00BFC4
#F8766D 0.575815011372252 0.464551736516198 3 #F8766D
#00BFC4 0.412468123233855 0.227033414101529 3 #00BFC4
#00BFC4 0.344234612998828 0.204597804301654 3 #00BFC4
#00BFC4 0.303742504652285 0.281327589817225 3 #00BFC4
#F8766D 0.769315597215521 0.305109336205091 3 #F8766D
#F8766D 0.761561789234268 0.547713063507733 3 #F8766D
#F8766D 0.69350058584327 0.356860809476802 3 #F8766D
#F8766D 0.562891998070163 0.497906009752012 3 #F8766D
#F8766D 0.519298366531119 0.403078165664543 3 #F8766D
#F8766D 0.266351919498242 0.379445990008675 3 #F8766D
#F8766D 0.532393686677235 0.591537287983487 3 #F8766D
#F8766D 0.563064304914191 0.360151365580783 3 #F8766D
#F8766D 0.571507340271556 0.566558975739627 3 #F8766D
#F8766D 0.470535529671239 0.51420921953992 3 #F8766D
#F8766D 0.5136122406782 0.583610039187532 3 #F8766D
#F8766D 0.628023985112689 0.499551287804002 3 #F8766D
#F8766D 0.690743676338824 0.386774955876634 3 #F8766D
#F8766D 0.214142945757805 0.604998653863412 3 #F8766D
#F8766D 0.187779998621545 0.327395375272967 3 #F8766D
#F8766D 0.555655110620994 0.580169912351551 3 #F8766D
#F8766D 0.546005927355435 0.598716683119447 3 #F8766D
#F8766D 0.71590047556689 0.308699033773071 3 #F8766D
#F8766D 0.540319801502516 0.541879804959765 3 #F8766D
#F8766D 0.560307395409746 0.311241736217057 3 #F8766D
#F8766D 0.450203322075953 0.479807951180113 3 #F8766D
#00BFC4 0.434695706113447 0.379894702204673 3 #00BFC4
#F8766D 0.644048521607278 0.448547668192288 3 #F8766D
#00BFC4 0.33768695292577 0.518098058571899 3 #00BFC4
#F8766D 0.77982631470122 0.250216877561399 3 #F8766D
#00BFC4 0.248776621407402 0.434637590116366 3 #00BFC4
#F8766D 0.253256599352126 0.466795297496186 3 #F8766D
#F8766D 0.66231304707423 0.432543599868378 3 #F8766D
#F8766D 0.620614790819491 0.397544048580574 3 #F8766D
#F8766D 0.556516644841133 0.418035238864459 3 #F8766D
#F8766D 0.664036115514508 0.48743605851207 3 #F8766D
#F8766D 0.672134537183817 0.401432887612552 3 #F8766D
#00BFC4 0.5711627265835 0.623694995363307 3 #00BFC4
#F8766D 0.851505961816803 0.299874360585121 3 #F8766D
#F8766D 0.627334757736577 0.65719883933112 3 #F8766D
#F8766D 0.644048521607278 0.268464506865297 3 #F8766D
#F8766D 0.616824040250879 0.65360914176314 3 #F8766D
#F8766D 0.556861258529189 0.500149570731999 3 #F8766D
#00BFC4 0.338203873457854 0.478312243860121 3 #00BFC4
#F8766D 0.388689778758012 0.478910526788118 3 #F8766D
#F8766D 0.332862361292991 0.661386819827096 3 #F8766D
#F8766D 0.589254945206424 0.575981931855574 3 #F8766D
#F8766D 0.267041146874354 0.458269765772234 3 #F8766D
#00BFC4 0.338720793989937 0.519444195159891 3 #00BFC4
#00BFC4 0.1714108484389 0.422821502288432 3 #00BFC4
#F8766D 0.615790199186712 0.415791677884472 3 #F8766D
#00BFC4 0.278930319112275 0.3929073558886 3 #00BFC4
#F8766D 0.478461644496519 0.506730682939962 3 #F8766D
#F8766D 0.440726445654421 0.50897424391995 3 #F8766D
#F8766D 0.547901302639741 0.48384636094409 3 #F8766D
#00BFC4 0.259459645737129 0.384082682700649 3 #00BFC4
#F8766D 0.525501412916121 0.615319034371354 3 #F8766D
#F8766D 0.749844923840375 0.414894253492477 3 #F8766D
#F8766D 0.501723068440278 0.517350204911903 3 #F8766D
#00BFC4 0.351988420980081 0.497457297556014 3 #00BFC4
#F8766D 0.625094768764215 0.576879356247569 3 #F8766D
#F8766D 0.319939347990902 0.535448263483801 3 #F8766D
#F8766D 0.506547660073058 0.515555356127913 3 #F8766D
#F8766D 0.552553587428493 0.854781776302013 3 #F8766D
#00BFC4 0.323557791715487 0.429851326692393 3 #00BFC4
#F8766D 0.268591908470604 0.496111160968022 3 #F8766D
#F8766D 0.470363222827211 0.504187980495976 3 #F8766D
#00BFC4 0.41367427114205 0.438227287684346 3 #00BFC4
#F8766D 0.581673444069199 0.396945765652577 3 #F8766D
#F8766D 0.676959128816597 0.498803434144007 3 #F8766D
#F8766D 0.643014680543111 0.302566633761106 3 #F8766D
#F8766D 0.627507064580605 0.444957970624308 3 #F8766D
#00BFC4 0.445551037287201 0.288506984953184 3 #00BFC4
#00BFC4 0.443483355158867 0.348634419216848 3 #00BFC4
#F8766D 0.872355089944173 0.189939872565736 3 #F8766D
#F8766D 0.259287338893101 0.345044721648868 3 #F8766D
#F8766D 0.651802329588531 0.407266146160519 3 #F8766D
#00BFC4 0.319767041146874 0.470833707260163 3 #00BFC4
#F8766D 0.670411468743539 0.394103921744593 3 #F8766D
#00BFC4 0.441932593562616 0.415342965688474 3 #00BFC4
#F8766D 0.625956302984355 0.370322175356726 3 #F8766D
#F8766D 0.568061203390999 0.578225492835562 3 #F8766D
#00BFC4 0.312185540009649 0.267267941009303 3 #00BFC4
#F8766D 0.655248466469088 0.457372341380239 3 #F8766D
#F8766D 0.536701357777931 0.456624487720243 3 #F8766D
#F8766D 0.310634778413399 0.442116126716324 3 #F8766D
#F8766D 0.346302295127162 0.509572526847946 3 #F8766D
#00BFC4 0.391102074574402 0.208187501869634 3 #00BFC4
#F8766D 0.548073609483769 0.493269317060038 3 #F8766D
#F8766D 0.4863877593218 0.590490292859493 3 #F8766D
#F8766D 0.615445585498656 0.480256663376111 3 #F8766D
#F8766D 0.297884071955338 0.564165844027641 3 #F8766D
#00BFC4 0.29374870769867 0.480555804840109 3 #00BFC4
#00BFC4 0.270142670066855 0.564016273295641 3 #00BFC4
#F8766D 0.469329381763044 0.384680965628646 3 #F8766D
#F8766D 0.614928664966573 0.474124263364145 3 #F8766D
#F8766D 0.683334482045627 0.427757336444405 3 #F8766D
#F8766D 0.56719966917086 0.506281970743965 3 #F8766D
#00BFC4 0.449858708387897 0.612925902659368 3 #00BFC4
#00BFC4 0.422289613343442 0.355514672888809 3 #00BFC4
#F8766D 0.496726169963471 0.382886116844656 3 #F8766D
#F8766D 0.462609414845958 0.531708995183822 3 #F8766D
#F8766D 0.522227582879592 0.723309102874749 3 #F8766D
#F8766D 0.588565717830312 0.466197014568189 3 #F8766D
#F8766D 0.448480253635674 0.523632175655868 3 #F8766D
#F8766D 0.180887724860431 0.456474916988244 3 #F8766D
#F8766D 0.30408711834034 0.409210565676508 3 #F8766D
#F8766D 0.65748845544145 0.556388165963684 3 #F8766D
#F8766D 0.584085739885588 0.494765024380029 3 #F8766D
#F8766D 0.647150044799779 0.386774955876634 3 #F8766D
#F8766D 0.228789027500172 0.596323551407461 3 #F8766D
#F8766D 0.628885519332828 0.534849980555805 3 #F8766D
#F8766D 0.363532979529947 0.579721200155554 3 #F8766D
#F8766D 0.336308498173547 0.463205599928206 3 #F8766D
#F8766D 0.487938520918051 0.432394029136379 3 #F8766D
#00BFC4 0.289957957130057 0.421176224236441 3 #00BFC4
#F8766D 0.554276655868771 0.39829190224057 3 #F8766D
#F8766D 0.560479702253774 0.451389512100272 3 #F8766D
#F8766D 0.601316424288373 0.519444195159891 3 #F8766D
#00BFC4 0.506203046385002 0.478312243860121 3 #00BFC4
#F8766D 0.509476876421531 0.527371443955847 3 #F8766D
#F8766D 0.552725894272521 0.65540399054713 3 #F8766D
#F8766D 0.383003652905093 0.521538185407879 3 #F8766D
#F8766D 0.492246192018747 0.455727063328248 3 #F8766D
#F8766D 0.434695706113447 0.592285141643483 3 #F8766D
#F8766D 0.693672892687297 0.424765921804421 3 #F8766D
#00BFC4 0.35284995520022 0.313335726465045 3 #00BFC4
#00BFC4 0.423495761251637 0.449295521852284 3 #00BFC4
#F8766D 0.451409469984148 0.48384636094409 3 #F8766D
#00BFC4 0.472430904955545 0.474872117024141 3 #00BFC4
#00BFC4 0.315803983734234 0.406368721768524 3 #00BFC4
#F8766D 0.499138465779861 0.474572975560142 3 #F8766D
#F8766D 0.570645806051416 0.512264800023931 3 #F8766D
#F8766D 0.692811358467158 0.418334380328457 3 #F8766D
#F8766D 0.514646081742367 0.444509258428311 3 #F8766D
#F8766D 0.646460817423668 0.406069580304526 3 #F8766D
#F8766D 0.469501688607071 0.642540907595202 3 #F8766D
#F8766D 0.53359983458543 0.488782195100063 3 #F8766D
#F8766D 0.333896202357158 0.378997277812678 3 #F8766D
#00BFC4 0.171755462126956 0.411304555924497 3 #00BFC4
#F8766D 0.689365221586602 0.353719824104819 3 #F8766D
#F8766D 0.272210352195189 0.455727063328248 3 #F8766D
#F8766D 0.674546833000207 0.60170809775943 3 #F8766D
#00BFC4 0.132297194844579 0.513311795147925 3 #00BFC4
#F8766D 0.522744503411676 0.592285141643483 3 #F8766D
#F8766D 0.657316148597422 0.511367375631936 3 #F8766D
#F8766D 0.436935695085809 0.36433934607676 3 #F8766D
#00BFC4 0.423151147563581 0.411154985192497 3 #00BFC4
#00BFC4 0.305982493624647 0.560127434263663 3 #00BFC4
#F8766D 0.488972361982218 0.346241287504861 3 #F8766D
#F8766D 0.318216279550624 0.419830087648449 3 #F8766D
#F8766D 0.503618443724585 0.534849980555805 3 #F8766D
#F8766D 0.922668688400303 0.493418887792037 3 #F8766D
#F8766D 0.253601213040182 0.49461545364803 3 #F8766D
#F8766D 0.71107588393411 0.552200185467708 3 #F8766D
#F8766D 0.605796402233097 0.547862634239732 3 #F8766D
#F8766D 0.475704734992074 0.67499775643902 3 #F8766D
#F8766D 0.547556688951685 0.472478985312154 3 #F8766D
#F8766D 0.550485905300159 0.45542792186425 3 #F8766D
#F8766D 0.384382107657316 0.695040234526908 3 #F8766D
#F8766D 0.682817561513543 0.427009482784409 3 #F8766D
#F8766D 0.508270728513337 0.361198360704777 3 #F8766D
#F8766D 0.587876490454201 0.402180741272548 3 #F8766D
#F8766D 0.699359018540216 0.326946663076969 3 #F8766D
#00BFC4 0.213970638913778 0.283272009333214 3 #00BFC4
#F8766D 0.670756082431594 0.34280116066888 3 #F8766D
#00BFC4 0.35526225101661 0.369424750964731 3 #00BFC4
#F8766D 0.453994072644565 0.531409853719824 3 #F8766D
#F8766D 0.488110827762079 0.784932244458404 3 #F8766D
#F8766D 0.787924736370529 0.435086302312363 3 #F8766D
#F8766D 0.781032462609415 0.405172155912531 3 #F8766D
#F8766D 0.60390102694879 0.647775883215172 3 #F8766D
#F8766D 0.3712867875112 0.3929073558886 3 #F8766D
#F8766D 0.287890275001723 0.497606868288013 3 #F8766D
#F8766D 0.759666413949962 0.438675999880343 3 #F8766D
#F8766D 0.530326004548901 0.567306829399623 3 #F8766D
#00BFC4 0.392308222482597 0.40891142421251 3 #00BFC4
#F8766D 0.573402715555862 0.476966107272129 3 #F8766D
#F8766D 0.600454890068234 0.341604594812887 3 #F8766D
#00BFC4 0.333034668137018 0.456774058452242 3 #00BFC4
#00BFC4 0.387655937693845 0.458419336504233 3 #00BFC4
#F8766D 0.31614859742229 0.430449609620389 3 #F8766D
#00BFC4 0.472775518643601 0.569400819647611 3 #00BFC4
#F8766D 0.439175684058171 0.604101229471417 3 #F8766D
#F8766D 0.285822592873389 0.368826468036735 3 #F8766D
#F8766D 0.749500310152319 0.338014897244907 3 #F8766D
#F8766D 0.589082638362396 0.419231804720452 3 #F8766D
#F8766D 0.531015231925012 0.404424302252535 3 #F8766D
#F8766D 0.574264249776001 0.488632624368064 3 #F8766D
#00BFC4 0.402302019436212 0.292994106913159 3 #00BFC4
#00BFC4 0.455027913708732 0.292395823985163 3 #00BFC4
#00BFC4 0.333206974981046 0.258293697089354 3 #00BFC4
#F8766D 0.511027638017782 0.449893804780281 3 #F8766D
#00BFC4 0.450547935764009 0.35536510215681 3 #00BFC4
#F8766D 0.20656144462058 0.52497831224386 3 #F8766D
#F8766D 0.415052725894273 0.399338897364564 3 #F8766D
#F8766D 0.505686125852919 0.497158156092016 3 #F8766D
#F8766D 0.610965607553932 0.499401717072003 3 #F8766D
#F8766D 0.378179061272314 0.30540847766909 3 #F8766D
#F8766D 0.642153146322972 0.406069580304526 3 #F8766D
#F8766D 0.736232683162175 0.475320829220138 3 #F8766D
#F8766D 0.559618168033634 0.441667414520327 3 #F8766D
#F8766D 0.61113791439796 0.293293248377158 3 #F8766D
#F8766D 0.704872837549107 0.331284214304945 3 #F8766D
#F8766D 0.567027362326832 0.532905561039816 3 #F8766D
#F8766D 0.705906678613275 0.308699033773071 3 #F8766D
#F8766D 0.551864360052381 0.371817882676718 3 #F8766D
#F8766D 0.521021434971397 0.434039307188369 3 #F8766D
#F8766D 0.340443862430216 0.430449609620389 3 #F8766D
#F8766D 0.615617892342684 0.397095336384576 3 #F8766D
#F8766D 0.694706733751465 0.535298692751802 3 #F8766D
#F8766D 0.612688675994211 0.319916838673008 3 #F8766D
#F8766D 0.746743400647874 0.318421131353017 3 #F8766D
#F8766D 0.608897925425598 0.351177121660833 3 #F8766D
#F8766D 0.292887173478531 0.398591043704568 3 #F8766D
#F8766D 0.622510166103798 0.431795746208382 3 #F8766D
#F8766D 0.689020607898546 0.252460438541386 3 #F8766D
#F8766D 0.712971259218416 0.362993209488767 3 #F8766D
#F8766D 0.53997518781446 0.440470848664333 3 #F8766D
#F8766D 0.633882417809635 0.547413922043734 3 #F8766D
#00BFC4 0.280825694396581 0.540533668371773 3 #00BFC4
#00BFC4 0.156075539320422 0.447949385264291 3 #00BFC4
#F8766D 0.279274932800331 0.437030721828353 3 #F8766D
#F8766D 0.491901578330691 0.549208770827724 3 #F8766D
#00BFC4 0.162278585705424 0.413548116904484 3 #00BFC4
#00BFC4 0.325453166999793 0.483098507284095 3 #00BFC4
#00BFC4 0.38644978978565 0.399039755900565 3 #00BFC4
#F8766D 0.452271004204287 0.625190702683299 3 #F8766D
#F8766D 0.687297539458267 0.413398546172485 3 #F8766D
#F8766D 0.215693707354056 0.629229112447276 3 #F8766D
#F8766D 0.38403749396926 0.457671482844237 3 #F8766D
#F8766D 0.479840099248742 0.521089473211882 3 #F8766D
#00BFC4 0.334413122889241 0.524080887851865 3 #00BFC4
#00BFC4 0.344406919842856 0.462906458464208 3 #00BFC4
#F8766D 0.662140740230202 0.489081336564061 3 #F8766D
#F8766D 0.584602660417672 0.325750097220976 3 #F8766D
#00BFC4 0.452098697360259 0.451539082832271 3 #00BFC4
#F8766D 0.33131159969674 0.455128780400251 3 #F8766D
#00BFC4 0.352505341512165 0.454081785276257 3 #00BFC4
#00BFC4 0.345096147218968 0.316327141105029 3 #00BFC4
#F8766D 0.385243641877455 0.494765024380029 3 #F8766D
#F8766D 0.690399062650769 0.653908283227138 3 #F8766D
#F8766D 0.499310772623889 0.765488049298513 3 #F8766D
#F8766D 0.646805431111724 0.373313589996709 3 #F8766D
#F8766D 0.575470397684196 0.429701755960394 3 #F8766D
#F8766D 0.686952925770212 0.447949385264291 3 #F8766D
#F8766D 0.459335584809429 0.669912351551048 3 #F8766D
#F8766D 0.460886346405679 0.404125160788537 3 #F8766D
#F8766D 0.578744227720725 0.450641658440276 3 #F8766D
#F8766D 0.65266386380867 0.455876634060247 3 #F8766D
#00BFC4 0.449686401543869 0.665574800323073 3 #00BFC4
#F8766D 0.295644082982976 0.549657483023722 3 #F8766D
#F8766D 0.234302846509063 0.408163570552514 3 #F8766D
#F8766D 0.550141291612103 0.602755092883425 3 #F8766D
#F8766D 0.634054724653663 0.369125609500733 3 #F8766D
#F8766D 0.573919636087945 0.484145502408089 3 #F8766D
#F8766D 0.719518919291474 0.564016273295641 3 #F8766D
#F8766D 0.504652284788752 0.675745610099016 3 #F8766D
#F8766D 0.615790199186712 0.544871219599749 3 #F8766D
#F8766D 0.544627472603212 0.639399922223219 3 #F8766D
#F8766D 0.457267902681094 0.615169463639355 3 #F8766D
#F8766D 0.574436556620029 0.498653863412007 3 #F8766D
#F8766D 0.548073609483769 0.481154087768105 3 #F8766D
#F8766D 0.538079812530154 0.354617248496814 3 #F8766D
#F8766D 0.309428630505204 0.291797541057166 3 #F8766D
#F8766D 0.648356192707974 0.716279278470789 3 #F8766D
#F8766D 0.307877868908953 0.65540399054713 3 #F8766D
#F8766D 0.490350816734441 0.475619970684136 3 #F8766D
#00BFC4 0.262044248397546 0.523482604923868 3 #00BFC4
#F8766D 0.409021986353298 0.658096263723114 3 #F8766D
#F8766D 0.634227031497691 0.519145053695893 3 #F8766D
#00BFC4 0.285477979185333 0.437928146220348 3 #00BFC4
#F8766D 0.389723619822179 0.546067785455742 3 #F8766D
#F8766D 0.6726514577159 0.311391306949056 3 #F8766D
#F8766D 0.560307395409746 0.457372341380239 3 #F8766D
#00BFC4 0.263595009993797 0.402330312004547 3 #00BFC4
#00BFC4 0.351816114136053 0.213272906757606 3 #00BFC4
#F8766D 0.33527465710938 0.409808848604505 3 #F8766D
#F8766D 0.617168653938934 0.335173053336923 3 #F8766D
#F8766D 0.686436005238128 0.579122917227557 3 #F8766D
#00BFC4 0.338720793989937 0.45527835113225 3 #00BFC4
#F8766D 0.727961954648839 0.405172155912531 3 #F8766D
#00BFC4 0.558584326969467 0.477713960932125 3 #00BFC4
#F8766D 0.602694879040595 0.462906458464208 3 #F8766D
#F8766D 0.747777241712041 0.180217774985791 3 #F8766D
#F8766D 0.379212902336481 0.448098955996291 3 #F8766D
#00BFC4 0.270314976910883 0.585554458703521 3 #00BFC4
#00BFC4 0.23774898338962 0.521239043943881 3 #00BFC4
#00BFC4 0.300296367771728 0.60350294654342 3 #00BFC4
#00BFC4 0.372665242263423 0.494166741452033 3 #00BFC4
#F8766D 0.680749879385209 0.505982829279966 3 #F8766D
#F8766D 0.663519194982425 0.402928594932544 3 #F8766D
#F8766D 0.747777241712041 0.402031170540549 3 #F8766D
#F8766D 0.748466469088152 0.451090370636274 3 #F8766D
#F8766D 0.315631676890206 0.526922731759849 3 #F8766D
#F8766D 0.486043145633745 0.434488019384367 3 #F8766D
#F8766D 0.628368598800744 0.363890633880762 3 #F8766D
#F8766D 0.627851678268661 0.442415268180322 3 #F8766D
#F8766D 0.497070783651527 0.420727512040444 3 #F8766D
#00BFC4 0.281514921772693 0.379894702204673 3 #00BFC4
#F8766D 0.590461093114618 0.583011756259535 3 #F8766D
#F8766D 0.648011579019919 0.364040204612761 3 #F8766D
#F8766D 0.508098421669309 0.468590146280176 3 #F8766D
#F8766D 0.786718588462334 0.352672828980825 3 #F8766D
#F8766D 0.604245640636846 0.440620419396332 3 #F8766D
#F8766D 0.605107174856985 0.374510155852703 3 #F8766D
#F8766D 0.498276931559722 0.478910526788118 3 #F8766D
#00BFC4 0.131263353780412 0.449145951120285 3 #00BFC4
#F8766D 0.585981115169894 0.486837775584074 3 #F8766D
#F8766D 0.539802880970432 0.727497083370726 3 #F8766D
#00BFC4 0.286167206561445 0.304810194741093 3 #00BFC4
#F8766D 0.457267902681094 0.457521912112238 3 #F8766D
#00BFC4 0.310807085257426 0.375407580244698 3 #00BFC4
#F8766D 0.72623888620856 0.556836878159682 3 #F8766D
#F8766D 0.738128058446481 0.334126058212929 3 #F8766D
#F8766D 0.661968433386174 0.410556702264501 3 #F8766D
#F8766D 0.547039768419602 0.490128331688055 3 #F8766D
#F8766D 0.38886208560204 0.498653863412007 3 #F8766D
#F8766D 0.35284995520022 0.302716204493105 3 #F8766D
#F8766D 0.744158797987456 0.453034790152263 3 #F8766D
#F8766D 0.579261148252809 0.446603248676299 3 #F8766D
#F8766D 0.614928664966573 0.581964761135541 3 #F8766D
#F8766D 0.645943896891584 0.518845912231894 3 #F8766D
#F8766D 0.609587152801709 0.357758233868797 3 #F8766D
#F8766D 0.671962230339789 0.437180292560352 3 #F8766D
#F8766D 0.716072782410917 0.467393580424183 3 #F8766D
#00BFC4 0.222241367427114 0.420877082772443 3 #00BFC4
#F8766D 0.583741126197532 0.562670136707649 3 #F8766D
#F8766D 0.897684196016266 0.252759580005385 3 #F8766D
#00BFC4 0.198290716107244 0.355514672888809 3 #00BFC4
#F8766D 0.580811909849059 0.48743605851207 3 #F8766D
#F8766D 0.341822317182438 0.395300487600586 3 #F8766D
#F8766D 0.706595905989386 0.337715755780909 3 #F8766D
#00BFC4 0.365256047970225 0.40352687786054 3 #00BFC4
#F8766D 0.682128334137432 0.418184809596458 3 #F8766D
#F8766D 0.760355641326073 0.384680965628646 3 #F8766D
#00BFC4 0.101454269763595 0.564764126955637 3 #00BFC4
#F8766D 0.741574195327038 0.438825570612343 3 #F8766D
#F8766D 0.614928664966573 0.403377307128541 3 #F8766D
#F8766D 0.533082914053346 0.547862634239732 3 #F8766D
#F8766D 0.654214625404921 0.458419336504233 3 #F8766D
#00BFC4 0.312185540009649 0.4464536779443 3 #00BFC4
#F8766D 0.577710386656558 0.435535014508361 3 #F8766D
#00BFC4 0.435384933489558 0.224640282389542 3 #00BFC4
#00BFC4 0.384726721345372 0.359104370456789 3 #00BFC4
#F8766D 0.696774415879799 0.569999102575608 3 #F8766D
#00BFC4 0.552553587428493 0.385428819288642 3 #00BFC4
#00BFC4 0.310979392101454 0.347288282628855 3 #00BFC4
#00BFC4 0.0762974705355296 0.617263453887343 3 #00BFC4
#F8766D 0.597697980563788 0.564016273295641 3 #F8766D
#00BFC4 0.282721069680888 0.218956594573574 3 #00BFC4
#F8766D 0.539285960438349 0.531559424451823 3 #F8766D
#00BFC4 0.326142394375905 0.513012653683927 3 #00BFC4
#00BFC4 0.280998001240609 0.403078165664543 3 #00BFC4
#F8766D 0.566510441794748 0.512713512219929 3 #F8766D
#F8766D 0.478117030808464 0.587349307487511 3 #F8766D
#F8766D 0.660073058101868 0.527072302491848 3 #F8766D
#F8766D 0.565131987042525 0.521089473211882 3 #F8766D
#00BFC4 0.483458542973327 0.248721170241407 3 #00BFC4
#F8766D 0.235681301261286 0.629528253911275 3 #F8766D
#F8766D 0.496898476807499 0.613374614855365 3 #F8766D
#F8766D 0.521021434971397 0.56955039037961 3 #F8766D
#F8766D 0.338720793989937 0.527521014687846 3 #F8766D
#F8766D 0.686436005238128 0.370172604624727 3 #F8766D
#F8766D 0.599765662692122 0.531559424451823 3 #F8766D
#00BFC4 0.34009924874216 0.419381375452451 3 #00BFC4
#F8766D 0.798090840168172 0.348036136288851 3 #F8766D
#F8766D 0.608897925425598 0.349830985072841 3 #F8766D
#F8766D 0.844096767523606 0.287160848365192 3 #F8766D
#F8766D 0.705217451237163 0.489679619492058 3 #F8766D
#F8766D 0.590805706802674 0.502243560979987 3 #F8766D
#00BFC4 0.228099800124061 0.404424302252535 3 #00BFC4
#F8766D 0.642842373699083 0.446304107212301 3 #F8766D
#F8766D 0.609587152801709 0.64104520027521 3 #F8766D
#F8766D 0.559790474877662 0.411902838852493 3 #F8766D
#F8766D 0.295127162450893 0.515405785395914 3 #F8766D
#00BFC4 0.410400441105521 0.452586077956265 3 #00BFC4
#F8766D 0.744158797987456 0.402031170540549 3 #F8766D
#F8766D 0.587531876766145 0.383035687576655 3 #F8766D
#F8766D 0.60631332276518 0.570148673307607 3 #F8766D
#F8766D 0.648873113240058 0.286712136169194 3 #F8766D
#F8766D 0.667999172927149 0.469337999940172 3 #F8766D
#F8766D 0.572368874491695 0.43568458524036 3 #F8766D
#00BFC4 0.292025639258391 0.319916838673008 3 #00BFC4
#F8766D 0.602177958508512 0.375856292440695 3 #F8766D
#F8766D 0.558928940657523 0.506132400011966 3 #F8766D
#00BFC4 0.280653387552554 0.35536510215681 3 #00BFC4
#F8766D 0.512578399614033 0.505085404887971 3 #F8766D
#F8766D 0.601661037976428 0.484444643872087 3 #F8766D
#00BFC4 0.235681301261286 0.412351551048491 3 #00BFC4
#F8766D 0.538769039906265 0.587798019683508 3 #F8766D
#F8766D 0.805500034461369 0.542926800083759 3 #F8766D
#F8766D 0.514818388586395 0.577028926979569 3 #F8766D
#F8766D 0.578227307188641 0.541431092763768 3 #F8766D
#F8766D 0.375422151767868 0.470833707260163 3 #F8766D
#00BFC4 0.324591632779654 0.500897424391995 3 #00BFC4
#F8766D 0.631470121993246 0.480854946304107 3 #F8766D
#F8766D 0.847715211248191 0.523033892727871 3 #F8766D
#00BFC4 0.202770694051968 0.290451404469173 3 #00BFC4
#F8766D 0.327865462816183 0.474572975560142 3 #F8766D
#F8766D 0.294437935074781 0.610084058751383 3 #F8766D
#F8766D 0.383003652905093 0.757560800502558 3 #F8766D
#F8766D 0.707974360741609 0.253806575129379 3 #F8766D
#F8766D 0.40402508787649 0.552050614735708 3 #F8766D
#F8766D 0.470535529671239 0.559529151335666 3 #F8766D
#F8766D 0.604417947480874 0.479957521912112 3 #F8766D
#F8766D 0.659039217037701 0.415193394956475 3 #F8766D
#F8766D 0.588910331518368 0.41788566813246 3 #F8766D
#00BFC4 0.312702460541733 0.445705824284304 3 #00BFC4
#00BFC4 0.213281411537666 0.553845463519698 3 #00BFC4
#F8766D 0.567027362326832 0.476068682880134 3 #F8766D
#F8766D 0.675408367220346 0.49641030243202 3 #F8766D
#F8766D 0.548590530015852 0.56790511232762 3 #F8766D
#F8766D 0.357846853677028 0.373762302192707 3 #F8766D
#00BFC4 0.153490936660004 0.433291453528374 3 #00BFC4
#F8766D 0.356468398924805 0.430599180352389 3 #F8766D
#00BFC4 0.365256047970225 0.521239043943881 3 #00BFC4
#00BFC4 0.211730649941416 0.534550839091806 3 #00BFC4
#F8766D 0.580639603005031 0.663032097879087 3 #F8766D
#F8766D 0.301674822523951 0.53215770737982 3 #F8766D
#F8766D 0.294610241918809 0.577477639175566 3 #F8766D
#F8766D 0.297884071955338 0.443611834036316 3 #F8766D
#F8766D 0.622165552415742 0.433291453528374 3 #F8766D
#F8766D 0.314425528982011 0.636258936851237 3 #F8766D
#F8766D 0.447963333103591 0.475619970684136 3 #F8766D
#F8766D 0.491384657798608 0.668117502767058 3 #F8766D
#00BFC4 0.210869115721276 0.651365580783152 3 #00BFC4
#F8766D 0.290302570818113 0.510469951239941 3 #F8766D
#00BFC4 0.612171755462127 0.65719883933112 4 #00BFC4
#F8766D 0.569095044455166 0.420428370576446 4 #F8766D
#00BFC4 0.537907505686126 0.58570402943552 4 #00BFC4
#F8766D 0.694879040595493 0.430748751084388 4 #F8766D
#00BFC4 0.485009304569577 0.646728888091178 4 #00BFC4
#00BFC4 0.754152594941071 0.363890633880762 4 #00BFC4
#F8766D 0.58873802467434 0.553396751323701 4 #F8766D
#00BFC4 0.450547935764009 0.662882527147088 4 #00BFC4
#00BFC4 0.612688675994211 0.571943522091597 4 #00BFC4
#F8766D 0.465883244882487 0.54277722935176 4 #F8766D
#00BFC4 0.412468123233855 0.802731161566305 4 #00BFC4
#00BFC4 0.655765387001172 0.404424302252535 4 #00BFC4
#F8766D 0.779481701013164 0.406368721768524 4 #F8766D
#F8766D 0.634054724653663 0.590041580663496 4 #F8766D
#00BFC4 0.609759459645737 0.734526907774687 4 #00BFC4
#F8766D 0.447791026259563 0.498653863412007 4 #F8766D
#00BFC4 0.763974085050658 0.513012653683927 4 #00BFC4
#00BFC4 0.397477427803432 0.558781297675671 4 #00BFC4
#00BFC4 0.442621820938728 0.571046097699602 4 #00BFC4
#00BFC4 0.503790750568613 0.551302761075713 4 #00BFC4
#00BFC4 0.686436005238128 0.581665619671543 4 #00BFC4
#00BFC4 0.669205320835344 0.45527835113225 4 #00BFC4
#00BFC4 0.624060927700048 0.549358341559724 4 #00BFC4
#00BFC4 0.495003101523192 0.525277453707858 4 #00BFC4
#00BFC4 0.506719966917086 0.633267522211254 4 #00BFC4
#00BFC4 0.481046247156937 0.467393580424183 4 #00BFC4
#00BFC4 0.469673995451099 0.525576595171857 4 #00BFC4
#00BFC4 0.621648631883658 0.488483053636064 4 #00BFC4
#F8766D 0.852712109724998 0.494166741452033 4 #F8766D
#00BFC4 0.59511337790337 0.51420921953992 4 #00BFC4
#F8766D 0.800847749672617 0.468141434084178 4 #F8766D
#00BFC4 0.480701633468881 0.547114780579736 4 #00BFC4
#F8766D 0.622510166103798 0.30002393131712 4 #F8766D
#00BFC4 0.577882693500586 0.47502168775614 4 #00BFC4
#F8766D 0.429698807636639 0.674698614975022 4 #F8766D
#F8766D 0.689537528430629 0.709548595530826 4 #F8766D
#F8766D 0.417120408022607 0.631472673427264 4 #F8766D
#00BFC4 0.77345096147219 0.450641658440276 4 #00BFC4
#F8766D 0.62716245089255 0.465897873104191 4 #F8766D
#00BFC4 0.608897925425598 0.536794400071794 4 #00BFC4
#F8766D 0.596319525811565 0.529016722007837 4 #F8766D
#00BFC4 0.731408091529396 0.722860390678752 4 #00BFC4
#F8766D 0.568578123923082 0.478162673128122 4 #F8766D
#F8766D 0.638362395754359 0.34100631188489 4 #F8766D
#00BFC4 0.533255220897374 0.442415268180322 4 #00BFC4
#F8766D 0.704183610172996 0.291647970325167 4 #F8766D
#00BFC4 0.394892825143015 0.613374614855365 4 #00BFC4
#00BFC4 0.676097594596457 0.565063268419636 4 #00BFC4
#F8766D 0.479840099248742 0.512115229291932 4 #F8766D
#00BFC4 0.774484802536357 0.578823775763558 4 #00BFC4
#F8766D 0.709180508649804 0.278934458105238 4 #F8766D
#00BFC4 0.494313874147081 0.651066439319154 4 #00BFC4
#F8766D 0.666793025018954 0.240046067785456 4 #F8766D
#00BFC4 0.540664415190571 0.502841843907984 4 #00BFC4
#00BFC4 0.407298917913019 0.528867151275838 4 #00BFC4
#00BFC4 0.200530705079606 0.284468575189207 4 #00BFC4
#00BFC4 0.535667516713764 0.459765473092225 4 #00BFC4
#00BFC4 0.804466193397202 0.351625833856831 4 #00BFC4
#F8766D 0.40488662209663 0.500299141463998 4 #F8766D
#F8766D 0.720380453511614 0.333079063088935 4 #F8766D
#00BFC4 0.666448411330898 0.317374136229023 4 #00BFC4
#00BFC4 0.658522296505617 0.472329414580155 4 #00BFC4
#00BFC4 0.404369701564546 0.597520117263454 4 #00BFC4
#00BFC4 0.518092218622924 0.424466780340423 4 #00BFC4
#00BFC4 0.145220208146668 0.562221424511652 4 #00BFC4
#00BFC4 0.64473774898339 0.570148673307607 4 #00BFC4
#00BFC4 0.792060100627197 0.552200185467708 4 #00BFC4
#00BFC4 0.636639327314081 0.621601005115319 4 #00BFC4
#00BFC4 0.380246743400648 0.528867151275838 4 #00BFC4
#00BFC4 0.296850230891171 0.560127434263663 4 #00BFC4
#F8766D 0.653870011716865 0.527670585419845 4 #F8766D
#00BFC4 0.606830243297264 0.599614107511442 4 #00BFC4
#F8766D 0.650940795368392 0.503440126835981 4 #F8766D
#00BFC4 0.611654834930043 0.382886116844656 4 #00BFC4
#00BFC4 0.566682748638776 0.572990517215591 4 #00BFC4
#00BFC4 0.57512578399614 0.329638936252954 4 #00BFC4
#00BFC4 0.489489282514301 0.502093990247988 4 #00BFC4
#00BFC4 0.32648700806396 0.420877082772443 4 #00BFC4
#00BFC4 0.521193741815425 0.486089921924078 4 #00BFC4
#00BFC4 0.497415397339582 0.307801609381076 4 #00BFC4
#00BFC4 0.565993521262665 0.468141434084178 4 #00BFC4
#00BFC4 0.772417120408023 0.260537258069341 4 #00BFC4
#F8766D 0.48483699772555 0.481901941428101 4 #F8766D
#00BFC4 0.904404162933352 0.0454545454545455 4 #00BFC4
#00BFC4 0.602694879040595 0.420877082772443 4 #00BFC4
#00BFC4 0.0454545454545454 0.408612282748512 4 #00BFC4
#F8766D 0.423495761251637 0.525127882975859 4 #F8766D
#F8766D 0.495864635743332 0.615019892907356 4 #F8766D
#00BFC4 0.53273830036529 0.633417092943253 4 #00BFC4
#00BFC4 0.14901095871528 0.640147775883215 4 #00BFC4
#00BFC4 0.543421324695017 0.699377785754883 4 #00BFC4
#F8766D 0.65266386380867 0.6607885368991 4 #F8766D
#00BFC4 0.570990419739472 0.542029375691765 4 #00BFC4
#F8766D 0.569439658143222 0.571644380627599 4 #F8766D
#00BFC4 0.56875043076711 0.440620419396332 4 #00BFC4
#00BFC4 0.16658625680612 0.593930419695474 4 #00BFC4
#00BFC4 0.585636501481839 0.476218253612133 4 #00BFC4
#00BFC4 0.573230408711834 0.613075473391367 4 #00BFC4
#F8766D 0.55996278172169 0.566409405007628 4 #F8766D
#00BFC4 0.546695154731546 0.601109814831434 4 #00BFC4
#00BFC4 0.401268178372045 0.623694995363307 4 #00BFC4
#00BFC4 0.444689503067062 0.418932663256454 4 #00BFC4
#F8766D 0.750017230684403 0.449893804780281 4 #F8766D
#00BFC4 0.173306223723206 0.446603248676299 4 #00BFC4
#00BFC4 0.410572747949549 0.54995662448772 4 #00BFC4
#00BFC4 0.597697980563788 0.482649795088097 4 #00BFC4
#00BFC4 0.420738851747191 0.553396751323701 4 #00BFC4
#00BFC4 0.374388310703701 0.781641688354423 4 #00BFC4
#00BFC4 0.419877317527052 0.449744234048281 4 #00BFC4
#00BFC4 0.45364945895651 0.678437883275001 4 #00BFC4
#00BFC4 0.376455992832035 0.517649346375901 4 #00BFC4
#00BFC4 0.403680474188435 0.472030273116157 4 #00BFC4
#00BFC4 0.188296919153629 0.467543151156182 4 #00BFC4
#00BFC4 0.344406919842856 0.538290107391786 4 #00BFC4
#00BFC4 0.554621269556827 0.634314517335248 4 #00BFC4
#00BFC4 0.548590530015852 0.341754165544886 4 #00BFC4
#F8766D 0.682989868357571 0.228379550689521 4 #F8766D
#00BFC4 0.564442759666414 0.419530946184451 4 #00BFC4
#F8766D 0.433834171893308 0.475619970684136 4 #F8766D
#00BFC4 0.650940795368392 0.611280624607377 4 #00BFC4
#00BFC4 0.546178234199462 0.542029375691765 4 #00BFC4
#00BFC4 0.465883244882487 0.498354721948009 4 #00BFC4
#00BFC4 0.664036115514508 0.219255736037572 4 #00BFC4
#00BFC4 0.579605761940864 0.595126985551467 4 #00BFC4
#00BFC4 0.281170308084637 0.451987795028269 4 #00BFC4
#F8766D 0.703322075952857 0.402629453468545 4 #F8766D
#F8766D 0.314597835826039 0.512713512219929 4 #F8766D
#00BFC4 0.547384382107657 0.534849980555805 4 #00BFC4
#00BFC4 0.465883244882487 0.680831014986987 4 #00BFC4
#00BFC4 0.56633813495072 0.783286966406413 4 #00BFC4
#00BFC4 0.295644082982976 0.625788985611295 4 #00BFC4
#00BFC4 0.10266041767179 0.434188877920368 4 #00BFC4
#F8766D 0.600971810600317 0.252909150737384 4 #F8766D
#00BFC4 0.416431180646495 0.464103024320201 4 #00BFC4
#00BFC4 0.462954028534013 0.586152741631517 4 #00BFC4
#00BFC4 0.694879040595493 0.52138861467588 4 #00BFC4
#00BFC4 0.444172582534978 0.416539531544467 4 #00BFC4
#00BFC4 0.599076435316011 0.325750097220976 4 #00BFC4
#00BFC4 0.569611964987249 0.349232702144844 4 #00BFC4
#00BFC4 0.551692053208353 0.430150468156391 4 #00BFC4
#00BFC4 0.664036115514508 0.512863082951928 4 #00BFC4
#F8766D 0.788269350058584 0.326946663076969 4 #F8766D
#F8766D 0.686436005238128 0.362394926560771 4 #F8766D
#00BFC4 0.648011579019919 0.508525531723952 4 #00BFC4
#00BFC4 0.631987042525329 0.513311795147925 4 #00BFC4
#F8766D 0.606485629609208 0.286263423973197 4 #F8766D
#00BFC4 0.452615617892343 0.545319931795746 4 #00BFC4
#00BFC4 0.726066579364532 0.50358969756798 4 #00BFC4
#F8766D 0.650251567992281 0.306605043525083 4 #F8766D
#F8766D 0.70470053070508 0.479658380448114 4 #F8766D
#F8766D 0.569095044455166 0.442116126716324 4 #F8766D
#00BFC4 0.498966158935833 0.380492985132669 4 #00BFC4
#00BFC4 0.593045695775036 0.545918214723743 4 #00BFC4
#00BFC4 0.494313874147081 0.675446468635017 4 #00BFC4
#00BFC4 0.376283685988007 0.581516048939543 4 #00BFC4
#00BFC4 0.587014956234062 0.528268868347842 4 #00BFC4
#00BFC4 0.226204424839755 0.714035717490801 4 #00BFC4
#00BFC4 0.377145220208147 0.61068234167938 4 #00BFC4
#00BFC4 0.660417671789923 0.357459092404798 4 #00BFC4
#00BFC4 0.425218829691915 0.59467827335547 4 #00BFC4
#00BFC4 0.518781445999035 0.562670136707649 4 #00BFC4
#00BFC4 0.602867185884623 0.465299590176194 4 #00BFC4
#00BFC4 0.428492659728444 0.55534117083969 4 #00BFC4
#00BFC4 0.414708112206217 0.732432917526698 4 #00BFC4
#F8766D 0.607174856985319 0.595874839211463 4 #F8766D
#00BFC4 0.293921014542698 0.699676927218882 4 #00BFC4
#F8766D 0.616134812874767 0.395450058332585 4 #F8766D
#00BFC4 0.407988145289131 0.581216907475545 4 #00BFC4
#00BFC4 0.476738576056241 0.719420263842771 4 #00BFC4
#00BFC4 0.434695706113447 0.503290556103982 4 #00BFC4
#00BFC4 0.743641877455372 0.372565736336714 4 #00BFC4
#00BFC4 0.598387207939899 0.58390918065153 4 #00BFC4
#00BFC4 0.61355021021435 0.601259385563433 4 #00BFC4
#00BFC4 0.5 0.669164497891053 4 #00BFC4
#00BFC4 0.371114480667172 0.532755990307817 4 #00BFC4
#00BFC4 0.537907505686126 0.719121122378773 4 #00BFC4
#00BFC4 0.489316975670274 0.45183822429627 4 #00BFC4
#00BFC4 0.317182438486457 0.611729336803374 4 #00BFC4
#00BFC4 0.222413674271142 0.352971970444823 4 #00BFC4
#00BFC4 0.526018333448204 0.481453229232104 4 #00BFC4
#00BFC4 0.460369425873596 0.506431541475964 4 #00BFC4
#F8766D 0.693155972155214 0.498953004876006 4 #F8766D
#00BFC4 0.354400716796471 0.625489844147297 4 #00BFC4
#00BFC4 0.408332758977187 0.400685033952556 4 #00BFC4
#F8766D 0.581845750913226 0.363741063148763 4 #F8766D
#00BFC4 0.720725067199669 0.472179843848156 4 #00BFC4
#F8766D 0.850472120752636 0.419082233988453 4 #F8766D
#00BFC4 0.6287132124888 0.656600556403123 4 #00BFC4
#F8766D 0.565993521262665 0.446603248676299 4 #F8766D
#00BFC4 0.541525949410711 0.661386819827096 4 #00BFC4
#00BFC4 0.563753532290303 0.513910078075922 4 #00BFC4
#00BFC4 0.521710662347508 0.503888839031978 4 #00BFC4
#00BFC4 0.543421324695017 0.492671034132041 4 #00BFC4
#F8766D 0.656110000689227 0.534102126895809 4 #F8766D
#00BFC4 0.514129161210283 0.509722097579945 4 #00BFC4
#00BFC4 0.539458267282376 0.502991414639983 4 #00BFC4
#00BFC4 0.587014956234062 0.549358341559724 4 #00BFC4
#00BFC4 0.407298917913019 0.656899697867121 4 #00BFC4
#00BFC4 0.710731270246054 0.477115678004128 4 #00BFC4
#00BFC4 0.351988420980081 0.444509258428311 4 #00BFC4
#00BFC4 0.510855331173754 0.616665170959347 4 #00BFC4
#00BFC4 0.53359983458543 0.656450985671124 4 #00BFC4
#00BFC4 0.453994072644565 0.587349307487511 4 #00BFC4
#00BFC4 0.627851678268661 0.365835053396751 4 #00BFC4
#00BFC4 0.521538355503481 0.592285141643483 4 #00BFC4
#00BFC4 0.62630091667241 0.644186185647192 4 #00BFC4
#00BFC4 0.630436280929078 0.588246731879506 4 #00BFC4
#00BFC4 0.636122406781997 0.533503843967812 4 #00BFC4
#00BFC4 0.504135364256668 0.529315863471836 4 #00BFC4
#00BFC4 0.436246467709697 0.638801639295223 4 #00BFC4
#00BFC4 0.49758770418361 0.666621795447067 4 #00BFC4
#00BFC4 0.537907505686126 0.543824224475755 4 #00BFC4
#F8766D 0.681439106761321 0.286263423973197 4 #F8766D
#00BFC4 0.600627196912261 0.471880702384157 4 #00BFC4
#00BFC4 0.65352539802881 0.458419336504233 4 #00BFC4
#00BFC4 0.498793852091805 0.472329414580155 4 #00BFC4
#00BFC4 0.596147218967537 0.517649346375901 4 #00BFC4
#00BFC4 0.618202495003102 0.645083610039187 4 #00BFC4
#F8766D 0.657143841753394 0.3393610338329 4 #F8766D
#00BFC4 0.475532428148046 0.424466780340423 4 #00BFC4
#F8766D 0.564442759666414 0.486538634120075 4 #F8766D
#00BFC4 0.471913984423461 0.642540907595202 4 #00BFC4
#00BFC4 0.692294437935075 0.597520117263454 4 #00BFC4
#F8766D 0.560652009097801 0.447201531604296 4 #F8766D
#00BFC4 0.689709835274657 0.432394029136379 4 #00BFC4
#F8766D 0.557033565373217 0.422073648628436 4 #F8766D
#F8766D 0.64870080639603 0.364638487540758 4 #F8766D
#00BFC4 0.754324901785099 0.428355619372401 4 #00BFC4
#F8766D 0.571679647115583 0.31782284842502 4 #F8766D
#00BFC4 0.389723619822179 0.677091746687008 4 #00BFC4
#F8766D 0.536184437245847 0.515405785395914 4 #F8766D
#F8766D 0.567371976014887 0.41429597056448 4 #F8766D
#00BFC4 0.586842649390034 0.584058751383529 4 #00BFC4
#00BFC4 0.442104900406644 0.650916868587155 4 #00BFC4
#F8766D 0.56875043076711 0.374510155852703 4 #F8766D
#00BFC4 0.490867737266524 0.5713452391636 4 #00BFC4
#00BFC4 0.623371700323937 0.488183912172066 4 #00BFC4
#00BFC4 0.451754083672203 0.583011756259535 4 #00BFC4
#00BFC4 0.361982217933696 0.36598462412875 4 #00BFC4
#00BFC4 0.523778344475843 0.544272936671752 4 #00BFC4
#00BFC4 0.179853883796264 0.637754644171229 4 #00BFC4
#00BFC4 0.511716865393893 0.538888390319782 4 #00BFC4
#00BFC4 0.406954304224964 0.545918214723743 4 #00BFC4
#00BFC4 0.578916534564753 0.616515600227347 4 #00BFC4
#00BFC4 0.52636294713626 0.527521014687846 4 #00BFC4
#00BFC4 0.543249017850989 0.505982829279966 4 #00BFC4
#F8766D 0.472603211799573 0.459765473092225 4 #F8766D
#00BFC4 0.663002274450341 0.666621795447067 4 #00BFC4
#00BFC4 0.471569370735406 0.575084507463579 4 #00BFC4
#00BFC4 0.521538355503481 0.589144156271501 4 #00BFC4
#F8766D 0.441415673030533 0.345343863112866 4 #F8766D
#00BFC4 0.533082914053346 0.307652038649077 4 #00BFC4
#F8766D 0.430560341856779 0.487585629244069 4 #F8766D
#00BFC4 0.287545661313667 0.467244009692183 4 #00BFC4
#F8766D 0.645599283203529 0.434188877920368 4 #F8766D
#00BFC4 0.687814459990351 0.479060097520117 4 #00BFC4
#00BFC4 0.60872561858157 0.523333034191869 4 #00BFC4
#00BFC4 0.449514094699841 0.546666068383739 4 #00BFC4
#00BFC4 0.584258046729616 0.720766400430764 4 #00BFC4
#00BFC4 0.467089392790682 0.570746956235604 4 #00BFC4
#F8766D 0.572196567647667 0.467692721888181 4 #F8766D
#00BFC4 0.427631125508305 0.656151844207125 4 #00BFC4
#F8766D 0.552036666896409 0.448098955996291 4 #F8766D
#00BFC4 0.751740299124681 0.490577043884053 4 #00BFC4
#F8766D 0.954545454545455 0.390364653444614 4 #F8766D
#F8766D 0.594251843683231 0.366882048520745 4 #F8766D
#F8766D 0.212419877317527 0.64104520027521 4 #F8766D
#00BFC4 0.62233785925977 0.545020790331748 4 #00BFC4
#F8766D 0.457957130057206 0.43030003888839 4 #F8766D
#F8766D 0.558584326969467 0.513610936611924 4 #F8766D
#00BFC4 0.392480529326625 0.367181189984744 4 #00BFC4
#00BFC4 0.529119856640706 0.706407610158844 4 #00BFC4
#F8766D 0.622510166103798 0.454081785276257 4 #F8766D
#00BFC4 0.498621545247777 0.594379131891471 4 #00BFC4
#00BFC4 0.520504514439313 0.385877531484639 4 #00BFC4
#00BFC4 0.235508994417258 0.572541805019594 4 #00BFC4
#00BFC4 0.498793852091805 0.723608244338748 4 #00BFC4
#00BFC4 0.609070232269626 0.523033892727871 4 #00BFC4
#00BFC4 0.496381556275415 0.450342516976278 4 #00BFC4
#00BFC4 0.445723344131229 0.553845463519698 4 #00BFC4
#00BFC4 0.346129988283135 0.631921385623261 4 #00BFC4
#00BFC4 0.566855055482804 0.367480331448742 4 #00BFC4
#F8766D 0.697635950099938 0.294938526429148 4 #F8766D
#F8766D 0.508959955889448 0.476367824344132 4 #F8766D
#00BFC4 0.606657936453236 0.66422866373508 4 #00BFC4
#00BFC4 0.420566544903163 0.458718477968231 4 #00BFC4
#00BFC4 0.562891998070163 0.473376409704149 4 #00BFC4
#00BFC4 0.340271555586188 0.685916419874959 4 #00BFC4
#F8766D 0.518092218622924 0.626237697807293 4 #F8766D
#F8766D 0.565821214418637 0.404274731520536 4 #F8766D
#00BFC4 0.438486456682059 0.691749678422926 4 #00BFC4
#F8766D 0.403163553656351 0.604998653863412 4 #F8766D
#00BFC4 0.590116479426563 0.412800263244488 4 #00BFC4
#F8766D 0.669205320835344 0.368228185108738 4 #F8766D
#F8766D 0.461058653249707 0.456474916988244 4 #F8766D
#F8766D 0.692122131091047 0.414146399832481 4 #F8766D
#00BFC4 0.45123716314012 0.455128780400251 4 #00BFC4
#F8766D 0.525846026604177 0.569251248915612 4 #F8766D
#00BFC4 0.361292990557585 0.530213287863831 4 #00BFC4
#F8766D 0.715383555034806 0.563417990367645 4 #F8766D
#00BFC4 0.50482459163278 0.369275180232732 4 #00BFC4
#00BFC4 0.544282858915156 0.607840497771396 4 #00BFC4
#00BFC4 0.430732648700806 0.577926351371564 4 #00BFC4
#00BFC4 0.396443586739265 0.576879356247569 4 #00BFC4
#00BFC4 0.65352539802881 0.567605970863621 4 #00BFC4
#F8766D 0.521366048659453 0.476367824344132 4 #F8766D
#00BFC4 0.541181335722655 0.456026204792246 4 #00BFC4
#00BFC4 0.477772417120408 0.954545454545454 4 #00BFC4
#F8766D 0.386966710317734 0.468291004816178 4 #F8766D
#F8766D 0.620442483975464 0.493568458524036 4 #F8766D
#00BFC4 0.541525949410711 0.558631726943672 4 #00BFC4
#00BFC4 0.431594182920946 0.525576595171857 4 #00BFC4
#00BFC4 0.511544558549866 0.556238595231685 4 #00BFC4
#00BFC4 0.656454614377283 0.407864429088516 4 #00BFC4
#F8766D 0.549279757391964 0.555789883035688 4 #F8766D
#00BFC4 0.493796953614998 0.52138861467588 4 #00BFC4
#F8766D 0.714522020814667 0.236306799485477 4 #F8766D
#00BFC4 0.674546833000207 0.357309521672799 4 #00BFC4
#00BFC4 0.396443586739265 0.456774058452242 4 #00BFC4
#00BFC4 0.465366324350403 0.508675102455951 4 #00BFC4
#00BFC4 0.441415673030533 0.689057405246941 4 #00BFC4
#00BFC4 0.464677096974292 0.69997606868288 4 #00BFC4
#00BFC4 0.416948101178579 0.543525083011756 4 #00BFC4
#00BFC4 0.445895650975257 0.809162703042269 4 #00BFC4
#00BFC4 0.521193741815425 0.545619073259744 4 #00BFC4
#00BFC4 0.32889930388035 0.673502049119028 4 #00BFC4
#00BFC4 0.546522847887518 0.59452870262347 4 #00BFC4
#00BFC4 0.617168653938934 0.549358341559724 4 #00BFC4
#00BFC4 0.3712867875112 0.626237697807293 4 #00BFC4
#00BFC4 0.496726169963471 0.582862185527536 4 #00BFC4
#00BFC4 0.556861258529189 0.454081785276257 4 #00BFC4
#00BFC4 0.521538355503481 0.444957970624308 4 #00BFC4
#00BFC4 0.567027362326832 0.522435609799874 4 #00BFC4
#00BFC4 0.570990419739472 0.798393610338329 4 #00BFC4
#00BFC4 0.60631332276518 0.586302312363517 4 #00BFC4
#00BFC4 0.683506788889655 0.63386580513925 4 #00BFC4
#00BFC4 0.65111310221242 0.584357892847527 4 #00BFC4
#00BFC4 0.330966986008684 0.479957521912112 4 #00BFC4
#00BFC4 0.416258873802467 0.327694516736965 4 #00BFC4
#F8766D 0.407298917913019 0.325301385024978 4 #F8766D
#00BFC4 0.542559790474878 0.41968051691645 4 #00BFC4
#00BFC4 0.410745054793576 0.501645278051991 4 #00BFC4
#00BFC4 0.36404990006203 0.463803882856203 4 #00BFC4
#00BFC4 0.721931215107864 0.311540877681055 4 #00BFC4
#00BFC4 0.658866910193673 0.422522360824434 4 #00BFC4
#00BFC4 0.589771865738507 0.538140536659786 4 #00BFC4
#00BFC4 0.457440209525122 0.435834155972359 4 #00BFC4
#00BFC4 0.299434833551589 0.459615902360226 4 #00BFC4
#00BFC4 0.445723344131229 0.618310449011337 4 #00BFC4
#00BFC4 0.664036115514508 0.338314038708905 4 #00BFC4
#00BFC4 0.517058377558757 0.570447814771605 4 #00BFC4
#00BFC4 0.458474050589289 0.572392234287595 4 #00BFC4
#00BFC4 0.341994624026466 0.618609590475336 4 #00BFC4
#00BFC4 0.53515059618168 0.659891112507105 4 #00BFC4
#00BFC4 0.622682472947825 0.653010858835143 4 #00BFC4
#00BFC4 0.611654834930043 0.457521912112238 4 #00BFC4
#00BFC4 0.222069060583086 0.551153190343713 4 #00BFC4
#00BFC4 0.386622096629678 0.585255317239523 4 #00BFC4
#00BFC4 0.378179061272314 0.638053785635227 4 #00BFC4
#00BFC4 0.424701909159832 0.541730234227766 4 #00BFC4
#00BFC4 0.567027362326832 0.689954829638936 4 #00BFC4
#00BFC4 0.745709559583707 0.391411648568608 4 #00BFC4
#F8766D 0.674029912468123 0.264874809297317 4 #F8766D
#00BFC4 0.574264249776001 0.491624039008047 4 #00BFC4
#F8766D 0.650768488524364 0.352224116784828 4 #F8766D
#00BFC4 0.44486180991109 0.415342965688474 4 #00BFC4
#00BFC4 0.667137638707009 0.5714948098956 4 #00BFC4
#00BFC4 0.809463091874009 0.580618624547548 4 #00BFC4
#00BFC4 0.537735198842098 0.68397200035897 4 #00BFC4
#00BFC4 0.467434006478737 0.607840497771396 4 #00BFC4
#F8766D 0.61751326762699 0.576281073319573 4 #F8766D
#00BFC4 0.585636501481839 0.338014897244907 4 #00BFC4
#00BFC4 0.671962230339789 0.562221424511652 4 #00BFC4
#00BFC4 0.532221379833207 0.562370995243651 4 #00BFC4
#00BFC4 0.507581501137225 0.506431541475964 4 #00BFC4
#00BFC4 0.633193190433524 0.508076819527955 4 #00BFC4
#00BFC4 0.560996622785857 0.513910078075922 4 #00BFC4
#00BFC4 0.521193741815425 0.584657034311526 4 #00BFC4
#00BFC4 0.512406092770005 0.586302312363517 4 #00BFC4
#00BFC4 0.540319801502516 0.556986448891681 4 #00BFC4
#00BFC4 0.541181335722655 0.688010410122947 4 #00BFC4
#00BFC4 0.518092218622924 0.675745610099016 4 #00BFC4
#00BFC4 0.545661313667379 0.545170361063747 4 #00BFC4
#00BFC4 0.506030739540975 0.493418887792037 4 #00BFC4
#00BFC4 0.651630022744503 0.251263872685393 4 #00BFC4
#00BFC4 0.476221655524157 0.617562595351342 4 #00BFC4
#00BFC4 0.492590805706803 0.609784917287385 4 #00BFC4
#00BFC4 0.607864084361431 0.568952107451614 4 #00BFC4
#00BFC4 0.590805706802674 0.468141434084178 4 #00BFC4
#00BFC4 0.570473499207389 0.41250112178049 4 #00BFC4
#00BFC4 0.509649183265559 0.589443297735499 4 #00BFC4
#00BFC4 0.520504514439313 0.422821502288432 4 #00BFC4
#00BFC4 0.574953477152113 0.283421580065213 4 #00BFC4
#00BFC4 0.491729271486663 0.495363307308026 4 #00BFC4
#00BFC4 0.702460541732718 0.460064614556224 4 #00BFC4
#00BFC4 0.596836446343649 0.421774507164438 4 #00BFC4
#00BFC4 0.495520022055276 0.323955248436986 4 #00BFC4
#00BFC4 0.644220828451306 0.490427473152054 4 #00BFC4
#00BFC4 0.547901302639741 0.376305004636693 4 #00BFC4
#00BFC4 0.566682748638776 0.416838673008466 4 #00BFC4
#00BFC4 0.526707560824316 0.69100182476293 4 #00BFC4
#00BFC4 0.619408642911296 0.244533189745431 4 #00BFC4
#00BFC4 0.56237507753808 0.444210116964312 4 #00BFC4
#00BFC4 0.454683300020677 0.493418887792037 4 #00BFC4
#00BFC4 0.694534426907437 0.631472673427264 4 #00BFC4
#00BFC4 0.40884967950927 0.769077746866493 4 #00BFC4
#F8766D 0.628196291956716 0.586152741631517 4 #F8766D
#F8766D 0.584947274105727 0.600511531903437 4 #F8766D
#00BFC4 0.412640430077883 0.466197014568189 4 #00BFC4
#00BFC4 0.78378937211386 0.481602799964103 4 #00BFC4
#F8766D 0.605279481701013 0.524529600047863 4 #F8766D
#00BFC4 0.650251567992281 0.525875736635855 4 #00BFC4
#00BFC4 0.651802329588531 0.431347034012384 4 #00BFC4
#00BFC4 0.520332207595286 0.504187980495976 4 #00BFC4
#00BFC4 0.696257495347715 0.494316312184032 4 #00BFC4
#00BFC4 0.676614515128541 0.515405785395914 4 #00BFC4
#00BFC4 0.726755806740644 0.628182117323282 4 #00BFC4
#00BFC4 0.712109724998277 0.290900116665171 4 #00BFC4
#00BFC4 0.647666965331863 0.455577492596249 4 #00BFC4
#00BFC4 0.584258046729616 0.314681863053038 4 #00BFC4
#00BFC4 0.552208973740437 0.48399593167609 4 #00BFC4
#00BFC4 0.32011165483493 0.474872117024141 4 #00BFC4
#00BFC4 0.678509890412847 0.442714409644321 4 #00BFC4
#00BFC4 0.68230064098146 0.402779024200544 4 #00BFC4
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<title>Interactive animation</title>
<script type="text/javascript" src="d3.v3.js"></script>
<script type="text/javascript" src="animint.js"></script>
<link rel="stylesheet" type="text/css" href="styles.css" />
</head>
<body>
<div id="plot"> </div>
<script>
var plot = new animint("#plot","plot.json");
</script>
</body>
</html>
{
"geoms": {
"geom1_point_strike": {
"geom": "point",
"classed": "geom1_point_strike",
"aes": {
"x": "px",
"y": "pz",
"colour": "pitch_type"
},
"params": {
"na.rm": false,
"alpha": 0.3
},
"subset_order": [
"PANEL"
],
"types": {
"colour": "rgb",
"x": "numeric",
"y": "numeric",
"PANEL": "factor",
"fill": "rgb"
},
"chunks": 1,
"total": 1,
"chunk_order": [],
"nest_order": [
"PANEL"
]
}
},
"selectors": [],
"plots": {
"strike": {
"strips": {
"right": [ [
"L"
],
[
"R"
] ],
"top": [ [
"Mariano Rivera"
],
[
"Phil Hughes"
] ]
},
"layout": {
"PANEL": [ "1", "2", "3", "4" ],
"ROW": [ 1, 1, 2, 2 ],
"COL": [ 1, 2, 1, 2 ],
"stand": [ "L", "L", "R", "R" ],
"pitcher_name": [ "Mariano Rivera", "Phil Hughes", "Mariano Rivera", "Phil Hughes" ],
"SCALE_X": [ 1, 1, 1, 1 ],
"SCALE_Y": [ 1, 1, 1, 1 ],
"AXIS_Y": [ true, false, true, false ],
"AXIS_X": [ false, false, true, true ],
"coord_fixed": [ true, true, true, true ],
"width_proportion": [ 0.43402, 0.43402, 0.43402, 0.43402 ],
"height_proportion": [ 0.5, 0.5, 0.5, 0.5 ],
"xdisplace": [ 0.065976, 0.5, 0.065976, 0.5 ],
"ydisplace": [ 0, 0, 0.5, 0.5 ]
},
"geoms": [
"geom1_point_strike"
],
"axis1": {
"x": [ 0.14367, 0.31598, 0.48828, 0.66059, 0.8329 ],
"xlab": [ "-2", "-1", "0", "1", "2" ],
"xrange": [ -2.8338, 2.9698 ],
"xline": true,
"xticks": true,
"y": [ 0.095112, 0.39425, 0.69339, 0.99254 ],
"ylab": [ "0", "2", "4", "6" ],
"yrange": [ -0.6359, 6.0499 ],
"yline": true,
"yticks": true
},
"axis2": {
"x": [ 0.14367, 0.31598, 0.48828, 0.66059, 0.8329 ],
"xlab": [ "-2", "-1", "0", "1", "2" ],
"xrange": [ -2.8338, 2.9698 ],
"xline": true,
"xticks": true,
"y": [ 0.095112, 0.39425, 0.69339, 0.99254 ],
"ylab": [ "0", "2", "4", "6" ],
"yrange": [ -0.6359, 6.0499 ],
"yline": true,
"yticks": true
},
"axis3": {
"x": [ 0.14367, 0.31598, 0.48828, 0.66059, 0.8329 ],
"xlab": [ "-2", "-1", "0", "1", "2" ],
"xrange": [ -2.8338, 2.9698 ],
"xline": true,
"xticks": true,
"y": [ 0.095112, 0.39425, 0.69339, 0.99254 ],
"ylab": [ "0", "2", "4", "6" ],
"yrange": [ -0.6359, 6.0499 ],
"yline": true,
"yticks": true
},
"axis4": {
"x": [ 0.14367, 0.31598, 0.48828, 0.66059, 0.8329 ],
"xlab": [ "-2", "-1", "0", "1", "2" ],
"xrange": [ -2.8338, 2.9698 ],
"xline": true,
"xticks": true,
"y": [ 0.095112, 0.39425, 0.69339, 0.99254 ],
"ylab": [ "0", "2", "4", "6" ],
"yrange": [ -0.6359, 6.0499 ],
"yline": true,
"yticks": true
},
"xtitle": "px",
"ytitle": "pz",
"xlabs": [ "-2", "-1", "0", "1", "2" ],
"ylabs": [ "0", "2", "4", "6" ],
"legend": {
"pitch_type": {
"guide": "legend",
"geoms": "point",
"title": "pitch_type",
"entries": [
{
"pointcolour": "#00BFC4",
"pointshape": 16,
"pointsize": 2,
"pointalpha": 0.3,
"label": [ "FF" ]
},
{
"pointcolour": "#F8766D",
"pointshape": 16,
"pointsize": 2,
"pointalpha": 0.3,
"label": [ "FC" ]
}
]
}
},
"options": {
"width": 400,
"height": 400
}
}
}
}
<script type="text/javascript" src="vendor/d3.v3.js"></script>
<script type="text/javascript" src="animint.js"></script>
<div id="plot"> </div>
<script>
var plot = new animint("#plot","plot.json");
</script>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment