stripmem 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/LICENSE +21 -0
- data/README.md +25 -0
- data/exe/stripmem +5 -0
- data/lib/stripmem/app.rb +67 -0
- data/lib/stripmem/public/app.css +37 -0
- data/lib/stripmem/public/app.js +167 -0
- data/lib/stripmem/public/components/d3/LICENSE +26 -0
- data/lib/stripmem/public/components/d3/Makefile +45 -0
- data/lib/stripmem/public/components/d3/README.md +7 -0
- data/lib/stripmem/public/components/d3/bin/bower +29 -0
- data/lib/stripmem/public/components/d3/bin/component +20 -0
- data/lib/stripmem/public/components/d3/bin/locale +33 -0
- data/lib/stripmem/public/components/d3/bin/start +3 -0
- data/lib/stripmem/public/components/d3/bin/uglify +34 -0
- data/lib/stripmem/public/components/d3/bower.json +25 -0
- data/lib/stripmem/public/components/d3/component.json +30 -0
- data/lib/stripmem/public/components/d3/d3.js +8798 -0
- data/lib/stripmem/public/components/d3/d3.min.js +5 -0
- data/lib/stripmem/public/components/d3/index-browserify.js +3 -0
- data/lib/stripmem/public/components/d3/index.js +15 -0
- data/lib/stripmem/public/components/d3/lib/colorbrewer/LICENSE +38 -0
- data/lib/stripmem/public/components/d3/lib/colorbrewer/colorbrewer.css +1690 -0
- data/lib/stripmem/public/components/d3/lib/colorbrewer/colorbrewer.js +302 -0
- data/lib/stripmem/public/components/d3/lib/geographiclib/LICENSE +23 -0
- data/lib/stripmem/public/components/d3/lib/jit/LICENSE +27 -0
- data/lib/stripmem/public/components/d3/lib/penner/LICENSE +31 -0
- data/lib/stripmem/public/components/d3/lib/polymaps/LICENSE +28 -0
- data/lib/stripmem/public/components/d3/lib/protovis/LICENSE +27 -0
- data/lib/stripmem/public/components/d3/lib/science/LICENSE +26 -0
- data/lib/stripmem/public/components/d3/lib/science/science.js +225 -0
- data/lib/stripmem/public/components/d3/lib/science/science.lin.js +27 -0
- data/lib/stripmem/public/components/d3/lib/science/science.lin.min.js +1 -0
- data/lib/stripmem/public/components/d3/lib/science/science.min.js +1 -0
- data/lib/stripmem/public/components/d3/lib/science/science.stats.js +720 -0
- data/lib/stripmem/public/components/d3/lib/science/science.stats.min.js +1 -0
- data/lib/stripmem/public/components/d3/package.json +53 -0
- data/lib/stripmem/public/components/d3/src/arrays/ascending.js +3 -0
- data/lib/stripmem/public/components/d3/src/arrays/bisect.js +28 -0
- data/lib/stripmem/public/components/d3/src/arrays/descending.js +3 -0
- data/lib/stripmem/public/components/d3/src/arrays/entries.js +5 -0
- data/lib/stripmem/public/components/d3/src/arrays/extent.js +21 -0
- data/lib/stripmem/public/components/d3/src/arrays/index.js +22 -0
- data/lib/stripmem/public/components/d3/src/arrays/keys.js +5 -0
- data/lib/stripmem/public/components/d3/src/arrays/map.js +50 -0
- data/lib/stripmem/public/components/d3/src/arrays/max.js +14 -0
- data/lib/stripmem/public/components/d3/src/arrays/mean.js +15 -0
- data/lib/stripmem/public/components/d3/src/arrays/median.js +9 -0
- data/lib/stripmem/public/components/d3/src/arrays/merge.js +3 -0
- data/lib/stripmem/public/components/d3/src/arrays/min.js +14 -0
- data/lib/stripmem/public/components/d3/src/arrays/nest.js +97 -0
- data/lib/stripmem/public/components/d3/src/arrays/permute.js +7 -0
- data/lib/stripmem/public/components/d3/src/arrays/quantile.js +8 -0
- data/lib/stripmem/public/components/d3/src/arrays/range.js +24 -0
- data/lib/stripmem/public/components/d3/src/arrays/set.js +38 -0
- data/lib/stripmem/public/components/d3/src/arrays/shuffle.js +8 -0
- data/lib/stripmem/public/components/d3/src/arrays/sum.js +14 -0
- data/lib/stripmem/public/components/d3/src/arrays/transpose.js +5 -0
- data/lib/stripmem/public/components/d3/src/arrays/values.js +5 -0
- data/lib/stripmem/public/components/d3/src/arrays/zip.js +15 -0
- data/lib/stripmem/public/components/d3/src/behavior/behavior.js +1 -0
- data/lib/stripmem/public/components/d3/src/behavior/drag.js +79 -0
- data/lib/stripmem/public/components/d3/src/behavior/index.js +3 -0
- data/lib/stripmem/public/components/d3/src/behavior/zoom.js +209 -0
- data/lib/stripmem/public/components/d3/src/color/color.js +5 -0
- data/lib/stripmem/public/components/d3/src/color/hcl.js +42 -0
- data/lib/stripmem/public/components/d3/src/color/hsl.js +64 -0
- data/lib/stripmem/public/components/d3/src/color/index.js +6 -0
- data/lib/stripmem/public/components/d3/src/color/lab.js +68 -0
- data/lib/stripmem/public/components/d3/src/color/rgb.js +307 -0
- data/lib/stripmem/public/components/d3/src/color/xyz.js +7 -0
- data/lib/stripmem/public/components/d3/src/compat/date.js +3 -0
- data/lib/stripmem/public/components/d3/src/compat/index.js +2 -0
- data/lib/stripmem/public/components/d3/src/compat/style.js +20 -0
- data/lib/stripmem/public/components/d3/src/core/array.js +19 -0
- data/lib/stripmem/public/components/d3/src/core/class.js +12 -0
- data/lib/stripmem/public/components/d3/src/core/document.js +3 -0
- data/lib/stripmem/public/components/d3/src/core/functor.js +5 -0
- data/lib/stripmem/public/components/d3/src/core/identity.js +3 -0
- data/lib/stripmem/public/components/d3/src/core/index.js +3 -0
- data/lib/stripmem/public/components/d3/src/core/noop.js +1 -0
- data/lib/stripmem/public/components/d3/src/core/ns.js +22 -0
- data/lib/stripmem/public/components/d3/src/core/rebind.js +16 -0
- data/lib/stripmem/public/components/d3/src/core/source.js +3 -0
- data/lib/stripmem/public/components/d3/src/core/subclass.js +11 -0
- data/lib/stripmem/public/components/d3/src/core/target.js +3 -0
- data/lib/stripmem/public/components/d3/src/core/true.js +3 -0
- data/lib/stripmem/public/components/d3/src/core/vendor.js +12 -0
- data/lib/stripmem/public/components/d3/src/d3.js +23 -0
- data/lib/stripmem/public/components/d3/src/dsv/csv.js +3 -0
- data/lib/stripmem/public/components/d3/src/dsv/dsv.js +136 -0
- data/lib/stripmem/public/components/d3/src/dsv/index.js +3 -0
- data/lib/stripmem/public/components/d3/src/dsv/tsv.js +3 -0
- data/lib/stripmem/public/components/d3/src/end.js +2 -0
- data/lib/stripmem/public/components/d3/src/event/dispatch.js +69 -0
- data/lib/stripmem/public/components/d3/src/event/drag.js +27 -0
- data/lib/stripmem/public/components/d3/src/event/event.js +50 -0
- data/lib/stripmem/public/components/d3/src/event/index.js +5 -0
- data/lib/stripmem/public/components/d3/src/event/mouse.js +39 -0
- data/lib/stripmem/public/components/d3/src/event/timer.js +82 -0
- data/lib/stripmem/public/components/d3/src/event/touches.js +12 -0
- data/lib/stripmem/public/components/d3/src/format/collapse.js +3 -0
- data/lib/stripmem/public/components/d3/src/format/format-locale.js +4 -0
- data/lib/stripmem/public/components/d3/src/format/format-localized.js +5 -0
- data/lib/stripmem/public/components/d3/src/format/format.js +144 -0
- data/lib/stripmem/public/components/d3/src/format/formatPrefix.js +22 -0
- data/lib/stripmem/public/components/d3/src/format/index.js +4 -0
- data/lib/stripmem/public/components/d3/src/format/requote.js +5 -0
- data/lib/stripmem/public/components/d3/src/format/round.js +5 -0
- data/lib/stripmem/public/components/d3/src/geo/albers-usa.js +129 -0
- data/lib/stripmem/public/components/d3/src/geo/albers.js +11 -0
- data/lib/stripmem/public/components/d3/src/geo/area.js +67 -0
- data/lib/stripmem/public/components/d3/src/geo/azimuthal-equal-area.js +12 -0
- data/lib/stripmem/public/components/d3/src/geo/azimuthal-equidistant.js +13 -0
- data/lib/stripmem/public/components/d3/src/geo/azimuthal.js +25 -0
- data/lib/stripmem/public/components/d3/src/geo/bounds.js +169 -0
- data/lib/stripmem/public/components/d3/src/geo/cartesian.js +47 -0
- data/lib/stripmem/public/components/d3/src/geo/centroid.js +149 -0
- data/lib/stripmem/public/components/d3/src/geo/circle.js +81 -0
- data/lib/stripmem/public/components/d3/src/geo/clip-antimeridian.js +101 -0
- data/lib/stripmem/public/components/d3/src/geo/clip-circle.js +182 -0
- data/lib/stripmem/public/components/d3/src/geo/clip-polygon.js +94 -0
- data/lib/stripmem/public/components/d3/src/geo/clip-view.js +212 -0
- data/lib/stripmem/public/components/d3/src/geo/clip.js +135 -0
- data/lib/stripmem/public/components/d3/src/geo/compose.js +12 -0
- data/lib/stripmem/public/components/d3/src/geo/conic-conformal.js +36 -0
- data/lib/stripmem/public/components/d3/src/geo/conic-equal-area.js +33 -0
- data/lib/stripmem/public/components/d3/src/geo/conic-equidistant.js +35 -0
- data/lib/stripmem/public/components/d3/src/geo/conic.js +16 -0
- data/lib/stripmem/public/components/d3/src/geo/distance.js +13 -0
- data/lib/stripmem/public/components/d3/src/geo/equirectangular.js +10 -0
- data/lib/stripmem/public/components/d3/src/geo/geo.js +1 -0
- data/lib/stripmem/public/components/d3/src/geo/gnomonic.js +12 -0
- data/lib/stripmem/public/components/d3/src/geo/graticule.js +102 -0
- data/lib/stripmem/public/components/d3/src/geo/greatArc.js +42 -0
- data/lib/stripmem/public/components/d3/src/geo/index.js +32 -0
- data/lib/stripmem/public/components/d3/src/geo/interpolate.js +38 -0
- data/lib/stripmem/public/components/d3/src/geo/length.js +43 -0
- data/lib/stripmem/public/components/d3/src/geo/mercator.js +48 -0
- data/lib/stripmem/public/components/d3/src/geo/orthographic.js +12 -0
- data/lib/stripmem/public/components/d3/src/geo/path-area.js +40 -0
- data/lib/stripmem/public/components/d3/src/geo/path-bounds.js +21 -0
- data/lib/stripmem/public/components/d3/src/geo/path-buffer.js +59 -0
- data/lib/stripmem/public/components/d3/src/geo/path-centroid.js +78 -0
- data/lib/stripmem/public/components/d3/src/geo/path-context.js +49 -0
- data/lib/stripmem/public/components/d3/src/geo/path.js +97 -0
- data/lib/stripmem/public/components/d3/src/geo/point-in-polygon.js +71 -0
- data/lib/stripmem/public/components/d3/src/geo/projection.js +132 -0
- data/lib/stripmem/public/components/d3/src/geo/resample.js +98 -0
- data/lib/stripmem/public/components/d3/src/geo/rotation.js +72 -0
- data/lib/stripmem/public/components/d3/src/geo/spherical.js +12 -0
- data/lib/stripmem/public/components/d3/src/geo/stereographic.js +12 -0
- data/lib/stripmem/public/components/d3/src/geo/stream.js +71 -0
- data/lib/stripmem/public/components/d3/src/geo/transverse-mercator.js +23 -0
- data/lib/stripmem/public/components/d3/src/geom/delaunay.js +31 -0
- data/lib/stripmem/public/components/d3/src/geom/geom.js +1 -0
- data/lib/stripmem/public/components/d3/src/geom/hull.js +120 -0
- data/lib/stripmem/public/components/d3/src/geom/index.js +6 -0
- data/lib/stripmem/public/components/d3/src/geom/polygon.js +105 -0
- data/lib/stripmem/public/components/d3/src/geom/quadtree.js +190 -0
- data/lib/stripmem/public/components/d3/src/geom/voronoi.js +545 -0
- data/lib/stripmem/public/components/d3/src/interpolate/array.js +19 -0
- data/lib/stripmem/public/components/d3/src/interpolate/ease.js +110 -0
- data/lib/stripmem/public/components/d3/src/interpolate/hcl.js +23 -0
- data/lib/stripmem/public/components/d3/src/interpolate/hsl.js +23 -0
- data/lib/stripmem/public/components/d3/src/interpolate/index.js +13 -0
- data/lib/stripmem/public/components/d3/src/interpolate/interpolate.js +25 -0
- data/lib/stripmem/public/components/d3/src/interpolate/lab.js +20 -0
- data/lib/stripmem/public/components/d3/src/interpolate/number.js +6 -0
- data/lib/stripmem/public/components/d3/src/interpolate/object.js +25 -0
- data/lib/stripmem/public/components/d3/src/interpolate/rgb.js +20 -0
- data/lib/stripmem/public/components/d3/src/interpolate/round.js +6 -0
- data/lib/stripmem/public/components/d3/src/interpolate/string.js +88 -0
- data/lib/stripmem/public/components/d3/src/interpolate/transform.js +56 -0
- data/lib/stripmem/public/components/d3/src/interpolate/uninterpolate.js +9 -0
- data/lib/stripmem/public/components/d3/src/layout/bundle.js +59 -0
- data/lib/stripmem/public/components/d3/src/layout/chord.js +157 -0
- data/lib/stripmem/public/components/d3/src/layout/cluster.js +92 -0
- data/lib/stripmem/public/components/d3/src/layout/force.js +359 -0
- data/lib/stripmem/public/components/d3/src/layout/hierarchy.js +116 -0
- data/lib/stripmem/public/components/d3/src/layout/histogram.js +110 -0
- data/lib/stripmem/public/components/d3/src/layout/index.js +13 -0
- data/lib/stripmem/public/components/d3/src/layout/layout.js +1 -0
- data/lib/stripmem/public/components/d3/src/layout/pack.js +212 -0
- data/lib/stripmem/public/components/d3/src/layout/partition.js +51 -0
- data/lib/stripmem/public/components/d3/src/layout/pie.js +99 -0
- data/lib/stripmem/public/components/d3/src/layout/stack.js +245 -0
- data/lib/stripmem/public/components/d3/src/layout/tree.js +251 -0
- data/lib/stripmem/public/components/d3/src/layout/treemap.js +230 -0
- data/lib/stripmem/public/components/d3/src/math/adder.js +34 -0
- data/lib/stripmem/public/components/d3/src/math/index.js +2 -0
- data/lib/stripmem/public/components/d3/src/math/number.js +3 -0
- data/lib/stripmem/public/components/d3/src/math/random.js +28 -0
- data/lib/stripmem/public/components/d3/src/math/transform.js +64 -0
- data/lib/stripmem/public/components/d3/src/math/trigonometry.js +29 -0
- data/lib/stripmem/public/components/d3/src/scale/bilinear.js +7 -0
- data/lib/stripmem/public/components/d3/src/scale/category.js +57 -0
- data/lib/stripmem/public/components/d3/src/scale/identity.js +33 -0
- data/lib/stripmem/public/components/d3/src/scale/index.js +11 -0
- data/lib/stripmem/public/components/d3/src/scale/linear.js +128 -0
- data/lib/stripmem/public/components/d3/src/scale/log.js +92 -0
- data/lib/stripmem/public/components/d3/src/scale/nice.js +28 -0
- data/lib/stripmem/public/components/d3/src/scale/ordinal.js +92 -0
- data/lib/stripmem/public/components/d3/src/scale/polylinear.js +24 -0
- data/lib/stripmem/public/components/d3/src/scale/pow.js +58 -0
- data/lib/stripmem/public/components/d3/src/scale/quantile.js +54 -0
- data/lib/stripmem/public/components/d3/src/scale/quantize.js +44 -0
- data/lib/stripmem/public/components/d3/src/scale/scale.js +10 -0
- data/lib/stripmem/public/components/d3/src/scale/sqrt.js +6 -0
- data/lib/stripmem/public/components/d3/src/scale/threshold.js +36 -0
- data/lib/stripmem/public/components/d3/src/selection/append.js +16 -0
- data/lib/stripmem/public/components/d3/src/selection/attr.js +62 -0
- data/lib/stripmem/public/components/d3/src/selection/call.js +8 -0
- data/lib/stripmem/public/components/d3/src/selection/classed.js +72 -0
- data/lib/stripmem/public/components/d3/src/selection/data.js +118 -0
- data/lib/stripmem/public/components/d3/src/selection/datum.js +7 -0
- data/lib/stripmem/public/components/d3/src/selection/each.js +16 -0
- data/lib/stripmem/public/components/d3/src/selection/empty.js +5 -0
- data/lib/stripmem/public/components/d3/src/selection/enter-insert.js +20 -0
- data/lib/stripmem/public/components/d3/src/selection/enter-select.js +27 -0
- data/lib/stripmem/public/components/d3/src/selection/enter.js +21 -0
- data/lib/stripmem/public/components/d3/src/selection/filter.js +28 -0
- data/lib/stripmem/public/components/d3/src/selection/html.js +10 -0
- data/lib/stripmem/public/components/d3/src/selection/index.js +1 -0
- data/lib/stripmem/public/components/d3/src/selection/insert.js +9 -0
- data/lib/stripmem/public/components/d3/src/selection/node.js +11 -0
- data/lib/stripmem/public/components/d3/src/selection/on.js +104 -0
- data/lib/stripmem/public/components/d3/src/selection/order.js +13 -0
- data/lib/stripmem/public/components/d3/src/selection/property.js +43 -0
- data/lib/stripmem/public/components/d3/src/selection/remove.js +11 -0
- data/lib/stripmem/public/components/d3/src/selection/select.js +32 -0
- data/lib/stripmem/public/components/d3/src/selection/selectAll.js +27 -0
- data/lib/stripmem/public/components/d3/src/selection/selection.js +67 -0
- data/lib/stripmem/public/components/d3/src/selection/size.js +7 -0
- data/lib/stripmem/public/components/d3/src/selection/sort.js +15 -0
- data/lib/stripmem/public/components/d3/src/selection/style.js +56 -0
- data/lib/stripmem/public/components/d3/src/selection/text.js +10 -0
- data/lib/stripmem/public/components/d3/src/selection/transition.js +19 -0
- data/lib/stripmem/public/components/d3/src/start.js +2 -0
- data/lib/stripmem/public/components/d3/src/svg/arc.js +99 -0
- data/lib/stripmem/public/components/d3/src/svg/area-radial.js +14 -0
- data/lib/stripmem/public/components/d3/src/svg/area.js +120 -0
- data/lib/stripmem/public/components/d3/src/svg/axis.js +222 -0
- data/lib/stripmem/public/components/d3/src/svg/brush.js +379 -0
- data/lib/stripmem/public/components/d3/src/svg/chord.js +90 -0
- data/lib/stripmem/public/components/d3/src/svg/diagonal-radial.js +26 -0
- data/lib/stripmem/public/components/d3/src/svg/diagonal.js +43 -0
- data/lib/stripmem/public/components/d3/src/svg/index.js +12 -0
- data/lib/stripmem/public/components/d3/src/svg/line-radial.js +26 -0
- data/lib/stripmem/public/components/d3/src/svg/line.js +439 -0
- data/lib/stripmem/public/components/d3/src/svg/svg.js +1 -0
- data/lib/stripmem/public/components/d3/src/svg/symbol.js +105 -0
- data/lib/stripmem/public/components/d3/src/time/day.js +21 -0
- data/lib/stripmem/public/components/d3/src/time/format-iso.js +20 -0
- data/lib/stripmem/public/components/d3/src/time/format-locale.js +10 -0
- data/lib/stripmem/public/components/d3/src/time/format-localized.js +11 -0
- data/lib/stripmem/public/components/d3/src/time/format-utc.js +31 -0
- data/lib/stripmem/public/components/d3/src/time/format.js +303 -0
- data/lib/stripmem/public/components/d3/src/time/hour.js +14 -0
- data/lib/stripmem/public/components/d3/src/time/index.js +15 -0
- data/lib/stripmem/public/components/d3/src/time/interval.js +71 -0
- data/lib/stripmem/public/components/d3/src/time/minute.js +13 -0
- data/lib/stripmem/public/components/d3/src/time/month.js +16 -0
- data/lib/stripmem/public/components/d3/src/time/scale-utc.js +43 -0
- data/lib/stripmem/public/components/d3/src/time/scale.js +150 -0
- data/lib/stripmem/public/components/d3/src/time/second.js +13 -0
- data/lib/stripmem/public/components/d3/src/time/time.js +35 -0
- data/lib/stripmem/public/components/d3/src/time/week.js +32 -0
- data/lib/stripmem/public/components/d3/src/time/year.js +16 -0
- data/lib/stripmem/public/components/d3/src/transition/attr.js +58 -0
- data/lib/stripmem/public/components/d3/src/transition/delay.js +9 -0
- data/lib/stripmem/public/components/d3/src/transition/duration.js +9 -0
- data/lib/stripmem/public/components/d3/src/transition/each.js +23 -0
- data/lib/stripmem/public/components/d3/src/transition/ease.js +10 -0
- data/lib/stripmem/public/components/d3/src/transition/filter.js +22 -0
- data/lib/stripmem/public/components/d3/src/transition/index.js +1 -0
- data/lib/stripmem/public/components/d3/src/transition/remove.js +8 -0
- data/lib/stripmem/public/components/d3/src/transition/select.js +27 -0
- data/lib/stripmem/public/components/d3/src/transition/selectAll.js +30 -0
- data/lib/stripmem/public/components/d3/src/transition/style.js +53 -0
- data/lib/stripmem/public/components/d3/src/transition/subtransition.js +25 -0
- data/lib/stripmem/public/components/d3/src/transition/text.js +11 -0
- data/lib/stripmem/public/components/d3/src/transition/transition.js +118 -0
- data/lib/stripmem/public/components/d3/src/transition/tween.js +17 -0
- data/lib/stripmem/public/components/d3/src/xhr/html.js +12 -0
- data/lib/stripmem/public/components/d3/src/xhr/index.js +5 -0
- data/lib/stripmem/public/components/d3/src/xhr/json.js +9 -0
- data/lib/stripmem/public/components/d3/src/xhr/text.js +5 -0
- data/lib/stripmem/public/components/d3/src/xhr/xhr.js +118 -0
- data/lib/stripmem/public/components/d3/src/xhr/xml.js +5 -0
- data/lib/stripmem/public/components/d3/test/XMLHttpRequest.js +55 -0
- data/lib/stripmem/public/components/d3/test/arrays/ascending-test.js +45 -0
- data/lib/stripmem/public/components/d3/test/arrays/bisect-test.js +257 -0
- data/lib/stripmem/public/components/d3/test/arrays/descending-test.js +45 -0
- data/lib/stripmem/public/components/d3/test/arrays/entries-test.js +39 -0
- data/lib/stripmem/public/components/d3/test/arrays/extent-test.js +50 -0
- data/lib/stripmem/public/components/d3/test/arrays/keys-test.js +27 -0
- data/lib/stripmem/public/components/d3/test/arrays/map-test.js +214 -0
- data/lib/stripmem/public/components/d3/test/arrays/max-test.js +51 -0
- data/lib/stripmem/public/components/d3/test/arrays/mean-test.js +39 -0
- data/lib/stripmem/public/components/d3/test/arrays/median-test.js +39 -0
- data/lib/stripmem/public/components/d3/test/arrays/merge-test.js +26 -0
- data/lib/stripmem/public/components/d3/test/arrays/min-test.js +51 -0
- data/lib/stripmem/public/components/d3/test/arrays/nest-test.js +256 -0
- data/lib/stripmem/public/components/d3/test/arrays/permute-test.js +49 -0
- data/lib/stripmem/public/components/d3/test/arrays/quantile-test.js +56 -0
- data/lib/stripmem/public/components/d3/test/arrays/range-test.js +99 -0
- data/lib/stripmem/public/components/d3/test/arrays/set-test.js +136 -0
- data/lib/stripmem/public/components/d3/test/arrays/sum-test.js +43 -0
- data/lib/stripmem/public/components/d3/test/arrays/transpose-test.js +28 -0
- data/lib/stripmem/public/components/d3/test/arrays/values-test.js +31 -0
- data/lib/stripmem/public/components/d3/test/arrays/zip-test.js +28 -0
- data/lib/stripmem/public/components/d3/test/assert.js +153 -0
- data/lib/stripmem/public/components/d3/test/color/hcl-test.js +112 -0
- data/lib/stripmem/public/components/d3/test/color/hsl-test.js +118 -0
- data/lib/stripmem/public/components/d3/test/color/lab-test.js +81 -0
- data/lib/stripmem/public/components/d3/test/color/rgb-test.js +91 -0
- data/lib/stripmem/public/components/d3/test/core/functor-test.js +25 -0
- data/lib/stripmem/public/components/d3/test/core/ns-test.js +57 -0
- data/lib/stripmem/public/components/d3/test/core/rebind-test.js +50 -0
- data/lib/stripmem/public/components/d3/test/core/version-test.js +16 -0
- data/lib/stripmem/public/components/d3/test/data/sample.csv +2 -0
- data/lib/stripmem/public/components/d3/test/data/sample.html +5 -0
- data/lib/stripmem/public/components/d3/test/data/sample.json +1 -0
- data/lib/stripmem/public/components/d3/test/data/sample.tsv +2 -0
- data/lib/stripmem/public/components/d3/test/data/sample.txt +1 -0
- data/lib/stripmem/public/components/d3/test/data/sample.xml +4 -0
- data/lib/stripmem/public/components/d3/test/data/us-counties.json +3186 -0
- data/lib/stripmem/public/components/d3/test/dsv/csv-test.js +214 -0
- data/lib/stripmem/public/components/d3/test/dsv/tsv-test.js +185 -0
- data/lib/stripmem/public/components/d3/test/event/dispatch-test.js +163 -0
- data/lib/stripmem/public/components/d3/test/event/mouse-test.html +22 -0
- data/lib/stripmem/public/components/d3/test/event/timer-test.js +74 -0
- data/lib/stripmem/public/components/d3/test/event/touch-test.html +61 -0
- data/lib/stripmem/public/components/d3/test/format/format-test.js +360 -0
- data/lib/stripmem/public/components/d3/test/format/formatPrefix-test.js +112 -0
- data/lib/stripmem/public/components/d3/test/format/requote-test.js +49 -0
- data/lib/stripmem/public/components/d3/test/format/round-test.js +66 -0
- data/lib/stripmem/public/components/d3/test/geo/albers-test.js +40 -0
- data/lib/stripmem/public/components/d3/test/geo/albers-usa-test.js +33 -0
- data/lib/stripmem/public/components/d3/test/geo/area-benchmark.js +12 -0
- data/lib/stripmem/public/components/d3/test/geo/area-test.js +185 -0
- data/lib/stripmem/public/components/d3/test/geo/azimuthal-equal-area-test.js +38 -0
- data/lib/stripmem/public/components/d3/test/geo/azimuthal-equidistant-test.js +38 -0
- data/lib/stripmem/public/components/d3/test/geo/benchmark.js +83 -0
- data/lib/stripmem/public/components/d3/test/geo/bounds-test.js +265 -0
- data/lib/stripmem/public/components/d3/test/geo/centroid-test.js +187 -0
- data/lib/stripmem/public/components/d3/test/geo/circle-test.js +29 -0
- data/lib/stripmem/public/components/d3/test/geo/clip-view-mock.js +4 -0
- data/lib/stripmem/public/components/d3/test/geo/clip-view-test.js +44 -0
- data/lib/stripmem/public/components/d3/test/geo/conic-conformal-test.js +38 -0
- data/lib/stripmem/public/components/d3/test/geo/conic-equal-area-test.js +38 -0
- data/lib/stripmem/public/components/d3/test/geo/conic-equidistant-test.js +38 -0
- data/lib/stripmem/public/components/d3/test/geo/distance-test.js +20 -0
- data/lib/stripmem/public/components/d3/test/geo/equirectangular-test.js +38 -0
- data/lib/stripmem/public/components/d3/test/geo/gnomonic-test.js +38 -0
- data/lib/stripmem/public/components/d3/test/geo/graticule-test.js +188 -0
- data/lib/stripmem/public/components/d3/test/geo/greatArc-test.js +35 -0
- data/lib/stripmem/public/components/d3/test/geo/interpolate-test.js +22 -0
- data/lib/stripmem/public/components/d3/test/geo/length-test.js +44 -0
- data/lib/stripmem/public/components/d3/test/geo/mercator-test.js +38 -0
- data/lib/stripmem/public/components/d3/test/geo/orthographic-test.js +34 -0
- data/lib/stripmem/public/components/d3/test/geo/path-test.js +832 -0
- data/lib/stripmem/public/components/d3/test/geo/point-in-polygon-mock.js +18 -0
- data/lib/stripmem/public/components/d3/test/geo/point-in-polygon-test.js +352 -0
- data/lib/stripmem/public/components/d3/test/geo/projection-test-suite.js +29 -0
- data/lib/stripmem/public/components/d3/test/geo/projection-test.js +58 -0
- data/lib/stripmem/public/components/d3/test/geo/rotation-test.js +35 -0
- data/lib/stripmem/public/components/d3/test/geo/stereographic-test.js +38 -0
- data/lib/stripmem/public/components/d3/test/geo/stream-test.js +264 -0
- data/lib/stripmem/public/components/d3/test/geo/transverse-mercator-test.js +38 -0
- data/lib/stripmem/public/components/d3/test/geom/hull-test.js +68 -0
- data/lib/stripmem/public/components/d3/test/geom/polygon-test.js +151 -0
- data/lib/stripmem/public/components/d3/test/geom/quadtree-test.js +139 -0
- data/lib/stripmem/public/components/d3/test/geom/voronoi-test.js +230 -0
- data/lib/stripmem/public/components/d3/test/interpolate/array-test.js +24 -0
- data/lib/stripmem/public/components/d3/test/interpolate/ease-test.js +135 -0
- data/lib/stripmem/public/components/d3/test/interpolate/hcl-test.js +47 -0
- data/lib/stripmem/public/components/d3/test/interpolate/hsl-test.js +47 -0
- data/lib/stripmem/public/components/d3/test/interpolate/interpolate-test.js +157 -0
- data/lib/stripmem/public/components/d3/test/interpolate/interpolate-transform-test.js +60 -0
- data/lib/stripmem/public/components/d3/test/interpolate/lab-test.js +31 -0
- data/lib/stripmem/public/components/d3/test/interpolate/number-test.js +20 -0
- data/lib/stripmem/public/components/d3/test/interpolate/object-test.js +35 -0
- data/lib/stripmem/public/components/d3/test/interpolate/rgb-test.js +31 -0
- data/lib/stripmem/public/components/d3/test/interpolate/round-test.js +17 -0
- data/lib/stripmem/public/components/d3/test/interpolate/string-test.js +43 -0
- data/lib/stripmem/public/components/d3/test/layout/chord-test.js +164 -0
- data/lib/stripmem/public/components/d3/test/layout/cluster-test.js +44 -0
- data/lib/stripmem/public/components/d3/test/layout/force-test.js +119 -0
- data/lib/stripmem/public/components/d3/test/layout/hierarchy-test.js +27 -0
- data/lib/stripmem/public/components/d3/test/layout/histogram-test.js +92 -0
- data/lib/stripmem/public/components/d3/test/layout/pack-test.js +129 -0
- data/lib/stripmem/public/components/d3/test/layout/partition-test.js +45 -0
- data/lib/stripmem/public/components/d3/test/layout/pie-test.js +24 -0
- data/lib/stripmem/public/components/d3/test/layout/tree-test.js +45 -0
- data/lib/stripmem/public/components/d3/test/layout/treemap-test.js +181 -0
- data/lib/stripmem/public/components/d3/test/load.js +58 -0
- data/lib/stripmem/public/components/d3/test/math/random-test.js +37 -0
- data/lib/stripmem/public/components/d3/test/math/transform-null-matrix-test.html +26 -0
- data/lib/stripmem/public/components/d3/test/math/transform-null-test.html +26 -0
- data/lib/stripmem/public/components/d3/test/math/transform-rotate-origin-test.html +40 -0
- data/lib/stripmem/public/components/d3/test/math/transform-rotate-test.html +138 -0
- data/lib/stripmem/public/components/d3/test/math/transform-test.html +88 -0
- data/lib/stripmem/public/components/d3/test/scale/category-test.js +76 -0
- data/lib/stripmem/public/components/d3/test/scale/identity-test.js +163 -0
- data/lib/stripmem/public/components/d3/test/scale/linear-test.js +281 -0
- data/lib/stripmem/public/components/d3/test/scale/log-test.js +378 -0
- data/lib/stripmem/public/components/d3/test/scale/ordinal-test.js +272 -0
- data/lib/stripmem/public/components/d3/test/scale/pow-test.js +267 -0
- data/lib/stripmem/public/components/d3/test/scale/quantile-test.js +91 -0
- data/lib/stripmem/public/components/d3/test/scale/quantize-test.js +92 -0
- data/lib/stripmem/public/components/d3/test/scale/sqrt-test.js +260 -0
- data/lib/stripmem/public/components/d3/test/scale/threshold-test.js +64 -0
- data/lib/stripmem/public/components/d3/test/selection/append-test.js +153 -0
- data/lib/stripmem/public/components/d3/test/selection/attr-test.js +182 -0
- data/lib/stripmem/public/components/d3/test/selection/call-test.js +75 -0
- data/lib/stripmem/public/components/d3/test/selection/classed-test.js +269 -0
- data/lib/stripmem/public/components/d3/test/selection/data-test.js +270 -0
- data/lib/stripmem/public/components/d3/test/selection/datum-test.js +87 -0
- data/lib/stripmem/public/components/d3/test/selection/each-test.js +87 -0
- data/lib/stripmem/public/components/d3/test/selection/empty-test.js +53 -0
- data/lib/stripmem/public/components/d3/test/selection/enter-test.js +24 -0
- data/lib/stripmem/public/components/d3/test/selection/filter-test.js +72 -0
- data/lib/stripmem/public/components/d3/test/selection/html-test.js +134 -0
- data/lib/stripmem/public/components/d3/test/selection/insert-test.js +169 -0
- data/lib/stripmem/public/components/d3/test/selection/node-test.js +55 -0
- data/lib/stripmem/public/components/d3/test/selection/on-test.js +135 -0
- data/lib/stripmem/public/components/d3/test/selection/order-test.js +32 -0
- data/lib/stripmem/public/components/d3/test/selection/property-test.js +118 -0
- data/lib/stripmem/public/components/d3/test/selection/remove-test.js +38 -0
- data/lib/stripmem/public/components/d3/test/selection/select-test.js +69 -0
- data/lib/stripmem/public/components/d3/test/selection/selectAll-test.js +52 -0
- data/lib/stripmem/public/components/d3/test/selection/selection-select-test.js +128 -0
- data/lib/stripmem/public/components/d3/test/selection/selection-selectAll-test.js +131 -0
- data/lib/stripmem/public/components/d3/test/selection/selection-test.js +38 -0
- data/lib/stripmem/public/components/d3/test/selection/size-test.js +52 -0
- data/lib/stripmem/public/components/d3/test/selection/sort-test.js +81 -0
- data/lib/stripmem/public/components/d3/test/selection/style-test.js +129 -0
- data/lib/stripmem/public/components/d3/test/selection/text-test.js +115 -0
- data/lib/stripmem/public/components/d3/test/svg/arc-test.js +143 -0
- data/lib/stripmem/public/components/d3/test/svg/area-radial-test.js +199 -0
- data/lib/stripmem/public/components/d3/test/svg/area-test.js +192 -0
- data/lib/stripmem/public/components/d3/test/svg/axis-test.js +447 -0
- data/lib/stripmem/public/components/d3/test/svg/brush-test.js +96 -0
- data/lib/stripmem/public/components/d3/test/svg/diagonal-test.js +62 -0
- data/lib/stripmem/public/components/d3/test/svg/line-radial-test.js +120 -0
- data/lib/stripmem/public/components/d3/test/svg/line-test.js +207 -0
- data/lib/stripmem/public/components/d3/test/svg/symbol-test.js +91 -0
- data/lib/stripmem/public/components/d3/test/time/day-test.js +178 -0
- data/lib/stripmem/public/components/d3/test/time/dayOfYear-test.js +16 -0
- data/lib/stripmem/public/components/d3/test/time/days-test.js +95 -0
- data/lib/stripmem/public/components/d3/test/time/format-iso-test.js +33 -0
- data/lib/stripmem/public/components/d3/test/time/format-test.js +300 -0
- data/lib/stripmem/public/components/d3/test/time/format-utc-test.js +219 -0
- data/lib/stripmem/public/components/d3/test/time/hour-test.js +215 -0
- data/lib/stripmem/public/components/d3/test/time/hours-test.js +109 -0
- data/lib/stripmem/public/components/d3/test/time/minute-test.js +127 -0
- data/lib/stripmem/public/components/d3/test/time/minutes-test.js +91 -0
- data/lib/stripmem/public/components/d3/test/time/month-test.js +150 -0
- data/lib/stripmem/public/components/d3/test/time/months-test.js +95 -0
- data/lib/stripmem/public/components/d3/test/time/scale-test.js +585 -0
- data/lib/stripmem/public/components/d3/test/time/second-test.js +143 -0
- data/lib/stripmem/public/components/d3/test/time/seconds-test.js +91 -0
- data/lib/stripmem/public/components/d3/test/time/time.js +30 -0
- data/lib/stripmem/public/components/d3/test/time/week-test.js +162 -0
- data/lib/stripmem/public/components/d3/test/time/weeks-test.js +95 -0
- data/lib/stripmem/public/components/d3/test/time/year-test.js +137 -0
- data/lib/stripmem/public/components/d3/test/time/years-test.js +74 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-attr.js +56 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-attrTween.js +59 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-call.js +30 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-delay.js +56 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-duration.js +60 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-each.js +163 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-filter.js +84 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-id.js +22 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-node.js +39 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-remove.js +45 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-select.js +60 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-selectAll.js +56 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-size.js +37 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-style.js +51 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-styleTween.js +65 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-text.js +27 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-time.js +38 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-transition.js +59 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test-tween.js +62 -0
- data/lib/stripmem/public/components/d3/test/transition/transition-test.js +89 -0
- data/lib/stripmem/public/components/d3/test/xhr/html-test.js +37 -0
- data/lib/stripmem/public/components/d3/test/xhr/json-test.js +51 -0
- data/lib/stripmem/public/components/d3/test/xhr/text-test.js +46 -0
- data/lib/stripmem/public/components/d3/test/xhr/xhr-test.js +54 -0
- data/lib/stripmem/public/components/d3/test/xhr/xml-test.js +46 -0
- data/lib/stripmem/public/components/jquery/README.md +11 -0
- data/lib/stripmem/public/components/jquery/bower.json +11 -0
- data/lib/stripmem/public/components/jquery/component.json +23 -0
- data/lib/stripmem/public/components/jquery/composer.json +35 -0
- data/lib/stripmem/public/components/jquery/jquery-migrate.js +511 -0
- data/lib/stripmem/public/components/jquery/jquery-migrate.min.js +3 -0
- data/lib/stripmem/public/components/jquery/jquery.js +8829 -0
- data/lib/stripmem/public/components/jquery/jquery.min.js +6 -0
- data/lib/stripmem/public/components/jquery/jquery.min.map +1 -0
- data/lib/stripmem/public/components/jquery/package.json +7 -0
- data/lib/stripmem/version.rb +3 -0
- data/lib/stripmem/views/index.erb +19 -0
- data/lib/stripmem/web.rb +19 -0
- data/lib/stripmem/websocket.rb +22 -0
- metadata +616 -0
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
(function(){science = {version: "1.7.0"}; // semver
|
|
2
|
+
science.ascending = function(a, b) {
|
|
3
|
+
return a - b;
|
|
4
|
+
};
|
|
5
|
+
// Euler's constant.
|
|
6
|
+
science.EULER = .5772156649015329;
|
|
7
|
+
// Compute exp(x) - 1 accurately for small x.
|
|
8
|
+
science.expm1 = function(x) {
|
|
9
|
+
return (x < 1e-5 && x > -1e-5) ? x + .5 * x * x : Math.exp(x) - 1;
|
|
10
|
+
};
|
|
11
|
+
science.functor = function(v) {
|
|
12
|
+
return typeof v === "function" ? v : function() { return v; };
|
|
13
|
+
};
|
|
14
|
+
// Based on:
|
|
15
|
+
// http://www.johndcook.com/blog/2010/06/02/whats-so-hard-about-finding-a-hypotenuse/
|
|
16
|
+
science.hypot = function(x, y) {
|
|
17
|
+
x = Math.abs(x);
|
|
18
|
+
y = Math.abs(y);
|
|
19
|
+
var max,
|
|
20
|
+
min;
|
|
21
|
+
if (x > y) { max = x; min = y; }
|
|
22
|
+
else { max = y; min = x; }
|
|
23
|
+
var r = min / max;
|
|
24
|
+
return max * Math.sqrt(1 + r * r);
|
|
25
|
+
};
|
|
26
|
+
science.quadratic = function() {
|
|
27
|
+
var complex = false;
|
|
28
|
+
|
|
29
|
+
function quadratic(a, b, c) {
|
|
30
|
+
var d = b * b - 4 * a * c;
|
|
31
|
+
if (d > 0) {
|
|
32
|
+
d = Math.sqrt(d) / (2 * a);
|
|
33
|
+
return complex
|
|
34
|
+
? [{r: -b - d, i: 0}, {r: -b + d, i: 0}]
|
|
35
|
+
: [-b - d, -b + d];
|
|
36
|
+
} else if (d === 0) {
|
|
37
|
+
d = -b / (2 * a);
|
|
38
|
+
return complex ? [{r: d, i: 0}] : [d];
|
|
39
|
+
} else {
|
|
40
|
+
if (complex) {
|
|
41
|
+
d = Math.sqrt(-d) / (2 * a);
|
|
42
|
+
return [
|
|
43
|
+
{r: -b, i: -d},
|
|
44
|
+
{r: -b, i: d}
|
|
45
|
+
];
|
|
46
|
+
}
|
|
47
|
+
return [];
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
quadratic.complex = function(x) {
|
|
52
|
+
if (!arguments.length) return complex;
|
|
53
|
+
complex = x;
|
|
54
|
+
return quadratic;
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
return quadratic;
|
|
58
|
+
};
|
|
59
|
+
// Constructs a multi-dimensional array filled with zeroes.
|
|
60
|
+
science.zeroes = function(n) {
|
|
61
|
+
var i = -1,
|
|
62
|
+
a = [];
|
|
63
|
+
if (arguments.length === 1)
|
|
64
|
+
while (++i < n)
|
|
65
|
+
a[i] = 0;
|
|
66
|
+
else
|
|
67
|
+
while (++i < n)
|
|
68
|
+
a[i] = science.zeroes.apply(
|
|
69
|
+
this, Array.prototype.slice.call(arguments, 1));
|
|
70
|
+
return a;
|
|
71
|
+
};
|
|
72
|
+
science.vector = {};
|
|
73
|
+
science.vector.cross = function(a, b) {
|
|
74
|
+
// TODO how to handle non-3D vectors?
|
|
75
|
+
// TODO handle 7D vectors?
|
|
76
|
+
return [
|
|
77
|
+
a[1] * b[2] - a[2] * b[1],
|
|
78
|
+
a[2] * b[0] - a[0] * b[2],
|
|
79
|
+
a[0] * b[1] - a[1] * b[0]
|
|
80
|
+
];
|
|
81
|
+
};
|
|
82
|
+
science.vector.dot = function(a, b) {
|
|
83
|
+
var s = 0,
|
|
84
|
+
i = -1,
|
|
85
|
+
n = Math.min(a.length, b.length);
|
|
86
|
+
while (++i < n) s += a[i] * b[i];
|
|
87
|
+
return s;
|
|
88
|
+
};
|
|
89
|
+
science.vector.length = function(p) {
|
|
90
|
+
return Math.sqrt(science.vector.dot(p, p));
|
|
91
|
+
};
|
|
92
|
+
science.vector.normalize = function(p) {
|
|
93
|
+
var length = science.vector.length(p);
|
|
94
|
+
return p.map(function(d) { return d / length; });
|
|
95
|
+
};
|
|
96
|
+
// 4x4 matrix determinant.
|
|
97
|
+
science.vector.determinant = function(matrix) {
|
|
98
|
+
var m = matrix[0].concat(matrix[1]).concat(matrix[2]).concat(matrix[3]);
|
|
99
|
+
return (
|
|
100
|
+
m[12] * m[9] * m[6] * m[3] - m[8] * m[13] * m[6] * m[3] -
|
|
101
|
+
m[12] * m[5] * m[10] * m[3] + m[4] * m[13] * m[10] * m[3] +
|
|
102
|
+
m[8] * m[5] * m[14] * m[3] - m[4] * m[9] * m[14] * m[3] -
|
|
103
|
+
m[12] * m[9] * m[2] * m[7] + m[8] * m[13] * m[2] * m[7] +
|
|
104
|
+
m[12] * m[1] * m[10] * m[7] - m[0] * m[13] * m[10] * m[7] -
|
|
105
|
+
m[8] * m[1] * m[14] * m[7] + m[0] * m[9] * m[14] * m[7] +
|
|
106
|
+
m[12] * m[5] * m[2] * m[11] - m[4] * m[13] * m[2] * m[11] -
|
|
107
|
+
m[12] * m[1] * m[6] * m[11] + m[0] * m[13] * m[6] * m[11] +
|
|
108
|
+
m[4] * m[1] * m[14] * m[11] - m[0] * m[5] * m[14] * m[11] -
|
|
109
|
+
m[8] * m[5] * m[2] * m[15] + m[4] * m[9] * m[2] * m[15] +
|
|
110
|
+
m[8] * m[1] * m[6] * m[15] - m[0] * m[9] * m[6] * m[15] -
|
|
111
|
+
m[4] * m[1] * m[10] * m[15] + m[0] * m[5] * m[10] * m[15]);
|
|
112
|
+
};
|
|
113
|
+
// Performs in-place Gauss-Jordan elimination.
|
|
114
|
+
//
|
|
115
|
+
// Based on Jarno Elonen's Python version (public domain):
|
|
116
|
+
// http://elonen.iki.fi/code/misc-notes/python-gaussj/index.html
|
|
117
|
+
science.vector.gaussjordan = function(m, eps) {
|
|
118
|
+
if (!eps) eps = 1e-10;
|
|
119
|
+
|
|
120
|
+
var h = m.length,
|
|
121
|
+
w = m[0].length,
|
|
122
|
+
y = -1,
|
|
123
|
+
y2,
|
|
124
|
+
x;
|
|
125
|
+
|
|
126
|
+
while (++y < h) {
|
|
127
|
+
var maxrow = y;
|
|
128
|
+
|
|
129
|
+
// Find max pivot.
|
|
130
|
+
y2 = y; while (++y2 < h) {
|
|
131
|
+
if (Math.abs(m[y2][y]) > Math.abs(m[maxrow][y]))
|
|
132
|
+
maxrow = y2;
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
// Swap.
|
|
136
|
+
var tmp = m[y];
|
|
137
|
+
m[y] = m[maxrow];
|
|
138
|
+
m[maxrow] = tmp;
|
|
139
|
+
|
|
140
|
+
// Singular?
|
|
141
|
+
if (Math.abs(m[y][y]) <= eps) return false;
|
|
142
|
+
|
|
143
|
+
// Eliminate column y.
|
|
144
|
+
y2 = y; while (++y2 < h) {
|
|
145
|
+
var c = m[y2][y] / m[y][y];
|
|
146
|
+
x = y - 1; while (++x < w) {
|
|
147
|
+
m[y2][x] -= m[y][x] * c;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
// Backsubstitute.
|
|
153
|
+
y = h; while (--y >= 0) {
|
|
154
|
+
var c = m[y][y];
|
|
155
|
+
y2 = -1; while (++y2 < y) {
|
|
156
|
+
x = w; while (--x >= y) {
|
|
157
|
+
m[y2][x] -= m[y][x] * m[y2][y] / c;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
m[y][y] /= c;
|
|
161
|
+
// Normalize row y.
|
|
162
|
+
x = h - 1; while (++x < w) {
|
|
163
|
+
m[y][x] /= c;
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
return true;
|
|
167
|
+
};
|
|
168
|
+
// Find matrix inverse using Gauss-Jordan.
|
|
169
|
+
science.vector.inverse = function(m) {
|
|
170
|
+
var n = m.length
|
|
171
|
+
i = -1;
|
|
172
|
+
|
|
173
|
+
// Check if the matrix is square.
|
|
174
|
+
if (n !== m[0].length) return;
|
|
175
|
+
|
|
176
|
+
// Augment with identity matrix I to get AI.
|
|
177
|
+
m = m.map(function(row, i) {
|
|
178
|
+
var identity = new Array(n),
|
|
179
|
+
j = -1;
|
|
180
|
+
while (++j < n) identity[j] = i === j ? 1 : 0;
|
|
181
|
+
return row.concat(identity);
|
|
182
|
+
});
|
|
183
|
+
|
|
184
|
+
// Compute IA^-1.
|
|
185
|
+
science.vector.gaussjordan(m);
|
|
186
|
+
|
|
187
|
+
// Remove identity matrix I to get A^-1.
|
|
188
|
+
while (++i < n) {
|
|
189
|
+
m[i] = m[i].slice(n);
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
return m;
|
|
193
|
+
};
|
|
194
|
+
science.vector.multiply = function(a, b) {
|
|
195
|
+
var m = a.length,
|
|
196
|
+
n = b[0].length,
|
|
197
|
+
p = b.length,
|
|
198
|
+
i = -1,
|
|
199
|
+
j,
|
|
200
|
+
k;
|
|
201
|
+
if (p !== a[0].length) throw {"error": "columns(a) != rows(b); " + a[0].length + " != " + p};
|
|
202
|
+
var ab = new Array(m);
|
|
203
|
+
while (++i < m) {
|
|
204
|
+
ab[i] = new Array(n);
|
|
205
|
+
j = -1; while(++j < n) {
|
|
206
|
+
var s = 0;
|
|
207
|
+
k = -1; while (++k < p) s += a[i][k] * b[k][j];
|
|
208
|
+
ab[i][j] = s;
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
return ab;
|
|
212
|
+
};
|
|
213
|
+
science.vector.transpose = function(a) {
|
|
214
|
+
var m = a.length,
|
|
215
|
+
n = a[0].length,
|
|
216
|
+
i = -1,
|
|
217
|
+
j,
|
|
218
|
+
b = new Array(n);
|
|
219
|
+
while (++i < n) {
|
|
220
|
+
b[i] = new Array(m);
|
|
221
|
+
j = -1; while (++j < m) b[i][j] = a[j][i];
|
|
222
|
+
}
|
|
223
|
+
return b;
|
|
224
|
+
};
|
|
225
|
+
})()
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
(function(){science.lin = {};
|
|
2
|
+
/**
|
|
3
|
+
* Solves tridiagonal systems of linear equations.
|
|
4
|
+
*
|
|
5
|
+
* Source: http://en.wikipedia.org/wiki/Tridiagonal_matrix_algorithm
|
|
6
|
+
*
|
|
7
|
+
* @param {number[]} a
|
|
8
|
+
* @param {number[]} b
|
|
9
|
+
* @param {number[]} c
|
|
10
|
+
* @param {number[]} d
|
|
11
|
+
* @param {number[]} x
|
|
12
|
+
* @param {number} n
|
|
13
|
+
*/
|
|
14
|
+
science.lin.tridag = function(a, b, c, d, x, n) {
|
|
15
|
+
var i,
|
|
16
|
+
m;
|
|
17
|
+
for (i = 1; i < n; i++) {
|
|
18
|
+
m = a[i] / b[i - 1];
|
|
19
|
+
b[i] -= m * c[i - 1];
|
|
20
|
+
d[i] -= m * d[i - 1];
|
|
21
|
+
}
|
|
22
|
+
x[n - 1] = d[n - 1] / b[n - 1];
|
|
23
|
+
for (i = n - 2; i >= 0; i--) {
|
|
24
|
+
x[i] = (d[i] - c[i] * x[i + 1]) / b[i];
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
})()
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
(function(){science.lin={},science.lin.tridag=function(a,b,c,d,e,f){var g,h;for(g=1;g<f;g++)h=a[g]/b[g-1],b[g]-=h*c[g-1],d[g]-=h*d[g-1];e[f-1]=d[f-1]/b[f-1];for(g=f-2;g>=0;g--)e[g]=(d[g]-c[g]*e[g+1])/b[g]}})()
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
(function(){science={version:"1.7.0"},science.ascending=function(a,b){return a-b},science.EULER=.5772156649015329,science.expm1=function(a){return a<1e-5&&a>-0.00001?a+.5*a*a:Math.exp(a)-1},science.functor=function(a){return typeof a=="function"?a:function(){return a}},science.hypot=function(a,b){a=Math.abs(a),b=Math.abs(b);var c,d;a>b?(c=a,d=b):(c=b,d=a);var e=d/c;return c*Math.sqrt(1+e*e)},science.quadratic=function(){function b(b,c,d){var e=c*c-4*b*d;if(e>0){e=Math.sqrt(e)/(2*b);return a?[{r:-c-e,i:0},{r:-c+e,i:0}]:[-c-e,-c+e]}if(e===0){e=-c/(2*b);return a?[{r:e,i:0}]:[e]}if(a){e=Math.sqrt(-e)/(2*b);return[{r:-c,i:-e},{r:-c,i:e}]}return[]}var a=!1;b.complex=function(c){if(!arguments.length)return a;a=c;return b};return b},science.zeroes=function(a){var b=-1,c=[];if(arguments.length===1)while(++b<a)c[b]=0;else while(++b<a)c[b]=science.zeroes.apply(this,Array.prototype.slice.call(arguments,1));return c},science.vector={},science.vector.cross=function(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]]},science.vector.dot=function(a,b){var c=0,d=-1,e=Math.min(a.length,b.length);while(++d<e)c+=a[d]*b[d];return c},science.vector.length=function(a){return Math.sqrt(science.vector.dot(a,a))},science.vector.normalize=function(a){var b=science.vector.length(a);return a.map(function(a){return a/b})},science.vector.determinant=function(a){var b=a[0].concat(a[1]).concat(a[2]).concat(a[3]);return b[12]*b[9]*b[6]*b[3]-b[8]*b[13]*b[6]*b[3]-b[12]*b[5]*b[10]*b[3]+b[4]*b[13]*b[10]*b[3]+b[8]*b[5]*b[14]*b[3]-b[4]*b[9]*b[14]*b[3]-b[12]*b[9]*b[2]*b[7]+b[8]*b[13]*b[2]*b[7]+b[12]*b[1]*b[10]*b[7]-b[0]*b[13]*b[10]*b[7]-b[8]*b[1]*b[14]*b[7]+b[0]*b[9]*b[14]*b[7]+b[12]*b[5]*b[2]*b[11]-b[4]*b[13]*b[2]*b[11]-b[12]*b[1]*b[6]*b[11]+b[0]*b[13]*b[6]*b[11]+b[4]*b[1]*b[14]*b[11]-b[0]*b[5]*b[14]*b[11]-b[8]*b[5]*b[2]*b[15]+b[4]*b[9]*b[2]*b[15]+b[8]*b[1]*b[6]*b[15]-b[0]*b[9]*b[6]*b[15]-b[4]*b[1]*b[10]*b[15]+b[0]*b[5]*b[10]*b[15]},science.vector.gaussjordan=function(a,b){b||(b=1e-10);var c=a.length,d=a[0].length,e=-1,f,g;while(++e<c){var h=e;f=e;while(++f<c)Math.abs(a[f][e])>Math.abs(a[h][e])&&(h=f);var i=a[e];a[e]=a[h],a[h]=i;if(Math.abs(a[e][e])<=b)return!1;f=e;while(++f<c){var j=a[f][e]/a[e][e];g=e-1;while(++g<d)a[f][g]-=a[e][g]*j}}e=c;while(--e>=0){var j=a[e][e];f=-1;while(++f<e){g=d;while(--g>=e)a[f][g]-=a[e][g]*a[f][e]/j}a[e][e]/=j,g=c-1;while(++g<d)a[e][g]/=j}return!0},science.vector.inverse=function(a){var b=a.length;i=-1;if(b===a[0].length){a=a.map(function(a,c){var d=Array(b),e=-1;while(++e<b)d[e]=c===e?1:0;return a.concat(d)}),science.vector.gaussjordan(a);while(++i<b)a[i]=a[i].slice(b);return a}},science.vector.multiply=function(a,b){var c=a.length,d=b[0].length,e=b.length,f=-1,g,h;if(e!==a[0].length)throw{error:"columns(a) != rows(b); "+a[0].length+" != "+e};var i=Array(c);while(++f<c){i[f]=Array(d),g=-1;while(++g<d){var j=0;h=-1;while(++h<e)j+=a[f][h]*b[h][g];i[f][g]=j}}return i},science.vector.transpose=function(a){var b=a.length,c=a[0].length,d=-1,e,f=Array(c);while(++d<c){f[d]=Array(b),e=-1;while(++e<b)f[d][e]=a[e][d]}return f}})()
|