2012-11-21 19:22:57 +04:00
|
|
|
require("../env");
|
|
|
|
|
|
|
|
var formatNumber = d3.format(",.02r"),
|
|
|
|
projection = d3.geo.stereographic().clipAngle(150),
|
|
|
|
path = d3.geo.path().projection(projection),
|
|
|
|
graticule = d3.geo.graticule().step([1, 1]),
|
|
|
|
circle = d3.geo.circle().angle(30),
|
|
|
|
n = 10;
|
|
|
|
|
|
|
|
var o = graticule(),
|
|
|
|
then = Date.now();
|
|
|
|
|
|
|
|
for (var i = 0, k = 0; i < n; i++, k++) {
|
|
|
|
path(o);
|
|
|
|
}
|
|
|
|
|
|
|
|
console.log("Dense graticule: " + formatNumber((Date.now() - then) / k) + "ms/op.");
|
|
|
|
|
|
|
|
o = {type: "GeometryCollection", geometries: d3.range(-180, 180, 1).map(function(x) {
|
|
|
|
return circle.origin([x, 0])();
|
|
|
|
})}
|
|
|
|
then = Date.now();
|
|
|
|
|
|
|
|
for (var i = 0, k = 0; i < n; i++, k++) {
|
|
|
|
path(o);
|
|
|
|
}
|
|
|
|
|
|
|
|
console.log("Circle polygons: " + formatNumber((Date.now() - then) / k) + "ms/op.");
|
|
|
|
|
|
|
|
o = spiral();
|
|
|
|
then = Date.now();
|
|
|
|
|
|
|
|
for (var i = 0, k = 0; i < n; i++, k++) {
|
|
|
|
path(o);
|
|
|
|
}
|
|
|
|
|
|
|
|
console.log("Spiral polygons: " + formatNumber((Date.now() - then) / k) + "ms/op.");
|
|
|
|
|
|
|
|
function spiral() {
|
2012-12-12 04:11:08 +04:00
|
|
|
var n = 1e4,
|
2012-11-21 19:22:57 +04:00
|
|
|
dy = 5;
|
|
|
|
|
|
|
|
var spiral = d3.range(0, 1 + 1 / n, 1 / n).map(function(t) {
|
|
|
|
return [(360 * 10 * t) % 360 - 180, -90 + dy + (90 - dy) * 2 * t];
|
|
|
|
}).concat(d3.range(1, 0, -1 / n).map(function(t) {
|
|
|
|
return [(360 * 10 * t) % 360 - 180, -90 + (90 - dy) * 2 * t];
|
|
|
|
}));
|
|
|
|
spiral.push(spiral[0]);
|
|
|
|
|
|
|
|
return {type: "Polygon", coordinates: [spiral]};
|
|
|
|
}
|