bum 0.0.4 → 0.0.12
Sign up to get free protection for your applications and to get access to all the features.
- data/README +0 -12
- data/bin/bum +16 -49
- data/bin/bum_master +20 -0
- data/lib/actor.rb +0 -0
- data/lib/app_role.rb +83 -0
- data/lib/client.rb +104 -0
- data/lib/db_crap.rb +85 -0
- data/lib/db_role.rb +107 -0
- data/lib/demo_socket.rb +51 -0
- data/lib/master.rb +109 -0
- data/lib/master_web.rb +81 -0
- data/lib/nice_socket.rb +77 -0
- data/lib/node.rb +96 -0
- data/lib/proxy_role.rb +132 -0
- data/lib/role.rb +99 -0
- data/lib/scenario.rb +186 -0
- data/lib/server.rb +30 -0
- data/lib/stats_role.rb +89 -0
- data/public/app.css +91 -0
- data/public/css/light.css +105 -0
- data/public/d3/LICENSE +26 -0
- data/public/d3/Makefile +247 -0
- data/public/d3/README.md +51 -0
- data/public/d3/d3.chart.js +984 -0
- data/public/d3/d3.chart.min.js +1 -0
- data/public/d3/d3.csv.js +92 -0
- data/public/d3/d3.csv.min.js +1 -0
- data/public/d3/d3.geo.js +692 -0
- data/public/d3/d3.geo.min.js +1 -0
- data/public/d3/d3.geom.js +825 -0
- data/public/d3/d3.geom.min.js +1 -0
- data/public/d3/d3.js +4013 -0
- data/public/d3/d3.layout.js +1865 -0
- data/public/d3/d3.layout.min.js +1 -0
- data/public/d3/d3.min.js +2 -0
- data/public/d3/d3.time.js +663 -0
- data/public/d3/d3.time.min.js +1 -0
- data/public/d3/examples/albers/albers.html +168 -0
- data/public/d3/examples/area/area-radial.html +48 -0
- data/public/d3/examples/area/area.html +113 -0
- data/public/d3/examples/axis/axis-alternating.html +50 -0
- data/public/d3/examples/axis/axis-ggplot2.html +68 -0
- data/public/d3/examples/axis/axis-multiples.html +117 -0
- data/public/d3/examples/axis/axis-orientations.html +63 -0
- data/public/d3/examples/axis/axis-transition.html +153 -0
- data/public/d3/examples/azimuthal/azimuthal.css +21 -0
- data/public/d3/examples/azimuthal/azimuthal.html +84 -0
- data/public/d3/examples/azimuthal/azimuthal.js +27 -0
- data/public/d3/examples/bar/bar.html +93 -0
- data/public/d3/examples/box/box.css +4 -0
- data/public/d3/examples/box/box.html +19 -0
- data/public/d3/examples/box/box.js +68 -0
- data/public/d3/examples/bubble/bubble.css +8 -0
- data/public/d3/examples/bubble/bubble.html +14 -0
- data/public/d3/examples/bubble/bubble.js +46 -0
- data/public/d3/examples/bullet/bullet.css +10 -0
- data/public/d3/examples/bullet/bullet.html +18 -0
- data/public/d3/examples/bullet/bullet.js +53 -0
- data/public/d3/examples/bullet/bullets.json +7 -0
- data/public/d3/examples/bundle/bundle-radial.css +9 -0
- data/public/d3/examples/bundle/bundle-radial.html +15 -0
- data/public/d3/examples/bundle/bundle-radial.js +50 -0
- data/public/d3/examples/bundle/bundle-treemap.css +14 -0
- data/public/d3/examples/bundle/bundle-treemap.html +16 -0
- data/public/d3/examples/bundle/bundle-treemap.js +53 -0
- data/public/d3/examples/bundle/packages.js +49 -0
- data/public/d3/examples/button.css +35 -0
- data/public/d3/examples/calendar/calendar.css +16 -0
- data/public/d3/examples/calendar/calendar.js +50 -0
- data/public/d3/examples/calendar/dji.csv +5233 -0
- data/public/d3/examples/calendar/dji.html +16 -0
- data/public/d3/examples/calendar/dji.js +61 -0
- data/public/d3/examples/calendar/vix.csv +5231 -0
- data/public/d3/examples/calendar/vix.html +16 -0
- data/public/d3/examples/calendar/vix.js +60 -0
- data/public/d3/examples/cartogram/cartogram.css +20 -0
- data/public/d3/examples/cartogram/cartogram.html +15 -0
- data/public/d3/examples/cartogram/cartogram.js +51 -0
- data/public/d3/examples/cartogram/demers.css +9 -0
- data/public/d3/examples/cartogram/demers.html +16 -0
- data/public/d3/examples/cartogram/demers.js +79 -0
- data/public/d3/examples/cartogram/dorling.css +9 -0
- data/public/d3/examples/cartogram/dorling.html +16 -0
- data/public/d3/examples/cartogram/dorling.js +80 -0
- data/public/d3/examples/chord/chord-flare.html +109 -0
- data/public/d3/examples/chord/chord.css +9 -0
- data/public/d3/examples/chord/chord.html +14 -0
- data/public/d3/examples/chord/chord.js +98 -0
- data/public/d3/examples/choropleth/choropleth-area.html +51 -0
- data/public/d3/examples/choropleth/choropleth-bounds.html +46 -0
- data/public/d3/examples/choropleth/choropleth.css +16 -0
- data/public/d3/examples/choropleth/choropleth.html +15 -0
- data/public/d3/examples/choropleth/choropleth.js +38 -0
- data/public/d3/examples/choropleth/unemployment.json +1 -0
- data/public/d3/examples/clock/clock.css +23 -0
- data/public/d3/examples/clock/clock.html +17 -0
- data/public/d3/examples/clock/clock.js +87 -0
- data/public/d3/examples/cluster/cluster-radial.html +14 -0
- data/public/d3/examples/cluster/cluster-radial.js +39 -0
- data/public/d3/examples/cluster/cluster.css +15 -0
- data/public/d3/examples/cluster/cluster.html +14 -0
- data/public/d3/examples/cluster/cluster.js +39 -0
- data/public/d3/examples/contour/contour.html +108 -0
- data/public/d3/examples/crimea/crimea-stacked-area.html +109 -0
- data/public/d3/examples/crimea/crimea-stacked-bar.html +98 -0
- data/public/d3/examples/crimea/crimea.csv +24 -0
- data/public/d3/examples/data/README +5 -0
- data/public/d3/examples/data/faithful.json +8 -0
- data/public/d3/examples/data/flare-imports.json +222 -0
- data/public/d3/examples/data/flare.json +380 -0
- data/public/d3/examples/data/morley.csv +101 -0
- data/public/d3/examples/data/sample.csv +2 -0
- data/public/d3/examples/data/sample.html +5 -0
- data/public/d3/examples/data/sample.json +1 -0
- data/public/d3/examples/data/sample.txt +1 -0
- data/public/d3/examples/data/sample.xml +4 -0
- data/public/d3/examples/data/stocks.csv +807 -0
- data/public/d3/examples/data/unemployment.csv +1709 -0
- data/public/d3/examples/data/us-borders.json +1 -0
- data/public/d3/examples/data/us-counties.json +3216 -0
- data/public/d3/examples/data/us-state-centroids.json +1 -0
- data/public/d3/examples/data/us-states.json +54 -0
- data/public/d3/examples/data/world-countries.json +246 -0
- data/public/d3/examples/delaunay/delaunay.html +44 -0
- data/public/d3/examples/donut/donut.html +124 -0
- data/public/d3/examples/dot/dot.html +103 -0
- data/public/d3/examples/force/README +10 -0
- data/public/d3/examples/force/force-bounds.html +70 -0
- data/public/d3/examples/force/force-cluster.html +251 -0
- data/public/d3/examples/force/force-dynamic.html +118 -0
- data/public/d3/examples/force/force-interactive.html +136 -0
- data/public/d3/examples/force/force-map.html +104 -0
- data/public/d3/examples/force/force-multi-foci.html +68 -0
- data/public/d3/examples/force/force.css +9 -0
- data/public/d3/examples/force/force.html +14 -0
- data/public/d3/examples/force/force.js +56 -0
- data/public/d3/examples/force/miserables.json +1 -0
- data/public/d3/examples/hello-world/hello-data-key.html +60 -0
- data/public/d3/examples/hello-world/hello-data-nested-key.html +75 -0
- data/public/d3/examples/hello-world/hello-data-nested.html +77 -0
- data/public/d3/examples/hello-world/hello-data.html +46 -0
- data/public/d3/examples/hello-world/hello-event.html +53 -0
- data/public/d3/examples/hello-world/hello-node-key.html +25 -0
- data/public/d3/examples/hello-world/hello-sort.html +75 -0
- data/public/d3/examples/hello-world/hello-transform.html +41 -0
- data/public/d3/examples/hello-world/hello-transition-undefined.html +43 -0
- data/public/d3/examples/hello-world/hello-transition.html +47 -0
- data/public/d3/examples/hello-world/hello-webkit-transition.html +64 -0
- data/public/d3/examples/hello-world/select-enter-add.html +29 -0
- data/public/d3/examples/hello-world/selectAll-enter-add.html +20 -0
- data/public/d3/examples/histogram/histogram.html +80 -0
- data/public/d3/examples/horizon/horizon.css +9 -0
- data/public/d3/examples/horizon/horizon.html +25 -0
- data/public/d3/examples/horizon/horizon.js +43 -0
- data/public/d3/examples/horizon/unemployment.json +1 -0
- data/public/d3/examples/hull/hull.html +75 -0
- data/public/d3/examples/kde/kde.css +9 -0
- data/public/d3/examples/kde/kde.html +14 -0
- data/public/d3/examples/kde/kde.js +40 -0
- data/public/d3/examples/line/line.css +22 -0
- data/public/d3/examples/line/line.html +11 -0
- data/public/d3/examples/line/line.js +63 -0
- data/public/d3/examples/marimekko/marimekko.html +116 -0
- data/public/d3/examples/marimekko/marimekko.json +18 -0
- data/public/d3/examples/marker/marker.html +169 -0
- data/public/d3/examples/mercator/mercator.html +133 -0
- data/public/d3/examples/moire/moire.html +53 -0
- data/public/d3/examples/pack/pack.css +15 -0
- data/public/d3/examples/pack/pack.html +14 -0
- data/public/d3/examples/pack/pack.js +33 -0
- data/public/d3/examples/partition/partition-icicle-zoom.html +59 -0
- data/public/d3/examples/partition/partition-icicle.html +45 -0
- data/public/d3/examples/partition/partition-sunburst-zoom.html +72 -0
- data/public/d3/examples/partition/partition-sunburst.html +21 -0
- data/public/d3/examples/partition/partition-sunburst.js +72 -0
- data/public/d3/examples/pie/pie-transition.html +70 -0
- data/public/d3/examples/pie/pie.html +51 -0
- data/public/d3/examples/population/population.css +28 -0
- data/public/d3/examples/population/population.csv +571 -0
- data/public/d3/examples/population/population.html +13 -0
- data/public/d3/examples/population/population.js +126 -0
- data/public/d3/examples/qq/qq.css +18 -0
- data/public/d3/examples/qq/qq.html +21 -0
- data/public/d3/examples/qq/qq.js +66 -0
- data/public/d3/examples/qq/stats.js +28 -0
- data/public/d3/examples/qq/turkers.json +1 -0
- data/public/d3/examples/quadtree/quadtree.html +114 -0
- data/public/d3/examples/sizzle/sizzle.html +27 -0
- data/public/d3/examples/sort/sort.css +4 -0
- data/public/d3/examples/sort/sort.html +12 -0
- data/public/d3/examples/sort/sort.js +112 -0
- data/public/d3/examples/spline/spline.css +30 -0
- data/public/d3/examples/spline/spline.html +14 -0
- data/public/d3/examples/spline/spline.js +113 -0
- data/public/d3/examples/splom/cross.js +7 -0
- data/public/d3/examples/splom/flowers.json +1 -0
- data/public/d3/examples/splom/splom.css +8 -0
- data/public/d3/examples/splom/splom.html +14 -0
- data/public/d3/examples/splom/splom.js +149 -0
- data/public/d3/examples/stream/stack.css +7 -0
- data/public/d3/examples/stream/stack.html +22 -0
- data/public/d3/examples/stream/stack.js +119 -0
- data/public/d3/examples/stream/stream.css +3 -0
- data/public/d3/examples/stream/stream.html +19 -0
- data/public/d3/examples/stream/stream.js +42 -0
- data/public/d3/examples/stream/stream_layers.js +33 -0
- data/public/d3/examples/superformula/dot.html +104 -0
- data/public/d3/examples/superformula/explorer.html +120 -0
- data/public/d3/examples/superformula/superformula.html +70 -0
- data/public/d3/examples/superformula/superformula.js +98 -0
- data/public/d3/examples/symbol-map/symbol-map.html +67 -0
- data/public/d3/examples/touch/touch.html +65 -0
- data/public/d3/examples/tree/tree-dynamic.html +111 -0
- data/public/d3/examples/tree/tree-interactive.html +139 -0
- data/public/d3/examples/tree/tree-radial.html +14 -0
- data/public/d3/examples/tree/tree-radial.js +40 -0
- data/public/d3/examples/tree/tree.css +15 -0
- data/public/d3/examples/tree/tree.html +14 -0
- data/public/d3/examples/tree/tree.js +39 -0
- data/public/d3/examples/treemap/treemap-svg.html +22 -0
- data/public/d3/examples/treemap/treemap-svg.js +34 -0
- data/public/d3/examples/treemap/treemap.css +8 -0
- data/public/d3/examples/treemap/treemap.html +22 -0
- data/public/d3/examples/treemap/treemap.js +53 -0
- data/public/d3/examples/voroboids/boid.js +235 -0
- data/public/d3/examples/voroboids/voroboids.css +15 -0
- data/public/d3/examples/voroboids/voroboids.html +14 -0
- data/public/d3/examples/voroboids/voroboids.js +65 -0
- data/public/d3/examples/voronoi/voronoi.css +16 -0
- data/public/d3/examples/voronoi/voronoi.html +15 -0
- data/public/d3/examples/voronoi/voronoi.js +34 -0
- data/public/d3/examples/zoom-pan/zoom-pan-transform.html +95 -0
- data/public/d3/examples/zoom-pan/zoom-pan.html +119 -0
- data/public/d3/examples/zoom/dji.csv +5233 -0
- data/public/d3/examples/zoom/zoom.html +162 -0
- data/public/d3/lib/colorbrewer/LICENSE +38 -0
- data/public/d3/lib/colorbrewer/colorbrewer.css +1327 -0
- data/public/d3/lib/colorbrewer/colorbrewer.js +32 -0
- data/public/d3/lib/jit/LICENSE +27 -0
- data/public/d3/lib/jquery-ui/LICENSE +25 -0
- data/public/d3/lib/jquery-ui/images/ui-bg_diagonals-thick_18_b81900_40x40.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-bg_diagonals-thick_20_666666_40x40.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-bg_flat_10_000000_40x100.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-bg_glass_100_f6f6f6_1x400.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-bg_glass_100_fdf5ce_1x400.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-bg_glass_65_ffffff_1x400.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-bg_gloss-wave_35_f6a828_500x100.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-bg_highlight-soft_100_eeeeee_1x100.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-bg_highlight-soft_75_ffe45c_1x100.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-icons_222222_256x240.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-icons_228ef1_256x240.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-icons_ef8c08_256x240.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-icons_ffd27a_256x240.png +0 -0
- data/public/d3/lib/jquery-ui/images/ui-icons_ffffff_256x240.png +0 -0
- data/public/d3/lib/jquery-ui/jquery-ui.css +318 -0
- data/public/d3/lib/jquery-ui/jquery-ui.min.js +83 -0
- data/public/d3/lib/jquery/LICENSE +20 -0
- data/public/d3/lib/jquery/jquery.js +6883 -0
- data/public/d3/lib/jquery/jquery.min.js +166 -0
- data/public/d3/lib/polymaps/LICENSE +28 -0
- data/public/d3/lib/protovis/LICENSE +27 -0
- data/public/d3/lib/science/LICENSE +26 -0
- data/public/d3/lib/science/science.js +5 -0
- data/public/d3/lib/science/science.min.js +1 -0
- data/public/d3/lib/science/science.stats.js +166 -0
- data/public/d3/lib/science/science.stats.min.js +1 -0
- data/public/d3/lib/sizzle/LICENSE +24 -0
- data/public/d3/lib/sizzle/sizzle.js +1376 -0
- data/public/d3/lib/sizzle/sizzle.min.js +28 -0
- data/public/d3/package.json +14 -0
- data/public/d3/src/behavior/behavior.js +1 -0
- data/public/d3/src/behavior/drag.js +106 -0
- data/public/d3/src/behavior/zoom.js +212 -0
- data/public/d3/src/chart/box.js +297 -0
- data/public/d3/src/chart/bullet.js +237 -0
- data/public/d3/src/chart/chart.js +1 -0
- data/public/d3/src/chart/horizon.js +203 -0
- data/public/d3/src/chart/qq.js +245 -0
- data/public/d3/src/compat/date.js +3 -0
- data/public/d3/src/compat/style.js +9 -0
- data/public/d3/src/core/array.js +11 -0
- data/public/d3/src/core/ascending.js +3 -0
- data/public/d3/src/core/bisect.js +38 -0
- data/public/d3/src/core/collapse.js +3 -0
- data/public/d3/src/core/core.js +1 -0
- data/public/d3/src/core/descending.js +3 -0
- data/public/d3/src/core/dispatch.js +45 -0
- data/public/d3/src/core/ease.js +128 -0
- data/public/d3/src/core/entries.js +5 -0
- data/public/d3/src/core/event.js +1 -0
- data/public/d3/src/core/first.js +13 -0
- data/public/d3/src/core/format.js +85 -0
- data/public/d3/src/core/functor.js +3 -0
- data/public/d3/src/core/hsl.js +62 -0
- data/public/d3/src/core/html.js +10 -0
- data/public/d3/src/core/interpolate.js +180 -0
- data/public/d3/src/core/json.js +5 -0
- data/public/d3/src/core/keys.js +5 -0
- data/public/d3/src/core/last.js +13 -0
- data/public/d3/src/core/max.js +14 -0
- data/public/d3/src/core/merge.js +3 -0
- data/public/d3/src/core/min.js +14 -0
- data/public/d3/src/core/nest.js +87 -0
- data/public/d3/src/core/noop.js +1 -0
- data/public/d3/src/core/ns.js +19 -0
- data/public/d3/src/core/permute.js +7 -0
- data/public/d3/src/core/quantile.js +8 -0
- data/public/d3/src/core/range.js +21 -0
- data/public/d3/src/core/rebind.js +7 -0
- data/public/d3/src/core/requote.js +5 -0
- data/public/d3/src/core/rgb.js +284 -0
- data/public/d3/src/core/round.js +5 -0
- data/public/d3/src/core/selection-append.js +15 -0
- data/public/d3/src/core/selection-attr.js +44 -0
- data/public/d3/src/core/selection-call.js +13 -0
- data/public/d3/src/core/selection-classed.js +46 -0
- data/public/d3/src/core/selection-data.js +110 -0
- data/public/d3/src/core/selection-each.js +9 -0
- data/public/d3/src/core/selection-empty.js +3 -0
- data/public/d3/src/core/selection-enter-select.js +24 -0
- data/public/d3/src/core/selection-enter.js +10 -0
- data/public/d3/src/core/selection-filter.js +19 -0
- data/public/d3/src/core/selection-html.js +6 -0
- data/public/d3/src/core/selection-insert.js +20 -0
- data/public/d3/src/core/selection-map.js +5 -0
- data/public/d3/src/core/selection-node.js +9 -0
- data/public/d3/src/core/selection-on.js +34 -0
- data/public/d3/src/core/selection-property.js +23 -0
- data/public/d3/src/core/selection-remove.js +9 -0
- data/public/d3/src/core/selection-root.js +16 -0
- data/public/d3/src/core/selection-select.js +30 -0
- data/public/d3/src/core/selection-selectAll.js +24 -0
- data/public/d3/src/core/selection-sort.js +20 -0
- data/public/d3/src/core/selection-style.js +26 -0
- data/public/d3/src/core/selection-text.js +6 -0
- data/public/d3/src/core/selection-transition.js +14 -0
- data/public/d3/src/core/selection.js +21 -0
- data/public/d3/src/core/split.js +21 -0
- data/public/d3/src/core/sum.js +14 -0
- data/public/d3/src/core/text.js +10 -0
- data/public/d3/src/core/this.js +3 -0
- data/public/d3/src/core/timer.js +104 -0
- data/public/d3/src/core/transition-attr.js +23 -0
- data/public/d3/src/core/transition-delay.js +6 -0
- data/public/d3/src/core/transition-duration.js +6 -0
- data/public/d3/src/core/transition-each.js +9 -0
- data/public/d3/src/core/transition-remove.js +6 -0
- data/public/d3/src/core/transition-select.js +22 -0
- data/public/d3/src/core/transition-selectAll.js +20 -0
- data/public/d3/src/core/transition-style.js +14 -0
- data/public/d3/src/core/transition-text.js +7 -0
- data/public/d3/src/core/transition-transition.js +3 -0
- data/public/d3/src/core/transition.js +105 -0
- data/public/d3/src/core/uninterpolate.js +9 -0
- data/public/d3/src/core/values.js +5 -0
- data/public/d3/src/core/xhr.js +10 -0
- data/public/d3/src/core/xml.js +10 -0
- data/public/d3/src/core/zip.js +13 -0
- data/public/d3/src/csv/csv.js +5 -0
- data/public/d3/src/csv/format.js +13 -0
- data/public/d3/src/csv/parse.js +73 -0
- data/public/d3/src/end.js +1 -0
- data/public/d3/src/externs.js +6 -0
- data/public/d3/src/geo/albers.js +128 -0
- data/public/d3/src/geo/azimuthal.js +70 -0
- data/public/d3/src/geo/bounds.js +76 -0
- data/public/d3/src/geo/geo.js +1 -0
- data/public/d3/src/geo/greatCircle.js +91 -0
- data/public/d3/src/geo/mercator.js +36 -0
- data/public/d3/src/geo/path.js +289 -0
- data/public/d3/src/geom/contour.js +78 -0
- data/public/d3/src/geom/delaunay.js +31 -0
- data/public/d3/src/geom/geom.js +1 -0
- data/public/d3/src/geom/hull.js +98 -0
- data/public/d3/src/geom/polygon.js +88 -0
- data/public/d3/src/geom/quadtree.js +129 -0
- data/public/d3/src/geom/voronoi.js +399 -0
- data/public/d3/src/layout/bundle.js +57 -0
- data/public/d3/src/layout/chord.js +148 -0
- data/public/d3/src/layout/cluster.js +77 -0
- data/public/d3/src/layout/force.js +332 -0
- data/public/d3/src/layout/hierarchy.js +120 -0
- data/public/d3/src/layout/histogram.js +102 -0
- data/public/d3/src/layout/layout.js +1 -0
- data/public/d3/src/layout/pack.js +200 -0
- data/public/d3/src/layout/partition.js +48 -0
- data/public/d3/src/layout/pie.js +95 -0
- data/public/d3/src/layout/stack.js +237 -0
- data/public/d3/src/layout/tree.js +234 -0
- data/public/d3/src/layout/treemap.js +213 -0
- data/public/d3/src/scale/bilinear.js +7 -0
- data/public/d3/src/scale/category.js +54 -0
- data/public/d3/src/scale/linear.js +115 -0
- data/public/d3/src/scale/log.js +80 -0
- data/public/d3/src/scale/nice.js +21 -0
- data/public/d3/src/scale/ordinal.js +74 -0
- data/public/d3/src/scale/polylinear.js +16 -0
- data/public/d3/src/scale/pow.js +54 -0
- data/public/d3/src/scale/quantile.js +43 -0
- data/public/d3/src/scale/quantize.js +36 -0
- data/public/d3/src/scale/scale.js +6 -0
- data/public/d3/src/scale/sqrt.js +3 -0
- data/public/d3/src/start.js +1 -0
- data/public/d3/src/svg/arc.js +95 -0
- data/public/d3/src/svg/area-radial.js +10 -0
- data/public/d3/src/svg/area.js +84 -0
- data/public/d3/src/svg/axis.js +182 -0
- data/public/d3/src/svg/chord.js +99 -0
- data/public/d3/src/svg/diagonal-radial.js +22 -0
- data/public/d3/src/svg/diagonal.js +38 -0
- data/public/d3/src/svg/line-radial.js +22 -0
- data/public/d3/src/svg/line.js +419 -0
- data/public/d3/src/svg/mouse.js +29 -0
- data/public/d3/src/svg/svg.js +1 -0
- data/public/d3/src/svg/symbol.js +98 -0
- data/public/d3/src/svg/touches.js +8 -0
- data/public/d3/src/time/day.js +7 -0
- data/public/d3/src/time/days.js +11 -0
- data/public/d3/src/time/format-iso.js +1 -0
- data/public/d3/src/time/format-utc.js +48 -0
- data/public/d3/src/time/format.js +315 -0
- data/public/d3/src/time/hour.js +8 -0
- data/public/d3/src/time/hours.js +11 -0
- data/public/d3/src/time/minute.js +5 -0
- data/public/d3/src/time/minutes.js +11 -0
- data/public/d3/src/time/month.js +7 -0
- data/public/d3/src/time/months.js +11 -0
- data/public/d3/src/time/range.js +16 -0
- data/public/d3/src/time/scale-utc.js +36 -0
- data/public/d3/src/time/scale.js +123 -0
- data/public/d3/src/time/second.js +5 -0
- data/public/d3/src/time/seconds.js +7 -0
- data/public/d3/src/time/time.js +3 -0
- data/public/d3/src/time/week.js +9 -0
- data/public/d3/src/time/weeks.js +11 -0
- data/public/d3/src/time/year.js +7 -0
- data/public/d3/src/time/years.js +11 -0
- data/public/d3/test/core/ascending-test.js +47 -0
- data/public/d3/test/core/bisect-test.js +103 -0
- data/public/d3/test/core/descending-test.js +47 -0
- data/public/d3/test/core/dispatch-test.js +116 -0
- data/public/d3/test/core/ease-test.js +129 -0
- data/public/d3/test/core/entries-test.js +43 -0
- data/public/d3/test/core/first-test.js +42 -0
- data/public/d3/test/core/format-test.js +204 -0
- data/public/d3/test/core/functor-test.js +29 -0
- data/public/d3/test/core/hsl-test.js +87 -0
- data/public/d3/test/core/html-test.js +37 -0
- data/public/d3/test/core/interpolate-test.js +203 -0
- data/public/d3/test/core/json-test.js +37 -0
- data/public/d3/test/core/keys-test.js +31 -0
- data/public/d3/test/core/last-test.js +42 -0
- data/public/d3/test/core/max-test.js +50 -0
- data/public/d3/test/core/merge-test.js +27 -0
- data/public/d3/test/core/min-test.js +50 -0
- data/public/d3/test/core/nest-test.js +236 -0
- data/public/d3/test/core/ns-test.js +53 -0
- data/public/d3/test/core/permute-test.js +53 -0
- data/public/d3/test/core/quantile-test.js +50 -0
- data/public/d3/test/core/range-test.js +93 -0
- data/public/d3/test/core/rebind-test.js +38 -0
- data/public/d3/test/core/requote-test.js +53 -0
- data/public/d3/test/core/rgb-test.js +89 -0
- data/public/d3/test/core/round-test.js +70 -0
- data/public/d3/test/core/select-test.js +42 -0
- data/public/d3/test/core/selectAll-test.js +42 -0
- data/public/d3/test/core/selection-append-test.js +119 -0
- data/public/d3/test/core/selection-attr-test.js +153 -0
- data/public/d3/test/core/selection-call-test.js +71 -0
- data/public/d3/test/core/selection-classed-test.js +200 -0
- data/public/d3/test/core/selection-data-test.js +165 -0
- data/public/d3/test/core/selection-each-test.js +83 -0
- data/public/d3/test/core/selection-empty-test.js +51 -0
- data/public/d3/test/core/selection-filter-test.js +63 -0
- data/public/d3/test/core/selection-html-test.js +121 -0
- data/public/d3/test/core/selection-insert-test.js +132 -0
- data/public/d3/test/core/selection-map-test.js +47 -0
- data/public/d3/test/core/selection-node-test.js +50 -0
- data/public/d3/test/core/selection-on-test.js +95 -0
- data/public/d3/test/core/selection-property-test.js +91 -0
- data/public/d3/test/core/selection-remove-test.js +39 -0
- data/public/d3/test/core/selection-select-test.js +125 -0
- data/public/d3/test/core/selection-selectAll-test.js +127 -0
- data/public/d3/test/core/selection-sort-test.js +59 -0
- data/public/d3/test/core/selection-style-test.js +100 -0
- data/public/d3/test/core/selection-test.js +35 -0
- data/public/d3/test/core/selection-text-test.js +109 -0
- data/public/d3/test/core/split-test.js +34 -0
- data/public/d3/test/core/sum-test.js +47 -0
- data/public/d3/test/core/text-test.js +48 -0
- data/public/d3/test/core/timer-test.js +62 -0
- data/public/d3/test/core/transition-test-attr.js +33 -0
- data/public/d3/test/core/transition-test-attrTween.js +67 -0
- data/public/d3/test/core/transition-test-call.js +33 -0
- data/public/d3/test/core/transition-test-delay.js +41 -0
- data/public/d3/test/core/transition-test-duration.js +41 -0
- data/public/d3/test/core/transition-test-each.js +166 -0
- data/public/d3/test/core/transition-test-id.js +20 -0
- data/public/d3/test/core/transition-test-remove.js +46 -0
- data/public/d3/test/core/transition-test-select.js +63 -0
- data/public/d3/test/core/transition-test-selectAll.js +55 -0
- data/public/d3/test/core/transition-test-style.js +38 -0
- data/public/d3/test/core/transition-test-styleTween.js +73 -0
- data/public/d3/test/core/transition-test-text.js +30 -0
- data/public/d3/test/core/transition-test-transition.js +60 -0
- data/public/d3/test/core/transition-test-tween.js +71 -0
- data/public/d3/test/core/transition-test.js +65 -0
- data/public/d3/test/core/values-test.js +35 -0
- data/public/d3/test/core/version-test.js +18 -0
- data/public/d3/test/core/xhr-test.js +56 -0
- data/public/d3/test/core/xml-test.js +48 -0
- data/public/d3/test/core/zip-test.js +32 -0
- data/public/d3/test/csv/csv-test.js +38 -0
- data/public/d3/test/csv/format-test.js +39 -0
- data/public/d3/test/csv/parse-test.js +101 -0
- data/public/d3/test/env-assert.js +96 -0
- data/public/d3/test/env-fragment.js +8 -0
- data/public/d3/test/env-xhr.js +56 -0
- data/public/d3/test/env.js +13 -0
- data/public/d3/test/geo/albers-test.js +57 -0
- data/public/d3/test/geo/azimuthal-test.js +89 -0
- data/public/d3/test/geo/greatCircle-test.js +42 -0
- data/public/d3/test/geo/mercator-test.js +57 -0
- data/public/d3/test/layout/histogram-test.js +91 -0
- data/public/d3/test/layout/partition-test.js +39 -0
- data/public/d3/test/layout/tree-test.js +21 -0
- data/public/d3/test/layout/treemap-test.js +180 -0
- data/public/d3/test/scale/category-test.js +74 -0
- data/public/d3/test/scale/linear-test.js +239 -0
- data/public/d3/test/scale/log-test.js +220 -0
- data/public/d3/test/scale/ordinal-test.js +193 -0
- data/public/d3/test/scale/pow-test.js +259 -0
- data/public/d3/test/scale/quantile-test.js +64 -0
- data/public/d3/test/scale/quantize-test.js +69 -0
- data/public/d3/test/scale/sqrt-test.js +256 -0
- data/public/d3/test/svg/arc-test.js +147 -0
- data/public/d3/test/svg/area-radial-test.js +200 -0
- data/public/d3/test/svg/area-test.js +191 -0
- data/public/d3/test/svg/axis-test.js +347 -0
- data/public/d3/test/svg/line-radial-test.js +125 -0
- data/public/d3/test/svg/line-test.js +189 -0
- data/public/d3/test/svg/symbol-test.js +96 -0
- data/public/d3/test/time/day-test.js +65 -0
- data/public/d3/test/time/days-test.js +105 -0
- data/public/d3/test/time/format-test.js +430 -0
- data/public/d3/test/time/hour-test.js +103 -0
- data/public/d3/test/time/hours-test.js +135 -0
- data/public/d3/test/time/minute-test.js +43 -0
- data/public/d3/test/time/minutes-test.js +101 -0
- data/public/d3/test/time/month-test.js +53 -0
- data/public/d3/test/time/months-test.js +105 -0
- data/public/d3/test/time/scale-test.js +525 -0
- data/public/d3/test/time/second-test.js +41 -0
- data/public/d3/test/time/seconds-test.js +101 -0
- data/public/d3/test/time/week-test.js +59 -0
- data/public/d3/test/time/weeks-test.js +105 -0
- data/public/d3/test/time/year-test.js +41 -0
- data/public/d3/test/time/years-test.js +73 -0
- data/public/graph.js +42 -0
- data/public/jquery.min.js +4 -0
- data/public/test.html +36 -0
- data/public/testdata/bigfucker.js +212 -0
- data/public/testdata/names_and_enabled.js +232 -0
- data/public/testdata/one.js +79 -0
- data/public/testdata/withnames.js +198 -0
- data/public/viz.js +289 -0
- data/views/graph.erb +15 -0
- data/views/one.erb +34 -0
- data/views/two.erb +44 -0
- data/views/vis.erb +47 -0
- metadata +594 -18
- data/lib/bum.rb +0 -385
- data/lib/client.rb.erb +0 -7
- data/lib/dhcpd.rb +0 -84
- data/lib/hosts.rb +0 -61
- data/lib/vmx.rb +0 -24
@@ -0,0 +1,182 @@
|
|
1
|
+
d3.svg.axis = function() {
|
2
|
+
var scale = d3.scale.linear(),
|
3
|
+
orient = "bottom",
|
4
|
+
tickMajorSize = 6,
|
5
|
+
tickMinorSize = 6,
|
6
|
+
tickEndSize = 6,
|
7
|
+
tickPadding = 3,
|
8
|
+
tickArguments_ = [10],
|
9
|
+
tickFormat_,
|
10
|
+
tickSubdivide = 0;
|
11
|
+
|
12
|
+
function axis(selection) {
|
13
|
+
selection.each(function(d, i, j) {
|
14
|
+
var g = d3.select(this);
|
15
|
+
|
16
|
+
// Ticks.
|
17
|
+
var ticks = scale.ticks.apply(scale, tickArguments_),
|
18
|
+
tickFormat = tickFormat_ == null ? scale.tickFormat.apply(scale, tickArguments_) : tickFormat_;
|
19
|
+
|
20
|
+
// Minor ticks.
|
21
|
+
var subticks = d3_svg_axisSubdivide(scale, ticks, tickSubdivide),
|
22
|
+
subtick = g.selectAll(".minor").data(subticks, String),
|
23
|
+
subtickEnter = subtick.enter().insert("svg:line", "g").attr("class", "tick minor").style("opacity", 1e-6),
|
24
|
+
subtickExit = transition(subtick.exit()).style("opacity", 1e-6).remove(),
|
25
|
+
subtickUpdate = transition(subtick).style("opacity", 1);
|
26
|
+
|
27
|
+
// Major ticks.
|
28
|
+
var tick = g.selectAll("g").data(ticks, String),
|
29
|
+
tickEnter = tick.enter().insert("svg:g", "path").style("opacity", 1e-6),
|
30
|
+
tickExit = transition(tick.exit()).style("opacity", 1e-6).remove(),
|
31
|
+
tickUpdate = transition(tick).style("opacity", 1),
|
32
|
+
tickTransform;
|
33
|
+
|
34
|
+
// Domain.
|
35
|
+
var range = d3_scaleExtent(scale.range()),
|
36
|
+
path = g.selectAll(".domain").data([0]),
|
37
|
+
pathEnter = path.enter().append("svg:path").attr("class", "domain"),
|
38
|
+
pathUpdate = transition(path);
|
39
|
+
|
40
|
+
// Stash the new scale and grab the old scale.
|
41
|
+
var scale0 = this.__chart__ || scale;
|
42
|
+
this.__chart__ = scale.copy();
|
43
|
+
|
44
|
+
tickEnter.append("svg:line").attr("class", "tick");
|
45
|
+
tickEnter.append("svg:text");
|
46
|
+
tickUpdate.select("text").text(tickFormat);
|
47
|
+
|
48
|
+
switch (orient) {
|
49
|
+
case "bottom": {
|
50
|
+
tickTransform = d3_svg_axisX;
|
51
|
+
subtickUpdate.attr("y2", tickMinorSize);
|
52
|
+
tickEnter.select("text").attr("dy", ".71em").attr("text-anchor", "middle");
|
53
|
+
tickUpdate.select("line").attr("y2", tickMajorSize);
|
54
|
+
tickUpdate.select("text").attr("y", Math.max(tickMajorSize, 0) + tickPadding);
|
55
|
+
pathUpdate.attr("d", "M" + range[0] + "," + tickEndSize + "V0H" + range[1] + "V" + tickEndSize);
|
56
|
+
break;
|
57
|
+
}
|
58
|
+
case "top": {
|
59
|
+
tickTransform = d3_svg_axisX;
|
60
|
+
subtickUpdate.attr("y2", -tickMinorSize);
|
61
|
+
tickEnter.select("text").attr("text-anchor", "middle");
|
62
|
+
tickUpdate.select("line").attr("y2", -tickMajorSize);
|
63
|
+
tickUpdate.select("text").attr("y", -(Math.max(tickMajorSize, 0) + tickPadding));
|
64
|
+
pathUpdate.attr("d", "M" + range[0] + "," + -tickEndSize + "V0H" + range[1] + "V" + -tickEndSize);
|
65
|
+
break;
|
66
|
+
}
|
67
|
+
case "left": {
|
68
|
+
tickTransform = d3_svg_axisY;
|
69
|
+
subtickUpdate.attr("x2", -tickMinorSize);
|
70
|
+
tickEnter.select("text").attr("dy", ".32em").attr("text-anchor", "end");
|
71
|
+
tickUpdate.select("line").attr("x2", -tickMajorSize);
|
72
|
+
tickUpdate.select("text").attr("x", -(Math.max(tickMajorSize, 0) + tickPadding));
|
73
|
+
pathUpdate.attr("d", "M" + -tickEndSize + "," + range[0] + "H0V" + range[1] + "H" + -tickEndSize);
|
74
|
+
break;
|
75
|
+
}
|
76
|
+
case "right": {
|
77
|
+
tickTransform = d3_svg_axisY;
|
78
|
+
subtickUpdate.attr("x2", tickMinorSize);
|
79
|
+
tickEnter.select("text").attr("dy", ".32em");
|
80
|
+
tickUpdate.select("line").attr("x2", tickMajorSize);
|
81
|
+
tickUpdate.select("text").attr("x", Math.max(tickMajorSize, 0) + tickPadding);
|
82
|
+
pathUpdate.attr("d", "M" + tickEndSize + "," + range[0] + "H0V" + range[1] + "H" + tickEndSize);
|
83
|
+
break;
|
84
|
+
}
|
85
|
+
}
|
86
|
+
|
87
|
+
tickEnter.call(tickTransform, scale0);
|
88
|
+
tickUpdate.call(tickTransform, scale);
|
89
|
+
tickExit.call(tickTransform, scale);
|
90
|
+
|
91
|
+
subtickEnter.call(tickTransform, scale0);
|
92
|
+
subtickUpdate.call(tickTransform, scale);
|
93
|
+
subtickExit.call(tickTransform, scale);
|
94
|
+
|
95
|
+
function transition(o) {
|
96
|
+
return selection.delay ? o.transition()
|
97
|
+
.delay(selection[j][i].delay)
|
98
|
+
.duration(selection[j][i].duration)
|
99
|
+
.ease(selection.ease()) : o;
|
100
|
+
}
|
101
|
+
});
|
102
|
+
}
|
103
|
+
|
104
|
+
axis.scale = function(x) {
|
105
|
+
if (!arguments.length) return scale;
|
106
|
+
scale = x;
|
107
|
+
return axis;
|
108
|
+
};
|
109
|
+
|
110
|
+
axis.orient = function(x) {
|
111
|
+
if (!arguments.length) return orient;
|
112
|
+
orient = x;
|
113
|
+
return axis;
|
114
|
+
};
|
115
|
+
|
116
|
+
axis.ticks = function() {
|
117
|
+
if (!arguments.length) return tickArguments_;
|
118
|
+
tickArguments_ = arguments;
|
119
|
+
return axis;
|
120
|
+
};
|
121
|
+
|
122
|
+
axis.tickFormat = function(x) {
|
123
|
+
if (!arguments.length) return tickFormat_;
|
124
|
+
tickFormat_ = x;
|
125
|
+
return axis;
|
126
|
+
};
|
127
|
+
|
128
|
+
axis.tickSize = function(x, y, z) {
|
129
|
+
if (!arguments.length) return tickMajorSize;
|
130
|
+
var n = arguments.length - 1;
|
131
|
+
tickMajorSize = +x;
|
132
|
+
tickMinorSize = n > 1 ? +y : tickMajorSize;
|
133
|
+
tickEndSize = n > 0 ? +arguments[n] : tickMajorSize;
|
134
|
+
return axis;
|
135
|
+
};
|
136
|
+
|
137
|
+
axis.tickPadding = function(x) {
|
138
|
+
if (!arguments.length) return tickPadding;
|
139
|
+
tickPadding = +x;
|
140
|
+
return axis;
|
141
|
+
};
|
142
|
+
|
143
|
+
axis.tickSubdivide = function(x) {
|
144
|
+
if (!arguments.length) return tickSubdivide;
|
145
|
+
tickSubdivide = +x;
|
146
|
+
return axis;
|
147
|
+
};
|
148
|
+
|
149
|
+
return axis;
|
150
|
+
};
|
151
|
+
|
152
|
+
function d3_svg_axisX(selection, x) {
|
153
|
+
selection.attr("transform", function(d) { return "translate(" + x(d) + ",0)"; });
|
154
|
+
}
|
155
|
+
|
156
|
+
function d3_svg_axisY(selection, y) {
|
157
|
+
selection.attr("transform", function(d) { return "translate(0," + y(d) + ")"; });
|
158
|
+
}
|
159
|
+
|
160
|
+
function d3_svg_axisSubdivide(scale, ticks, m) {
|
161
|
+
subticks = [];
|
162
|
+
if (m && ticks.length > 1) {
|
163
|
+
var extent = d3_scaleExtent(scale.domain()),
|
164
|
+
subticks,
|
165
|
+
i = -1,
|
166
|
+
n = ticks.length,
|
167
|
+
d = (ticks[1] - ticks[0]) / ++m,
|
168
|
+
j,
|
169
|
+
v;
|
170
|
+
while (++i < n) {
|
171
|
+
for (j = m; --j > 0;) {
|
172
|
+
if ((v = +ticks[i] - j * d) >= extent[0]) {
|
173
|
+
subticks.push(v);
|
174
|
+
}
|
175
|
+
}
|
176
|
+
}
|
177
|
+
for (--i, j = 0; ++j < m && (v = +ticks[i] + j * d) < extent[1];) {
|
178
|
+
subticks.push(v);
|
179
|
+
}
|
180
|
+
}
|
181
|
+
return subticks;
|
182
|
+
}
|
@@ -0,0 +1,99 @@
|
|
1
|
+
d3.svg.chord = function() {
|
2
|
+
var source = d3_svg_chordSource,
|
3
|
+
target = d3_svg_chordTarget,
|
4
|
+
radius = d3_svg_chordRadius,
|
5
|
+
startAngle = d3_svg_arcStartAngle,
|
6
|
+
endAngle = d3_svg_arcEndAngle;
|
7
|
+
|
8
|
+
// TODO Allow control point to be customized.
|
9
|
+
|
10
|
+
function chord(d, i) {
|
11
|
+
var s = subgroup(this, source, d, i),
|
12
|
+
t = subgroup(this, target, d, i);
|
13
|
+
return "M" + s.p0
|
14
|
+
+ arc(s.r, s.p1) + (equals(s, t)
|
15
|
+
? curve(s.r, s.p1, s.r, s.p0)
|
16
|
+
: curve(s.r, s.p1, t.r, t.p0)
|
17
|
+
+ arc(t.r, t.p1)
|
18
|
+
+ curve(t.r, t.p1, s.r, s.p0))
|
19
|
+
+ "Z";
|
20
|
+
}
|
21
|
+
|
22
|
+
function subgroup(self, f, d, i) {
|
23
|
+
var subgroup = f.call(self, d, i),
|
24
|
+
r = radius.call(self, subgroup, i),
|
25
|
+
a0 = startAngle.call(self, subgroup, i) + d3_svg_arcOffset,
|
26
|
+
a1 = endAngle.call(self, subgroup, i) + d3_svg_arcOffset;
|
27
|
+
return {
|
28
|
+
r: r,
|
29
|
+
a0: a0,
|
30
|
+
a1: a1,
|
31
|
+
p0: [r * Math.cos(a0), r * Math.sin(a0)],
|
32
|
+
p1: [r * Math.cos(a1), r * Math.sin(a1)]
|
33
|
+
};
|
34
|
+
}
|
35
|
+
|
36
|
+
function equals(a, b) {
|
37
|
+
return a.a0 == b.a0 && a.a1 == b.a1;
|
38
|
+
}
|
39
|
+
|
40
|
+
function arc(r, p) {
|
41
|
+
return "A" + r + "," + r + " 0 0,1 " + p;
|
42
|
+
}
|
43
|
+
|
44
|
+
function curve(r0, p0, r1, p1) {
|
45
|
+
return "Q 0,0 " + p1;
|
46
|
+
}
|
47
|
+
|
48
|
+
chord.radius = function(v) {
|
49
|
+
if (!arguments.length) return radius;
|
50
|
+
radius = d3.functor(v);
|
51
|
+
return chord;
|
52
|
+
};
|
53
|
+
|
54
|
+
chord.source = function(v) {
|
55
|
+
if (!arguments.length) return source;
|
56
|
+
source = d3.functor(v);
|
57
|
+
return chord;
|
58
|
+
};
|
59
|
+
|
60
|
+
chord.target = function(v) {
|
61
|
+
if (!arguments.length) return target;
|
62
|
+
target = d3.functor(v);
|
63
|
+
return chord;
|
64
|
+
};
|
65
|
+
|
66
|
+
chord.startAngle = function(v) {
|
67
|
+
if (!arguments.length) return startAngle;
|
68
|
+
startAngle = d3.functor(v);
|
69
|
+
return chord;
|
70
|
+
};
|
71
|
+
|
72
|
+
chord.endAngle = function(v) {
|
73
|
+
if (!arguments.length) return endAngle;
|
74
|
+
endAngle = d3.functor(v);
|
75
|
+
return chord;
|
76
|
+
};
|
77
|
+
|
78
|
+
return chord;
|
79
|
+
};
|
80
|
+
|
81
|
+
function d3_svg_chordSource(d) {
|
82
|
+
return d.source;
|
83
|
+
}
|
84
|
+
|
85
|
+
function d3_svg_chordTarget(d) {
|
86
|
+
return d.target;
|
87
|
+
}
|
88
|
+
|
89
|
+
function d3_svg_chordRadius(d) {
|
90
|
+
return d.radius;
|
91
|
+
}
|
92
|
+
|
93
|
+
function d3_svg_chordStartAngle(d) {
|
94
|
+
return d.startAngle;
|
95
|
+
}
|
96
|
+
|
97
|
+
function d3_svg_chordEndAngle(d) {
|
98
|
+
return d.endAngle;
|
99
|
+
}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
d3.svg.diagonal.radial = function() {
|
2
|
+
var diagonal = d3.svg.diagonal(),
|
3
|
+
projection = d3_svg_diagonalProjection,
|
4
|
+
projection_ = diagonal.projection;
|
5
|
+
|
6
|
+
diagonal.projection = function(x) {
|
7
|
+
return arguments.length
|
8
|
+
? projection_(d3_svg_diagonalRadialProjection(projection = x))
|
9
|
+
: projection;
|
10
|
+
};
|
11
|
+
|
12
|
+
return diagonal;
|
13
|
+
};
|
14
|
+
|
15
|
+
function d3_svg_diagonalRadialProjection(projection) {
|
16
|
+
return function() {
|
17
|
+
var d = projection.apply(this, arguments),
|
18
|
+
r = d[0],
|
19
|
+
a = d[1] + d3_svg_arcOffset;
|
20
|
+
return [r * Math.cos(a), r * Math.sin(a)];
|
21
|
+
};
|
22
|
+
}
|
@@ -0,0 +1,38 @@
|
|
1
|
+
d3.svg.diagonal = function() {
|
2
|
+
var source = d3_svg_chordSource,
|
3
|
+
target = d3_svg_chordTarget,
|
4
|
+
projection = d3_svg_diagonalProjection;
|
5
|
+
|
6
|
+
function diagonal(d, i) {
|
7
|
+
var p0 = source.call(this, d, i),
|
8
|
+
p3 = target.call(this, d, i),
|
9
|
+
m = (p0.y + p3.y) / 2,
|
10
|
+
p = [p0, {x: p0.x, y: m}, {x: p3.x, y: m}, p3];
|
11
|
+
p = p.map(projection);
|
12
|
+
return "M" + p[0] + "C" + p[1] + " " + p[2] + " " + p[3];
|
13
|
+
}
|
14
|
+
|
15
|
+
diagonal.source = function(x) {
|
16
|
+
if (!arguments.length) return source;
|
17
|
+
source = d3.functor(x);
|
18
|
+
return diagonal;
|
19
|
+
};
|
20
|
+
|
21
|
+
diagonal.target = function(x) {
|
22
|
+
if (!arguments.length) return target;
|
23
|
+
target = d3.functor(x);
|
24
|
+
return diagonal;
|
25
|
+
};
|
26
|
+
|
27
|
+
diagonal.projection = function(x) {
|
28
|
+
if (!arguments.length) return projection;
|
29
|
+
projection = x;
|
30
|
+
return diagonal;
|
31
|
+
};
|
32
|
+
|
33
|
+
return diagonal;
|
34
|
+
};
|
35
|
+
|
36
|
+
function d3_svg_diagonalProjection(d) {
|
37
|
+
return [d.x, d.y];
|
38
|
+
}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
d3.svg.line.radial = function() {
|
2
|
+
var line = d3_svg_line(d3_svg_lineRadial);
|
3
|
+
line.radius = line.x, delete line.x;
|
4
|
+
line.angle = line.y, delete line.y;
|
5
|
+
return line;
|
6
|
+
};
|
7
|
+
|
8
|
+
function d3_svg_lineRadial(points) {
|
9
|
+
var point,
|
10
|
+
i = -1,
|
11
|
+
n = points.length,
|
12
|
+
r,
|
13
|
+
a;
|
14
|
+
while (++i < n) {
|
15
|
+
point = points[i];
|
16
|
+
r = point[0];
|
17
|
+
a = point[1] + d3_svg_arcOffset;
|
18
|
+
point[0] = r * Math.cos(a);
|
19
|
+
point[1] = r * Math.sin(a);
|
20
|
+
}
|
21
|
+
return points;
|
22
|
+
}
|
@@ -0,0 +1,419 @@
|
|
1
|
+
function d3_svg_line(projection) {
|
2
|
+
var x = d3_svg_lineX,
|
3
|
+
y = d3_svg_lineY,
|
4
|
+
interpolate = "linear",
|
5
|
+
interpolator = d3_svg_lineInterpolators[interpolate],
|
6
|
+
tension = .7;
|
7
|
+
|
8
|
+
function line(d) {
|
9
|
+
return d.length < 1 ? null : "M" + interpolator(projection(d3_svg_linePoints(this, d, x, y)), tension);
|
10
|
+
}
|
11
|
+
|
12
|
+
line.x = function(v) {
|
13
|
+
if (!arguments.length) return x;
|
14
|
+
x = v;
|
15
|
+
return line;
|
16
|
+
};
|
17
|
+
|
18
|
+
line.y = function(v) {
|
19
|
+
if (!arguments.length) return y;
|
20
|
+
y = v;
|
21
|
+
return line;
|
22
|
+
};
|
23
|
+
|
24
|
+
line.interpolate = function(v) {
|
25
|
+
if (!arguments.length) return interpolate;
|
26
|
+
interpolator = d3_svg_lineInterpolators[interpolate = v];
|
27
|
+
return line;
|
28
|
+
};
|
29
|
+
|
30
|
+
line.tension = function(v) {
|
31
|
+
if (!arguments.length) return tension;
|
32
|
+
tension = v;
|
33
|
+
return line;
|
34
|
+
};
|
35
|
+
|
36
|
+
return line;
|
37
|
+
}
|
38
|
+
|
39
|
+
d3.svg.line = function() {
|
40
|
+
return d3_svg_line(Object);
|
41
|
+
};
|
42
|
+
|
43
|
+
// Converts the specified array of data into an array of points
|
44
|
+
// (x-y tuples), by evaluating the specified `x` and `y` functions on each
|
45
|
+
// data point. The `this` context of the evaluated functions is the specified
|
46
|
+
// "self" object; each function is passed the current datum and index.
|
47
|
+
function d3_svg_linePoints(self, d, x, y) {
|
48
|
+
var points = [],
|
49
|
+
i = -1,
|
50
|
+
n = d.length,
|
51
|
+
fx = typeof x === "function",
|
52
|
+
fy = typeof y === "function",
|
53
|
+
value;
|
54
|
+
if (fx && fy) {
|
55
|
+
while (++i < n) points.push([
|
56
|
+
x.call(self, value = d[i], i),
|
57
|
+
y.call(self, value, i)
|
58
|
+
]);
|
59
|
+
} else if (fx) {
|
60
|
+
while (++i < n) points.push([x.call(self, d[i], i), y]);
|
61
|
+
} else if (fy) {
|
62
|
+
while (++i < n) points.push([x, y.call(self, d[i], i)]);
|
63
|
+
} else {
|
64
|
+
while (++i < n) points.push([x, y]);
|
65
|
+
}
|
66
|
+
return points;
|
67
|
+
}
|
68
|
+
|
69
|
+
// The default `x` property, which references d[0].
|
70
|
+
function d3_svg_lineX(d) {
|
71
|
+
return d[0];
|
72
|
+
}
|
73
|
+
|
74
|
+
// The default `y` property, which references d[1].
|
75
|
+
function d3_svg_lineY(d) {
|
76
|
+
return d[1];
|
77
|
+
}
|
78
|
+
|
79
|
+
// The various interpolators supported by the `line` class.
|
80
|
+
var d3_svg_lineInterpolators = {
|
81
|
+
"linear": d3_svg_lineLinear,
|
82
|
+
"step-before": d3_svg_lineStepBefore,
|
83
|
+
"step-after": d3_svg_lineStepAfter,
|
84
|
+
"basis": d3_svg_lineBasis,
|
85
|
+
"basis-open": d3_svg_lineBasisOpen,
|
86
|
+
"basis-closed": d3_svg_lineBasisClosed,
|
87
|
+
"bundle": d3_svg_lineBundle,
|
88
|
+
"cardinal": d3_svg_lineCardinal,
|
89
|
+
"cardinal-open": d3_svg_lineCardinalOpen,
|
90
|
+
"cardinal-closed": d3_svg_lineCardinalClosed,
|
91
|
+
"monotone": d3_svg_lineMonotone
|
92
|
+
};
|
93
|
+
|
94
|
+
// Linear interpolation; generates "L" commands.
|
95
|
+
function d3_svg_lineLinear(points) {
|
96
|
+
var path = [],
|
97
|
+
i = 0,
|
98
|
+
n = points.length,
|
99
|
+
p = points[0];
|
100
|
+
path.push(p[0], ",", p[1]);
|
101
|
+
while (++i < n) path.push("L", (p = points[i])[0], ",", p[1]);
|
102
|
+
return path.join("");
|
103
|
+
}
|
104
|
+
|
105
|
+
// Step interpolation; generates "H" and "V" commands.
|
106
|
+
function d3_svg_lineStepBefore(points) {
|
107
|
+
var path = [],
|
108
|
+
i = 0,
|
109
|
+
n = points.length,
|
110
|
+
p = points[0];
|
111
|
+
path.push(p[0], ",", p[1]);
|
112
|
+
while (++i < n) path.push("V", (p = points[i])[1], "H", p[0]);
|
113
|
+
return path.join("");
|
114
|
+
}
|
115
|
+
|
116
|
+
// Step interpolation; generates "H" and "V" commands.
|
117
|
+
function d3_svg_lineStepAfter(points) {
|
118
|
+
var path = [],
|
119
|
+
i = 0,
|
120
|
+
n = points.length,
|
121
|
+
p = points[0];
|
122
|
+
path.push(p[0], ",", p[1]);
|
123
|
+
while (++i < n) path.push("H", (p = points[i])[0], "V", p[1]);
|
124
|
+
return path.join("");
|
125
|
+
}
|
126
|
+
|
127
|
+
// Open cardinal spline interpolation; generates "C" commands.
|
128
|
+
function d3_svg_lineCardinalOpen(points, tension) {
|
129
|
+
return points.length < 4
|
130
|
+
? d3_svg_lineLinear(points)
|
131
|
+
: points[1] + d3_svg_lineHermite(points.slice(1, points.length - 1),
|
132
|
+
d3_svg_lineCardinalTangents(points, tension));
|
133
|
+
}
|
134
|
+
|
135
|
+
// Closed cardinal spline interpolation; generates "C" commands.
|
136
|
+
function d3_svg_lineCardinalClosed(points, tension) {
|
137
|
+
return points.length < 3
|
138
|
+
? d3_svg_lineLinear(points)
|
139
|
+
: points[0] + d3_svg_lineHermite((points.push(points[0]), points),
|
140
|
+
d3_svg_lineCardinalTangents([points[points.length - 2]]
|
141
|
+
.concat(points, [points[1]]), tension));
|
142
|
+
}
|
143
|
+
|
144
|
+
// Cardinal spline interpolation; generates "C" commands.
|
145
|
+
function d3_svg_lineCardinal(points, tension, closed) {
|
146
|
+
return points.length < 3
|
147
|
+
? d3_svg_lineLinear(points)
|
148
|
+
: points[0] + d3_svg_lineHermite(points,
|
149
|
+
d3_svg_lineCardinalTangents(points, tension));
|
150
|
+
}
|
151
|
+
|
152
|
+
// Hermite spline construction; generates "C" commands.
|
153
|
+
function d3_svg_lineHermite(points, tangents) {
|
154
|
+
if (tangents.length < 1
|
155
|
+
|| (points.length != tangents.length
|
156
|
+
&& points.length != tangents.length + 2)) {
|
157
|
+
return d3_svg_lineLinear(points);
|
158
|
+
}
|
159
|
+
|
160
|
+
var quad = points.length != tangents.length,
|
161
|
+
path = "",
|
162
|
+
p0 = points[0],
|
163
|
+
p = points[1],
|
164
|
+
t0 = tangents[0],
|
165
|
+
t = t0,
|
166
|
+
pi = 1;
|
167
|
+
|
168
|
+
if (quad) {
|
169
|
+
path += "Q" + (p[0] - t0[0] * 2 / 3) + "," + (p[1] - t0[1] * 2 / 3)
|
170
|
+
+ "," + p[0] + "," + p[1];
|
171
|
+
p0 = points[1];
|
172
|
+
pi = 2;
|
173
|
+
}
|
174
|
+
|
175
|
+
if (tangents.length > 1) {
|
176
|
+
t = tangents[1];
|
177
|
+
p = points[pi];
|
178
|
+
pi++;
|
179
|
+
path += "C" + (p0[0] + t0[0]) + "," + (p0[1] + t0[1])
|
180
|
+
+ "," + (p[0] - t[0]) + "," + (p[1] - t[1])
|
181
|
+
+ "," + p[0] + "," + p[1];
|
182
|
+
for (var i = 2; i < tangents.length; i++, pi++) {
|
183
|
+
p = points[pi];
|
184
|
+
t = tangents[i];
|
185
|
+
path += "S" + (p[0] - t[0]) + "," + (p[1] - t[1])
|
186
|
+
+ "," + p[0] + "," + p[1];
|
187
|
+
}
|
188
|
+
}
|
189
|
+
|
190
|
+
if (quad) {
|
191
|
+
var lp = points[pi];
|
192
|
+
path += "Q" + (p[0] + t[0] * 2 / 3) + "," + (p[1] + t[1] * 2 / 3)
|
193
|
+
+ "," + lp[0] + "," + lp[1];
|
194
|
+
}
|
195
|
+
|
196
|
+
return path;
|
197
|
+
}
|
198
|
+
|
199
|
+
// Generates tangents for a cardinal spline.
|
200
|
+
function d3_svg_lineCardinalTangents(points, tension) {
|
201
|
+
var tangents = [],
|
202
|
+
a = (1 - tension) / 2,
|
203
|
+
p0,
|
204
|
+
p1 = points[0],
|
205
|
+
p2 = points[1],
|
206
|
+
i = 1,
|
207
|
+
n = points.length;
|
208
|
+
while (++i < n) {
|
209
|
+
p0 = p1;
|
210
|
+
p1 = p2;
|
211
|
+
p2 = points[i];
|
212
|
+
tangents.push([a * (p2[0] - p0[0]), a * (p2[1] - p0[1])]);
|
213
|
+
}
|
214
|
+
return tangents;
|
215
|
+
}
|
216
|
+
|
217
|
+
// B-spline interpolation; generates "C" commands.
|
218
|
+
function d3_svg_lineBasis(points) {
|
219
|
+
if (points.length < 3) return d3_svg_lineLinear(points);
|
220
|
+
var path = [],
|
221
|
+
i = 1,
|
222
|
+
n = points.length,
|
223
|
+
pi = points[0],
|
224
|
+
x0 = pi[0],
|
225
|
+
y0 = pi[1],
|
226
|
+
px = [x0, x0, x0, (pi = points[1])[0]],
|
227
|
+
py = [y0, y0, y0, pi[1]];
|
228
|
+
path.push(x0, ",", y0);
|
229
|
+
d3_svg_lineBasisBezier(path, px, py);
|
230
|
+
while (++i < n) {
|
231
|
+
pi = points[i];
|
232
|
+
px.shift(); px.push(pi[0]);
|
233
|
+
py.shift(); py.push(pi[1]);
|
234
|
+
d3_svg_lineBasisBezier(path, px, py);
|
235
|
+
}
|
236
|
+
i = -1;
|
237
|
+
while (++i < 2) {
|
238
|
+
px.shift(); px.push(pi[0]);
|
239
|
+
py.shift(); py.push(pi[1]);
|
240
|
+
d3_svg_lineBasisBezier(path, px, py);
|
241
|
+
}
|
242
|
+
return path.join("");
|
243
|
+
}
|
244
|
+
|
245
|
+
// Open B-spline interpolation; generates "C" commands.
|
246
|
+
function d3_svg_lineBasisOpen(points) {
|
247
|
+
if (points.length < 4) return d3_svg_lineLinear(points);
|
248
|
+
var path = [],
|
249
|
+
i = -1,
|
250
|
+
n = points.length,
|
251
|
+
pi,
|
252
|
+
px = [0],
|
253
|
+
py = [0];
|
254
|
+
while (++i < 3) {
|
255
|
+
pi = points[i];
|
256
|
+
px.push(pi[0]);
|
257
|
+
py.push(pi[1]);
|
258
|
+
}
|
259
|
+
path.push(d3_svg_lineDot4(d3_svg_lineBasisBezier3, px)
|
260
|
+
+ "," + d3_svg_lineDot4(d3_svg_lineBasisBezier3, py));
|
261
|
+
--i; while (++i < n) {
|
262
|
+
pi = points[i];
|
263
|
+
px.shift(); px.push(pi[0]);
|
264
|
+
py.shift(); py.push(pi[1]);
|
265
|
+
d3_svg_lineBasisBezier(path, px, py);
|
266
|
+
}
|
267
|
+
return path.join("");
|
268
|
+
}
|
269
|
+
|
270
|
+
// Closed B-spline interpolation; generates "C" commands.
|
271
|
+
function d3_svg_lineBasisClosed(points) {
|
272
|
+
var path,
|
273
|
+
i = -1,
|
274
|
+
n = points.length,
|
275
|
+
m = n + 4,
|
276
|
+
pi,
|
277
|
+
px = [],
|
278
|
+
py = [];
|
279
|
+
while (++i < 4) {
|
280
|
+
pi = points[i % n];
|
281
|
+
px.push(pi[0]);
|
282
|
+
py.push(pi[1]);
|
283
|
+
}
|
284
|
+
path = [
|
285
|
+
d3_svg_lineDot4(d3_svg_lineBasisBezier3, px), ",",
|
286
|
+
d3_svg_lineDot4(d3_svg_lineBasisBezier3, py)
|
287
|
+
];
|
288
|
+
--i; while (++i < m) {
|
289
|
+
pi = points[i % n];
|
290
|
+
px.shift(); px.push(pi[0]);
|
291
|
+
py.shift(); py.push(pi[1]);
|
292
|
+
d3_svg_lineBasisBezier(path, px, py);
|
293
|
+
}
|
294
|
+
return path.join("");
|
295
|
+
}
|
296
|
+
|
297
|
+
function d3_svg_lineBundle(points, tension) {
|
298
|
+
var n = points.length - 1,
|
299
|
+
x0 = points[0][0],
|
300
|
+
y0 = points[0][1],
|
301
|
+
dx = points[n][0] - x0,
|
302
|
+
dy = points[n][1] - y0,
|
303
|
+
i = -1,
|
304
|
+
p,
|
305
|
+
t;
|
306
|
+
while (++i <= n) {
|
307
|
+
p = points[i];
|
308
|
+
t = i / n;
|
309
|
+
p[0] = tension * p[0] + (1 - tension) * (x0 + t * dx);
|
310
|
+
p[1] = tension * p[1] + (1 - tension) * (y0 + t * dy);
|
311
|
+
}
|
312
|
+
return d3_svg_lineBasis(points);
|
313
|
+
}
|
314
|
+
|
315
|
+
// Returns the dot product of the given four-element vectors.
|
316
|
+
function d3_svg_lineDot4(a, b) {
|
317
|
+
return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];
|
318
|
+
}
|
319
|
+
|
320
|
+
// Matrix to transform basis (b-spline) control points to bezier
|
321
|
+
// control points. Derived from FvD 11.2.8.
|
322
|
+
var d3_svg_lineBasisBezier1 = [0, 2/3, 1/3, 0],
|
323
|
+
d3_svg_lineBasisBezier2 = [0, 1/3, 2/3, 0],
|
324
|
+
d3_svg_lineBasisBezier3 = [0, 1/6, 2/3, 1/6];
|
325
|
+
|
326
|
+
// Pushes a "C" Bézier curve onto the specified path array, given the
|
327
|
+
// two specified four-element arrays which define the control points.
|
328
|
+
function d3_svg_lineBasisBezier(path, x, y) {
|
329
|
+
path.push(
|
330
|
+
"C", d3_svg_lineDot4(d3_svg_lineBasisBezier1, x),
|
331
|
+
",", d3_svg_lineDot4(d3_svg_lineBasisBezier1, y),
|
332
|
+
",", d3_svg_lineDot4(d3_svg_lineBasisBezier2, x),
|
333
|
+
",", d3_svg_lineDot4(d3_svg_lineBasisBezier2, y),
|
334
|
+
",", d3_svg_lineDot4(d3_svg_lineBasisBezier3, x),
|
335
|
+
",", d3_svg_lineDot4(d3_svg_lineBasisBezier3, y));
|
336
|
+
}
|
337
|
+
|
338
|
+
// Computes the slope from points p0 to p1.
|
339
|
+
function d3_svg_lineSlope(p0, p1) {
|
340
|
+
return (p1[1] - p0[1]) / (p1[0] - p0[0]);
|
341
|
+
}
|
342
|
+
|
343
|
+
// Compute three-point differences for the given points.
|
344
|
+
// http://en.wikipedia.org/wiki/Cubic_Hermite_spline#Finite_difference
|
345
|
+
function d3_svg_lineFiniteDifferences(points) {
|
346
|
+
var i = 0,
|
347
|
+
j = points.length - 1,
|
348
|
+
m = [],
|
349
|
+
p0 = points[0],
|
350
|
+
p1 = points[1],
|
351
|
+
d = m[0] = d3_svg_lineSlope(p0, p1);
|
352
|
+
while (++i < j) {
|
353
|
+
m[i] = d + (d = d3_svg_lineSlope(p0 = p1, p1 = points[i + 1]));
|
354
|
+
}
|
355
|
+
m[i] = d;
|
356
|
+
return m;
|
357
|
+
}
|
358
|
+
|
359
|
+
// Interpolates the given points using Fritsch-Carlson Monotone cubic Hermite
|
360
|
+
// interpolation. Returns an array of tangent vectors. For details, see
|
361
|
+
// http://en.wikipedia.org/wiki/Monotone_cubic_interpolation
|
362
|
+
function d3_svg_lineMonotoneTangents(points) {
|
363
|
+
var tangents = [],
|
364
|
+
d,
|
365
|
+
a,
|
366
|
+
b,
|
367
|
+
s,
|
368
|
+
m = d3_svg_lineFiniteDifferences(points),
|
369
|
+
i = -1,
|
370
|
+
j = points.length - 1;
|
371
|
+
|
372
|
+
// The first two steps are done by computing finite-differences:
|
373
|
+
// 1. Compute the slopes of the secant lines between successive points.
|
374
|
+
// 2. Initialize the tangents at every point as the average of the secants.
|
375
|
+
|
376
|
+
// Then, for each segment…
|
377
|
+
while (++i < j) {
|
378
|
+
d = d3_svg_lineSlope(points[i], points[i + 1]);
|
379
|
+
|
380
|
+
// 3. If two successive yk = y{k + 1} are equal (i.e., d is zero), then set
|
381
|
+
// mk = m{k + 1} = 0 as the spline connecting these points must be flat to
|
382
|
+
// preserve monotonicity. Ignore step 4 and 5 for those k.
|
383
|
+
|
384
|
+
if (Math.abs(d) < 1e-6) {
|
385
|
+
m[i] = m[i + 1] = 0;
|
386
|
+
} else {
|
387
|
+
// 4. Let ak = mk / dk and bk = m{k + 1} / dk.
|
388
|
+
a = m[i] / d;
|
389
|
+
b = m[i + 1] / d;
|
390
|
+
|
391
|
+
// 5. Prevent overshoot and ensure monotonicity by restricting the
|
392
|
+
// magnitude of vector <ak, bk> to a circle of radius 3.
|
393
|
+
s = a * a + b * b;
|
394
|
+
if (s > 9) {
|
395
|
+
s = d * 3 / Math.sqrt(s);
|
396
|
+
m[i] = s * a;
|
397
|
+
m[i + 1] = s * b;
|
398
|
+
}
|
399
|
+
}
|
400
|
+
}
|
401
|
+
|
402
|
+
// Compute the normalized tangent vector from the slopes. Note that if x is
|
403
|
+
// not monotonic, it's possible that the slope will be infinite, so we protect
|
404
|
+
// against NaN by setting the coordinate to zero.
|
405
|
+
i = -1; while (++i <= j) {
|
406
|
+
s = (points[Math.min(j, i + 1)][0] - points[Math.max(0, i - 1)][0])
|
407
|
+
/ (6 * (1 + m[i] * m[i]));
|
408
|
+
tangents.push([s || 0, m[i] * s || 0]);
|
409
|
+
}
|
410
|
+
|
411
|
+
return tangents;
|
412
|
+
}
|
413
|
+
|
414
|
+
function d3_svg_lineMonotone(points) {
|
415
|
+
return points.length < 3
|
416
|
+
? d3_svg_lineLinear(points)
|
417
|
+
: points[0] +
|
418
|
+
d3_svg_lineHermite(points, d3_svg_lineMonotoneTangents(points));
|
419
|
+
}
|