@veritone-ce/design-system 2.9.0-next.2 → 2.9.0-next.3

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.
Files changed (629) hide show
  1. package/dist/cjs/bundled_modules/d3-array/src/ascending.js +9 -0
  2. package/dist/cjs/bundled_modules/d3-array/src/bisect.js +16 -0
  3. package/dist/cjs/bundled_modules/d3-array/src/bisector.js +62 -0
  4. package/dist/cjs/bundled_modules/d3-array/src/descending.js +13 -0
  5. package/dist/cjs/bundled_modules/d3-array/src/deviation.js +12 -0
  6. package/dist/cjs/bundled_modules/d3-array/src/fsum.js +45 -0
  7. package/dist/cjs/bundled_modules/d3-array/src/intersection.js +25 -0
  8. package/dist/cjs/bundled_modules/d3-array/src/max.js +26 -0
  9. package/dist/cjs/bundled_modules/d3-array/src/mean.js +25 -0
  10. package/dist/cjs/bundled_modules/d3-array/src/median.js +11 -0
  11. package/dist/cjs/bundled_modules/d3-array/src/merge.js +15 -0
  12. package/dist/cjs/bundled_modules/d3-array/src/min.js +26 -0
  13. package/dist/cjs/bundled_modules/d3-array/src/number.js +27 -0
  14. package/dist/cjs/bundled_modules/d3-array/src/permute.js +9 -0
  15. package/dist/cjs/bundled_modules/d3-array/src/quantile.js +36 -0
  16. package/dist/cjs/bundled_modules/d3-array/src/quickselect.js +59 -0
  17. package/dist/cjs/bundled_modules/d3-array/src/range.js +19 -0
  18. package/dist/cjs/bundled_modules/d3-array/src/sort.js +20 -0
  19. package/dist/cjs/bundled_modules/d3-array/src/sum.js +17 -0
  20. package/dist/cjs/bundled_modules/d3-array/src/ticks.js +63 -0
  21. package/dist/cjs/bundled_modules/d3-array/src/union.js +17 -0
  22. package/dist/cjs/bundled_modules/d3-array/src/variance.js +31 -0
  23. package/dist/cjs/bundled_modules/d3-color/src/color.js +410 -0
  24. package/dist/cjs/bundled_modules/d3-color/src/cubehelix.js +68 -0
  25. package/dist/cjs/bundled_modules/d3-color/src/define.js +17 -0
  26. package/dist/cjs/bundled_modules/d3-color/src/lab.js +124 -0
  27. package/dist/cjs/bundled_modules/d3-color/src/math.js +7 -0
  28. package/dist/cjs/bundled_modules/d3-delaunay/src/delaunay.js +254 -0
  29. package/dist/cjs/bundled_modules/d3-delaunay/src/path.js +43 -0
  30. package/dist/cjs/bundled_modules/d3-delaunay/src/polygon.js +23 -0
  31. package/dist/cjs/bundled_modules/d3-delaunay/src/voronoi.js +338 -0
  32. package/dist/cjs/bundled_modules/d3-dispatch/src/dispatch.js +88 -0
  33. package/dist/cjs/bundled_modules/d3-dsv/src/dsv.js +170 -0
  34. package/dist/cjs/bundled_modules/d3-force/src/center.js +46 -0
  35. package/dist/cjs/bundled_modules/d3-force/src/collide.js +106 -0
  36. package/dist/cjs/bundled_modules/d3-force/src/constant.js +11 -0
  37. package/dist/cjs/bundled_modules/d3-force/src/jiggle.js +9 -0
  38. package/dist/cjs/bundled_modules/d3-force/src/lcg.js +15 -0
  39. package/dist/cjs/bundled_modules/d3-force/src/link.js +123 -0
  40. package/dist/cjs/bundled_modules/d3-force/src/manyBody.js +122 -0
  41. package/dist/cjs/bundled_modules/d3-force/src/simulation.js +164 -0
  42. package/dist/cjs/bundled_modules/d3-force/src/x.js +47 -0
  43. package/dist/cjs/bundled_modules/d3-force/src/y.js +47 -0
  44. package/dist/cjs/bundled_modules/d3-format/src/defaultLocale.js +24 -0
  45. package/dist/cjs/bundled_modules/d3-format/src/exponent.js +11 -0
  46. package/dist/cjs/bundled_modules/d3-format/src/formatDecimal.js +27 -0
  47. package/dist/cjs/bundled_modules/d3-format/src/formatGroup.js +24 -0
  48. package/dist/cjs/bundled_modules/d3-format/src/formatNumerals.js +13 -0
  49. package/dist/cjs/bundled_modules/d3-format/src/formatPrefixAuto.js +22 -0
  50. package/dist/cjs/bundled_modules/d3-format/src/formatRounded.js +17 -0
  51. package/dist/cjs/bundled_modules/d3-format/src/formatSpecifier.js +54 -0
  52. package/dist/cjs/bundled_modules/d3-format/src/formatTrim.js +17 -0
  53. package/dist/cjs/bundled_modules/d3-format/src/formatTypes.js +25 -0
  54. package/dist/cjs/bundled_modules/d3-format/src/identity.js +9 -0
  55. package/dist/cjs/bundled_modules/d3-format/src/locale.js +154 -0
  56. package/dist/cjs/bundled_modules/d3-format/src/precisionFixed.js +11 -0
  57. package/dist/cjs/bundled_modules/d3-format/src/precisionPrefix.js +11 -0
  58. package/dist/cjs/bundled_modules/d3-format/src/precisionRound.js +12 -0
  59. package/dist/cjs/bundled_modules/d3-geo/src/area.js +83 -0
  60. package/dist/cjs/bundled_modules/d3-geo/src/bounds.js +185 -0
  61. package/dist/cjs/bundled_modules/d3-geo/src/cartesian.js +43 -0
  62. package/dist/cjs/bundled_modules/d3-geo/src/centroid.js +149 -0
  63. package/dist/cjs/bundled_modules/d3-geo/src/circle.js +35 -0
  64. package/dist/cjs/bundled_modules/d3-geo/src/clip/antimeridian.js +98 -0
  65. package/dist/cjs/bundled_modules/d3-geo/src/clip/buffer.js +30 -0
  66. package/dist/cjs/bundled_modules/d3-geo/src/clip/circle.js +183 -0
  67. package/dist/cjs/bundled_modules/d3-geo/src/clip/index.js +137 -0
  68. package/dist/cjs/bundled_modules/d3-geo/src/clip/line.js +65 -0
  69. package/dist/cjs/bundled_modules/d3-geo/src/clip/rectangle.js +174 -0
  70. package/dist/cjs/bundled_modules/d3-geo/src/clip/rejoin.js +109 -0
  71. package/dist/cjs/bundled_modules/d3-geo/src/compose.js +18 -0
  72. package/dist/cjs/bundled_modules/d3-geo/src/graticule.js +107 -0
  73. package/dist/cjs/bundled_modules/d3-geo/src/identity.js +7 -0
  74. package/dist/cjs/bundled_modules/d3-geo/src/math.js +57 -0
  75. package/dist/cjs/bundled_modules/d3-geo/src/noop.js +7 -0
  76. package/dist/cjs/bundled_modules/d3-geo/src/path/area.js +54 -0
  77. package/dist/cjs/bundled_modules/d3-geo/src/path/bounds.js +32 -0
  78. package/dist/cjs/bundled_modules/d3-geo/src/path/centroid.js +104 -0
  79. package/dist/cjs/bundled_modules/d3-geo/src/path/context.js +51 -0
  80. package/dist/cjs/bundled_modules/d3-geo/src/path/index.js +82 -0
  81. package/dist/cjs/bundled_modules/d3-geo/src/path/measure.js +49 -0
  82. package/dist/cjs/bundled_modules/d3-geo/src/path/string.js +92 -0
  83. package/dist/cjs/bundled_modules/d3-geo/src/pointEqual.js +11 -0
  84. package/dist/cjs/bundled_modules/d3-geo/src/polygonContains.js +80 -0
  85. package/dist/cjs/bundled_modules/d3-geo/src/projection/albers.js +16 -0
  86. package/dist/cjs/bundled_modules/d3-geo/src/projection/albersUsa.js +117 -0
  87. package/dist/cjs/bundled_modules/d3-geo/src/projection/azimuthal.js +32 -0
  88. package/dist/cjs/bundled_modules/d3-geo/src/projection/azimuthalEqualArea.js +24 -0
  89. package/dist/cjs/bundled_modules/d3-geo/src/projection/azimuthalEquidistant.js +24 -0
  90. package/dist/cjs/bundled_modules/d3-geo/src/projection/conic.js +19 -0
  91. package/dist/cjs/bundled_modules/d3-geo/src/projection/conicConformal.js +45 -0
  92. package/dist/cjs/bundled_modules/d3-geo/src/projection/conicEqualArea.js +40 -0
  93. package/dist/cjs/bundled_modules/d3-geo/src/projection/conicEquidistant.js +39 -0
  94. package/dist/cjs/bundled_modules/d3-geo/src/projection/cylindricalEqualArea.js +19 -0
  95. package/dist/cjs/bundled_modules/d3-geo/src/projection/equalEarth.js +43 -0
  96. package/dist/cjs/bundled_modules/d3-geo/src/projection/equirectangular.js +19 -0
  97. package/dist/cjs/bundled_modules/d3-geo/src/projection/fit.js +54 -0
  98. package/dist/cjs/bundled_modules/d3-geo/src/projection/gnomonic.js +23 -0
  99. package/dist/cjs/bundled_modules/d3-geo/src/projection/identity.js +91 -0
  100. package/dist/cjs/bundled_modules/d3-geo/src/projection/index.js +184 -0
  101. package/dist/cjs/bundled_modules/d3-geo/src/projection/mercator.js +60 -0
  102. package/dist/cjs/bundled_modules/d3-geo/src/projection/naturalEarth1.js +35 -0
  103. package/dist/cjs/bundled_modules/d3-geo/src/projection/orthographic.js +22 -0
  104. package/dist/cjs/bundled_modules/d3-geo/src/projection/resample.js +108 -0
  105. package/dist/cjs/bundled_modules/d3-geo/src/projection/stereographic.js +25 -0
  106. package/dist/cjs/bundled_modules/d3-geo/src/projection/transverseMercator.js +34 -0
  107. package/dist/cjs/bundled_modules/d3-geo/src/rotation.js +86 -0
  108. package/dist/cjs/bundled_modules/d3-geo/src/stream.js +75 -0
  109. package/dist/cjs/bundled_modules/d3-geo/src/transform.js +24 -0
  110. package/dist/cjs/bundled_modules/d3-geo-projection/src/math.js +28 -0
  111. package/dist/cjs/bundled_modules/d3-geo-projection/src/mollweide.js +38 -0
  112. package/dist/cjs/bundled_modules/d3-hierarchy/src/accessors.js +13 -0
  113. package/dist/cjs/bundled_modules/d3-hierarchy/src/array.js +27 -0
  114. package/dist/cjs/bundled_modules/d3-hierarchy/src/cluster.js +90 -0
  115. package/dist/cjs/bundled_modules/d3-hierarchy/src/constant.js +16 -0
  116. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/ancestors.js +13 -0
  117. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/count.js +18 -0
  118. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/descendants.js +9 -0
  119. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/each.js +13 -0
  120. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/eachAfter.js +21 -0
  121. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/eachBefore.js +18 -0
  122. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/find.js +14 -0
  123. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/index.js +99 -0
  124. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/iterator.js +20 -0
  125. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/leaves.js +15 -0
  126. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/links.js +15 -0
  127. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/path.js +36 -0
  128. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/sort.js +13 -0
  129. package/dist/cjs/bundled_modules/d3-hierarchy/src/hierarchy/sum.js +15 -0
  130. package/dist/cjs/bundled_modules/d3-hierarchy/src/lcg.js +15 -0
  131. package/dist/cjs/bundled_modules/d3-hierarchy/src/pack/enclose.js +122 -0
  132. package/dist/cjs/bundled_modules/d3-hierarchy/src/pack/index.js +87 -0
  133. package/dist/cjs/bundled_modules/d3-hierarchy/src/pack/siblings.js +118 -0
  134. package/dist/cjs/bundled_modules/d3-hierarchy/src/partition.js +58 -0
  135. package/dist/cjs/bundled_modules/d3-hierarchy/src/stratify.js +151 -0
  136. package/dist/cjs/bundled_modules/d3-hierarchy/src/tree.js +243 -0
  137. package/dist/cjs/bundled_modules/d3-hierarchy/src/treemap/binary.js +52 -0
  138. package/dist/cjs/bundled_modules/d3-hierarchy/src/treemap/dice.js +18 -0
  139. package/dist/cjs/bundled_modules/d3-hierarchy/src/treemap/index.js +100 -0
  140. package/dist/cjs/bundled_modules/d3-hierarchy/src/treemap/resquarify.js +42 -0
  141. package/dist/cjs/bundled_modules/d3-hierarchy/src/treemap/round.js +12 -0
  142. package/dist/cjs/bundled_modules/d3-hierarchy/src/treemap/slice.js +18 -0
  143. package/dist/cjs/bundled_modules/d3-hierarchy/src/treemap/sliceDice.js +12 -0
  144. package/dist/cjs/bundled_modules/d3-hierarchy/src/treemap/squarify.js +74 -0
  145. package/dist/cjs/bundled_modules/d3-interpolate/src/array.js +29 -0
  146. package/dist/cjs/bundled_modules/d3-interpolate/src/basis.js +26 -0
  147. package/dist/cjs/bundled_modules/d3-interpolate/src/basisClosed.js +19 -0
  148. package/dist/cjs/bundled_modules/d3-interpolate/src/color.js +37 -0
  149. package/dist/cjs/bundled_modules/d3-interpolate/src/constant.js +7 -0
  150. package/dist/cjs/bundled_modules/d3-interpolate/src/cubehelix.js +36 -0
  151. package/dist/cjs/bundled_modules/d3-interpolate/src/date.js +12 -0
  152. package/dist/cjs/bundled_modules/d3-interpolate/src/discrete.js +12 -0
  153. package/dist/cjs/bundled_modules/d3-interpolate/src/hcl.js +28 -0
  154. package/dist/cjs/bundled_modules/d3-interpolate/src/hsl.js +28 -0
  155. package/dist/cjs/bundled_modules/d3-interpolate/src/hue.js +15 -0
  156. package/dist/cjs/bundled_modules/d3-interpolate/src/index.js +53 -0
  157. package/dist/cjs/bundled_modules/d3-interpolate/src/lab.js +22 -0
  158. package/dist/cjs/bundled_modules/d3-interpolate/src/number.js +11 -0
  159. package/dist/cjs/bundled_modules/d3-interpolate/src/numberArray.js +21 -0
  160. package/dist/cjs/bundled_modules/d3-interpolate/src/object.js +29 -0
  161. package/dist/cjs/bundled_modules/d3-interpolate/src/piecewise.js +17 -0
  162. package/dist/cjs/bundled_modules/d3-interpolate/src/quantize.js +11 -0
  163. package/dist/cjs/bundled_modules/d3-interpolate/src/rgb.js +63 -0
  164. package/dist/cjs/bundled_modules/d3-interpolate/src/round.js +11 -0
  165. package/dist/cjs/bundled_modules/d3-interpolate/src/string.js +70 -0
  166. package/dist/cjs/bundled_modules/d3-interpolate/src/transform/decompose.js +33 -0
  167. package/dist/cjs/bundled_modules/d3-interpolate/src/transform/index.js +68 -0
  168. package/dist/cjs/bundled_modules/d3-interpolate/src/transform/parse.js +23 -0
  169. package/dist/cjs/bundled_modules/d3-interpolate/src/value.js +28 -0
  170. package/dist/cjs/bundled_modules/d3-interpolate/src/zoom.js +77 -0
  171. package/dist/cjs/bundled_modules/d3-path/src/path.js +157 -0
  172. package/dist/cjs/bundled_modules/d3-quadtree/src/add.js +91 -0
  173. package/dist/cjs/bundled_modules/d3-quadtree/src/cover.js +49 -0
  174. package/dist/cjs/bundled_modules/d3-quadtree/src/data.js +13 -0
  175. package/dist/cjs/bundled_modules/d3-quadtree/src/extent.js +11 -0
  176. package/dist/cjs/bundled_modules/d3-quadtree/src/find.js +76 -0
  177. package/dist/cjs/bundled_modules/d3-quadtree/src/quad.js +13 -0
  178. package/dist/cjs/bundled_modules/d3-quadtree/src/quadtree.js +79 -0
  179. package/dist/cjs/bundled_modules/d3-quadtree/src/remove.js +69 -0
  180. package/dist/cjs/bundled_modules/d3-quadtree/src/root.js +9 -0
  181. package/dist/cjs/bundled_modules/d3-quadtree/src/size.js +13 -0
  182. package/dist/cjs/bundled_modules/d3-quadtree/src/visit.js +22 -0
  183. package/dist/cjs/bundled_modules/d3-quadtree/src/visitAfter.js +27 -0
  184. package/dist/cjs/bundled_modules/d3-quadtree/src/x.js +14 -0
  185. package/dist/cjs/bundled_modules/d3-quadtree/src/y.js +14 -0
  186. package/dist/cjs/bundled_modules/d3-scale/src/constant.js +11 -0
  187. package/dist/cjs/bundled_modules/d3-scale/src/continuous.js +136 -0
  188. package/dist/cjs/bundled_modules/d3-scale/src/diverging.js +116 -0
  189. package/dist/cjs/bundled_modules/d3-scale/src/identity.js +34 -0
  190. package/dist/cjs/bundled_modules/d3-scale/src/init.js +31 -0
  191. package/dist/cjs/bundled_modules/d3-scale/src/linear.js +77 -0
  192. package/dist/cjs/bundled_modules/d3-scale/src/log.js +148 -0
  193. package/dist/cjs/bundled_modules/d3-scale/src/nice.js +24 -0
  194. package/dist/cjs/bundled_modules/d3-scale/src/number.js +9 -0
  195. package/dist/cjs/bundled_modules/d3-scale/src/ordinal.js +53 -0
  196. package/dist/cjs/bundled_modules/d3-scale/src/pow.js +58 -0
  197. package/dist/cjs/bundled_modules/d3-scale/src/quantile.js +65 -0
  198. package/dist/cjs/bundled_modules/d3-scale/src/quantize.js +62 -0
  199. package/dist/cjs/bundled_modules/d3-scale/src/sequential.js +119 -0
  200. package/dist/cjs/bundled_modules/d3-scale/src/symlog.js +42 -0
  201. package/dist/cjs/bundled_modules/d3-scale/src/threshold.js +45 -0
  202. package/dist/cjs/bundled_modules/d3-scale/src/tickFormat.js +39 -0
  203. package/dist/cjs/bundled_modules/d3-scale/src/time.js +85 -0
  204. package/dist/cjs/bundled_modules/d3-scale/src/utcTime.js +21 -0
  205. package/dist/cjs/bundled_modules/d3-scale-chromatic/src/categorical/Accent.js +9 -0
  206. package/dist/cjs/bundled_modules/d3-scale-chromatic/src/categorical/Dark2.js +9 -0
  207. package/dist/cjs/bundled_modules/d3-scale-chromatic/src/categorical/Paired.js +9 -0
  208. package/dist/cjs/bundled_modules/d3-scale-chromatic/src/categorical/Pastel1.js +9 -0
  209. package/dist/cjs/bundled_modules/d3-scale-chromatic/src/categorical/Pastel2.js +9 -0
  210. package/dist/cjs/bundled_modules/d3-scale-chromatic/src/categorical/Set1.js +9 -0
  211. package/dist/cjs/bundled_modules/d3-scale-chromatic/src/categorical/Set2.js +9 -0
  212. package/dist/cjs/bundled_modules/d3-scale-chromatic/src/categorical/Set3.js +9 -0
  213. package/dist/cjs/bundled_modules/d3-scale-chromatic/src/categorical/category10.js +9 -0
  214. package/dist/cjs/bundled_modules/d3-scale-chromatic/src/categorical/observable10.js +9 -0
  215. package/dist/cjs/bundled_modules/d3-scale-chromatic/src/colors.js +11 -0
  216. package/dist/cjs/bundled_modules/d3-shape/src/arc.js +274 -0
  217. package/dist/cjs/bundled_modules/d3-shape/src/area.js +118 -0
  218. package/dist/cjs/bundled_modules/d3-shape/src/array.js +11 -0
  219. package/dist/cjs/bundled_modules/d3-shape/src/constant.js +11 -0
  220. package/dist/cjs/bundled_modules/d3-shape/src/curve/basis.js +59 -0
  221. package/dist/cjs/bundled_modules/d3-shape/src/curve/basisClosed.js +58 -0
  222. package/dist/cjs/bundled_modules/d3-shape/src/curve/basisOpen.js +45 -0
  223. package/dist/cjs/bundled_modules/d3-shape/src/curve/bundle.js +62 -0
  224. package/dist/cjs/bundled_modules/d3-shape/src/curve/cardinal.js +69 -0
  225. package/dist/cjs/bundled_modules/d3-shape/src/curve/cardinalClosed.js +68 -0
  226. package/dist/cjs/bundled_modules/d3-shape/src/curve/cardinalOpen.js +56 -0
  227. package/dist/cjs/bundled_modules/d3-shape/src/curve/catmullRom.js +95 -0
  228. package/dist/cjs/bundled_modules/d3-shape/src/curve/catmullRomClosed.js +80 -0
  229. package/dist/cjs/bundled_modules/d3-shape/src/curve/catmullRomOpen.js +68 -0
  230. package/dist/cjs/bundled_modules/d3-shape/src/curve/linear.js +37 -0
  231. package/dist/cjs/bundled_modules/d3-shape/src/curve/linearClosed.js +31 -0
  232. package/dist/cjs/bundled_modules/d3-shape/src/curve/monotone.js +109 -0
  233. package/dist/cjs/bundled_modules/d3-shape/src/curve/natural.js +71 -0
  234. package/dist/cjs/bundled_modules/d3-shape/src/curve/step.js +61 -0
  235. package/dist/cjs/bundled_modules/d3-shape/src/line.js +64 -0
  236. package/dist/cjs/bundled_modules/d3-shape/src/math.js +36 -0
  237. package/dist/cjs/bundled_modules/d3-shape/src/noop.js +7 -0
  238. package/dist/cjs/bundled_modules/d3-shape/src/path.js +23 -0
  239. package/dist/cjs/bundled_modules/d3-shape/src/point.js +12 -0
  240. package/dist/cjs/bundled_modules/d3-shape/src/symbol/circle.js +15 -0
  241. package/dist/cjs/bundled_modules/d3-shape/src/symbol.js +38 -0
  242. package/dist/cjs/bundled_modules/d3-time/src/day.js +41 -0
  243. package/dist/cjs/bundled_modules/d3-time/src/duration.js +17 -0
  244. package/dist/cjs/bundled_modules/d3-time/src/hour.js +31 -0
  245. package/dist/cjs/bundled_modules/d3-time/src/interval.js +73 -0
  246. package/dist/cjs/bundled_modules/d3-time/src/millisecond.js +29 -0
  247. package/dist/cjs/bundled_modules/d3-time/src/minute.js +31 -0
  248. package/dist/cjs/bundled_modules/d3-time/src/month.js +32 -0
  249. package/dist/cjs/bundled_modules/d3-time/src/second.js +18 -0
  250. package/dist/cjs/bundled_modules/d3-time/src/ticks.js +64 -0
  251. package/dist/cjs/bundled_modules/d3-time/src/week.js +73 -0
  252. package/dist/cjs/bundled_modules/d3-time/src/year.js +54 -0
  253. package/dist/cjs/bundled_modules/d3-time-format/src/defaultLocale.js +33 -0
  254. package/dist/cjs/bundled_modules/d3-time-format/src/locale.js +694 -0
  255. package/dist/cjs/bundled_modules/d3-timer/src/interval.js +23 -0
  256. package/dist/cjs/bundled_modules/d3-timer/src/timer.js +117 -0
  257. package/dist/cjs/bundled_modules/delaunator/index.js +485 -0
  258. package/dist/cjs/bundled_modules/internmap/src/index.js +66 -0
  259. package/dist/cjs/bundled_modules/json-stringify-pretty-compact/index.js +104 -0
  260. package/dist/cjs/bundled_modules/robust-predicates/esm/orient2d.js +184 -0
  261. package/dist/cjs/bundled_modules/robust-predicates/esm/util.js +95 -0
  262. package/dist/cjs/bundled_modules/topojson-client/src/feature.js +77 -0
  263. package/dist/cjs/bundled_modules/topojson-client/src/identity.js +9 -0
  264. package/dist/cjs/bundled_modules/topojson-client/src/mesh.js +60 -0
  265. package/dist/cjs/bundled_modules/topojson-client/src/reverse.js +10 -0
  266. package/dist/cjs/bundled_modules/topojson-client/src/stitch.js +79 -0
  267. package/dist/cjs/bundled_modules/topojson-client/src/transform.js +25 -0
  268. package/dist/cjs/bundled_modules/vega/build/vega.module.js +272 -0
  269. package/dist/cjs/bundled_modules/vega-canvas/build/vega-canvas.browser.js +18 -0
  270. package/dist/cjs/bundled_modules/vega-crossfilter/build/vega-crossfilter.js +676 -0
  271. package/dist/cjs/bundled_modules/vega-dataflow/build/vega-dataflow.js +2102 -0
  272. package/dist/cjs/bundled_modules/vega-embed/build/embed.js +2939 -0
  273. package/dist/cjs/bundled_modules/vega-encode/build/vega-encode.js +962 -0
  274. package/dist/cjs/bundled_modules/vega-event-selector/build/vega-event-selector.js +192 -0
  275. package/dist/cjs/bundled_modules/vega-expression/build/vega-expression.js +1615 -0
  276. package/dist/cjs/bundled_modules/vega-force/build/vega-force.js +295 -0
  277. package/dist/cjs/bundled_modules/vega-format/build/vega-format.js +201 -0
  278. package/dist/cjs/bundled_modules/vega-functions/build/vega-functions.js +842 -0
  279. package/dist/cjs/bundled_modules/vega-geo/build/vega-geo.js +1333 -0
  280. package/dist/cjs/bundled_modules/vega-hierarchy/build/vega-hierarchy.js +580 -0
  281. package/dist/cjs/bundled_modules/vega-interpreter/build/vega-interpreter.js +310 -0
  282. package/dist/cjs/bundled_modules/vega-label/build/vega-label.js +876 -0
  283. package/dist/cjs/bundled_modules/vega-lite/build/index.js +20157 -0
  284. package/dist/cjs/bundled_modules/vega-loader/build/vega-loader.browser.js +337 -0
  285. package/dist/cjs/bundled_modules/vega-parser/build/vega-parser.js +3805 -0
  286. package/dist/cjs/bundled_modules/vega-projection/build/vega-projection.js +90 -0
  287. package/dist/cjs/bundled_modules/vega-regression/build/vega-regression.js +236 -0
  288. package/dist/cjs/bundled_modules/vega-runtime/build/vega-runtime.js +588 -0
  289. package/dist/cjs/bundled_modules/vega-scale/build/vega-scale.js +846 -0
  290. package/dist/cjs/bundled_modules/vega-scenegraph/build/vega-scenegraph.js +5040 -0
  291. package/dist/cjs/bundled_modules/vega-schema-url-parser/dist/parser.modern.js +7 -0
  292. package/dist/cjs/bundled_modules/vega-selections/build/vega-selection.js +342 -0
  293. package/dist/cjs/bundled_modules/vega-statistics/build/vega-statistics.js +1193 -0
  294. package/dist/cjs/bundled_modules/vega-themes/build/index.js +853 -0
  295. package/dist/cjs/bundled_modules/vega-time/build/vega-time.js +342 -0
  296. package/dist/cjs/bundled_modules/vega-tooltip/build/index.js +353 -0
  297. package/dist/cjs/bundled_modules/vega-transforms/build/vega-transforms.js +3781 -0
  298. package/dist/cjs/bundled_modules/vega-util/build/vega-util.js +824 -0
  299. package/dist/cjs/bundled_modules/vega-view/build/vega-view.js +1306 -0
  300. package/dist/cjs/bundled_modules/vega-view-transforms/build/vega-view-transforms.js +1313 -0
  301. package/dist/cjs/bundled_modules/vega-voronoi/build/vega-voronoi.js +80 -0
  302. package/dist/cjs/bundled_modules/vega-wordcloud/build/vega-wordcloud.js +540 -0
  303. package/dist/cjs/unstable/extras/chart/BarChart.js +42 -0
  304. package/dist/cjs/unstable/extras/chart/Chart.js +100 -0
  305. package/dist/cjs/unstable/extras/chart/DistributionChart.js +84 -0
  306. package/dist/cjs/unstable/extras/chart/DonutChart.js +43 -0
  307. package/dist/cjs/unstable/extras/chart/LineChart.js +45 -0
  308. package/dist/cjs/unstable/extras/chart/PieChart.js +39 -0
  309. package/dist/cjs/unstable/extras/chart/TimelineChart.js +48 -0
  310. package/dist/cjs/unstable/extras/chart/index.js +23 -0
  311. package/dist/esm/bundled_modules/d3-array/src/ascending.js +5 -0
  312. package/dist/esm/bundled_modules/d3-array/src/bisect.js +10 -0
  313. package/dist/esm/bundled_modules/d3-array/src/bisector.js +58 -0
  314. package/dist/esm/bundled_modules/d3-array/src/descending.js +9 -0
  315. package/dist/esm/bundled_modules/d3-array/src/deviation.js +8 -0
  316. package/dist/esm/bundled_modules/d3-array/src/fsum.js +43 -0
  317. package/dist/esm/bundled_modules/d3-array/src/intersection.js +21 -0
  318. package/dist/esm/bundled_modules/d3-array/src/max.js +22 -0
  319. package/dist/esm/bundled_modules/d3-array/src/mean.js +21 -0
  320. package/dist/esm/bundled_modules/d3-array/src/median.js +7 -0
  321. package/dist/esm/bundled_modules/d3-array/src/merge.js +11 -0
  322. package/dist/esm/bundled_modules/d3-array/src/min.js +22 -0
  323. package/dist/esm/bundled_modules/d3-array/src/number.js +22 -0
  324. package/dist/esm/bundled_modules/d3-array/src/permute.js +5 -0
  325. package/dist/esm/bundled_modules/d3-array/src/quantile.js +31 -0
  326. package/dist/esm/bundled_modules/d3-array/src/quickselect.js +55 -0
  327. package/dist/esm/bundled_modules/d3-array/src/range.js +15 -0
  328. package/dist/esm/bundled_modules/d3-array/src/sort.js +17 -0
  329. package/dist/esm/bundled_modules/d3-array/src/sum.js +13 -0
  330. package/dist/esm/bundled_modules/d3-array/src/ticks.js +57 -0
  331. package/dist/esm/bundled_modules/d3-array/src/union.js +13 -0
  332. package/dist/esm/bundled_modules/d3-array/src/variance.js +27 -0
  333. package/dist/esm/bundled_modules/d3-color/src/color.js +398 -0
  334. package/dist/esm/bundled_modules/d3-color/src/cubehelix.js +63 -0
  335. package/dist/esm/bundled_modules/d3-color/src/define.js +12 -0
  336. package/dist/esm/bundled_modules/d3-color/src/lab.js +117 -0
  337. package/dist/esm/bundled_modules/d3-color/src/math.js +4 -0
  338. package/dist/esm/bundled_modules/d3-delaunay/src/delaunay.js +250 -0
  339. package/dist/esm/bundled_modules/d3-delaunay/src/path.js +39 -0
  340. package/dist/esm/bundled_modules/d3-delaunay/src/polygon.js +19 -0
  341. package/dist/esm/bundled_modules/d3-delaunay/src/voronoi.js +334 -0
  342. package/dist/esm/bundled_modules/d3-dispatch/src/dispatch.js +84 -0
  343. package/dist/esm/bundled_modules/d3-dsv/src/dsv.js +166 -0
  344. package/dist/esm/bundled_modules/d3-force/src/center.js +42 -0
  345. package/dist/esm/bundled_modules/d3-force/src/collide.js +102 -0
  346. package/dist/esm/bundled_modules/d3-force/src/constant.js +7 -0
  347. package/dist/esm/bundled_modules/d3-force/src/jiggle.js +5 -0
  348. package/dist/esm/bundled_modules/d3-force/src/lcg.js +11 -0
  349. package/dist/esm/bundled_modules/d3-force/src/link.js +119 -0
  350. package/dist/esm/bundled_modules/d3-force/src/manyBody.js +118 -0
  351. package/dist/esm/bundled_modules/d3-force/src/simulation.js +158 -0
  352. package/dist/esm/bundled_modules/d3-force/src/x.js +43 -0
  353. package/dist/esm/bundled_modules/d3-force/src/y.js +43 -0
  354. package/dist/esm/bundled_modules/d3-format/src/defaultLocale.js +20 -0
  355. package/dist/esm/bundled_modules/d3-format/src/exponent.js +7 -0
  356. package/dist/esm/bundled_modules/d3-format/src/formatDecimal.js +22 -0
  357. package/dist/esm/bundled_modules/d3-format/src/formatGroup.js +20 -0
  358. package/dist/esm/bundled_modules/d3-format/src/formatNumerals.js +9 -0
  359. package/dist/esm/bundled_modules/d3-format/src/formatPrefixAuto.js +18 -0
  360. package/dist/esm/bundled_modules/d3-format/src/formatRounded.js +13 -0
  361. package/dist/esm/bundled_modules/d3-format/src/formatSpecifier.js +49 -0
  362. package/dist/esm/bundled_modules/d3-format/src/formatTrim.js +13 -0
  363. package/dist/esm/bundled_modules/d3-format/src/formatTypes.js +21 -0
  364. package/dist/esm/bundled_modules/d3-format/src/identity.js +5 -0
  365. package/dist/esm/bundled_modules/d3-format/src/locale.js +150 -0
  366. package/dist/esm/bundled_modules/d3-format/src/precisionFixed.js +7 -0
  367. package/dist/esm/bundled_modules/d3-format/src/precisionPrefix.js +7 -0
  368. package/dist/esm/bundled_modules/d3-format/src/precisionRound.js +8 -0
  369. package/dist/esm/bundled_modules/d3-geo/src/area.js +78 -0
  370. package/dist/esm/bundled_modules/d3-geo/src/bounds.js +181 -0
  371. package/dist/esm/bundled_modules/d3-geo/src/cartesian.js +35 -0
  372. package/dist/esm/bundled_modules/d3-geo/src/centroid.js +145 -0
  373. package/dist/esm/bundled_modules/d3-geo/src/circle.js +33 -0
  374. package/dist/esm/bundled_modules/d3-geo/src/clip/antimeridian.js +94 -0
  375. package/dist/esm/bundled_modules/d3-geo/src/clip/buffer.js +26 -0
  376. package/dist/esm/bundled_modules/d3-geo/src/clip/circle.js +179 -0
  377. package/dist/esm/bundled_modules/d3-geo/src/clip/index.js +133 -0
  378. package/dist/esm/bundled_modules/d3-geo/src/clip/line.js +61 -0
  379. package/dist/esm/bundled_modules/d3-geo/src/clip/rectangle.js +170 -0
  380. package/dist/esm/bundled_modules/d3-geo/src/clip/rejoin.js +105 -0
  381. package/dist/esm/bundled_modules/d3-geo/src/compose.js +14 -0
  382. package/dist/esm/bundled_modules/d3-geo/src/graticule.js +103 -0
  383. package/dist/esm/bundled_modules/d3-geo/src/identity.js +3 -0
  384. package/dist/esm/bundled_modules/d3-geo/src/math.js +33 -0
  385. package/dist/esm/bundled_modules/d3-geo/src/noop.js +3 -0
  386. package/dist/esm/bundled_modules/d3-geo/src/path/area.js +50 -0
  387. package/dist/esm/bundled_modules/d3-geo/src/path/bounds.js +28 -0
  388. package/dist/esm/bundled_modules/d3-geo/src/path/centroid.js +100 -0
  389. package/dist/esm/bundled_modules/d3-geo/src/path/context.js +47 -0
  390. package/dist/esm/bundled_modules/d3-geo/src/path/index.js +78 -0
  391. package/dist/esm/bundled_modules/d3-geo/src/path/measure.js +45 -0
  392. package/dist/esm/bundled_modules/d3-geo/src/path/string.js +88 -0
  393. package/dist/esm/bundled_modules/d3-geo/src/pointEqual.js +7 -0
  394. package/dist/esm/bundled_modules/d3-geo/src/polygonContains.js +76 -0
  395. package/dist/esm/bundled_modules/d3-geo/src/projection/albers.js +12 -0
  396. package/dist/esm/bundled_modules/d3-geo/src/projection/albersUsa.js +113 -0
  397. package/dist/esm/bundled_modules/d3-geo/src/projection/azimuthal.js +29 -0
  398. package/dist/esm/bundled_modules/d3-geo/src/projection/azimuthalEqualArea.js +19 -0
  399. package/dist/esm/bundled_modules/d3-geo/src/projection/azimuthalEquidistant.js +19 -0
  400. package/dist/esm/bundled_modules/d3-geo/src/projection/conic.js +17 -0
  401. package/dist/esm/bundled_modules/d3-geo/src/projection/conicConformal.js +40 -0
  402. package/dist/esm/bundled_modules/d3-geo/src/projection/conicEqualArea.js +35 -0
  403. package/dist/esm/bundled_modules/d3-geo/src/projection/conicEquidistant.js +34 -0
  404. package/dist/esm/bundled_modules/d3-geo/src/projection/cylindricalEqualArea.js +17 -0
  405. package/dist/esm/bundled_modules/d3-geo/src/projection/equalEarth.js +38 -0
  406. package/dist/esm/bundled_modules/d3-geo/src/projection/equirectangular.js +14 -0
  407. package/dist/esm/bundled_modules/d3-geo/src/projection/fit.js +49 -0
  408. package/dist/esm/bundled_modules/d3-geo/src/projection/gnomonic.js +18 -0
  409. package/dist/esm/bundled_modules/d3-geo/src/projection/identity.js +87 -0
  410. package/dist/esm/bundled_modules/d3-geo/src/projection/index.js +179 -0
  411. package/dist/esm/bundled_modules/d3-geo/src/projection/mercator.js +54 -0
  412. package/dist/esm/bundled_modules/d3-geo/src/projection/naturalEarth1.js +30 -0
  413. package/dist/esm/bundled_modules/d3-geo/src/projection/orthographic.js +17 -0
  414. package/dist/esm/bundled_modules/d3-geo/src/projection/resample.js +104 -0
  415. package/dist/esm/bundled_modules/d3-geo/src/projection/stereographic.js +20 -0
  416. package/dist/esm/bundled_modules/d3-geo/src/projection/transverseMercator.js +29 -0
  417. package/dist/esm/bundled_modules/d3-geo/src/rotation.js +81 -0
  418. package/dist/esm/bundled_modules/d3-geo/src/stream.js +71 -0
  419. package/dist/esm/bundled_modules/d3-geo/src/transform.js +22 -0
  420. package/dist/esm/bundled_modules/d3-geo-projection/src/math.js +18 -0
  421. package/dist/esm/bundled_modules/d3-geo-projection/src/mollweide.js +31 -0
  422. package/dist/esm/bundled_modules/d3-hierarchy/src/accessors.js +10 -0
  423. package/dist/esm/bundled_modules/d3-hierarchy/src/array.js +22 -0
  424. package/dist/esm/bundled_modules/d3-hierarchy/src/cluster.js +86 -0
  425. package/dist/esm/bundled_modules/d3-hierarchy/src/constant.js +11 -0
  426. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/ancestors.js +9 -0
  427. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/count.js +14 -0
  428. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/descendants.js +5 -0
  429. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/each.js +9 -0
  430. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/eachAfter.js +17 -0
  431. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/eachBefore.js +14 -0
  432. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/find.js +10 -0
  433. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/index.js +93 -0
  434. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/iterator.js +16 -0
  435. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/leaves.js +11 -0
  436. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/links.js +11 -0
  437. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/path.js +32 -0
  438. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/sort.js +9 -0
  439. package/dist/esm/bundled_modules/d3-hierarchy/src/hierarchy/sum.js +11 -0
  440. package/dist/esm/bundled_modules/d3-hierarchy/src/lcg.js +11 -0
  441. package/dist/esm/bundled_modules/d3-hierarchy/src/pack/enclose.js +120 -0
  442. package/dist/esm/bundled_modules/d3-hierarchy/src/pack/index.js +83 -0
  443. package/dist/esm/bundled_modules/d3-hierarchy/src/pack/siblings.js +116 -0
  444. package/dist/esm/bundled_modules/d3-hierarchy/src/partition.js +54 -0
  445. package/dist/esm/bundled_modules/d3-hierarchy/src/stratify.js +147 -0
  446. package/dist/esm/bundled_modules/d3-hierarchy/src/tree.js +239 -0
  447. package/dist/esm/bundled_modules/d3-hierarchy/src/treemap/binary.js +48 -0
  448. package/dist/esm/bundled_modules/d3-hierarchy/src/treemap/dice.js +14 -0
  449. package/dist/esm/bundled_modules/d3-hierarchy/src/treemap/index.js +96 -0
  450. package/dist/esm/bundled_modules/d3-hierarchy/src/treemap/resquarify.js +38 -0
  451. package/dist/esm/bundled_modules/d3-hierarchy/src/treemap/round.js +8 -0
  452. package/dist/esm/bundled_modules/d3-hierarchy/src/treemap/slice.js +14 -0
  453. package/dist/esm/bundled_modules/d3-hierarchy/src/treemap/sliceDice.js +8 -0
  454. package/dist/esm/bundled_modules/d3-hierarchy/src/treemap/squarify.js +68 -0
  455. package/dist/esm/bundled_modules/d3-interpolate/src/array.js +24 -0
  456. package/dist/esm/bundled_modules/d3-interpolate/src/basis.js +21 -0
  457. package/dist/esm/bundled_modules/d3-interpolate/src/basisClosed.js +15 -0
  458. package/dist/esm/bundled_modules/d3-interpolate/src/color.js +31 -0
  459. package/dist/esm/bundled_modules/d3-interpolate/src/constant.js +3 -0
  460. package/dist/esm/bundled_modules/d3-interpolate/src/cubehelix.js +31 -0
  461. package/dist/esm/bundled_modules/d3-interpolate/src/date.js +8 -0
  462. package/dist/esm/bundled_modules/d3-interpolate/src/discrete.js +8 -0
  463. package/dist/esm/bundled_modules/d3-interpolate/src/hcl.js +23 -0
  464. package/dist/esm/bundled_modules/d3-interpolate/src/hsl.js +23 -0
  465. package/dist/esm/bundled_modules/d3-interpolate/src/hue.js +11 -0
  466. package/dist/esm/bundled_modules/d3-interpolate/src/index.js +21 -0
  467. package/dist/esm/bundled_modules/d3-interpolate/src/lab.js +18 -0
  468. package/dist/esm/bundled_modules/d3-interpolate/src/number.js +7 -0
  469. package/dist/esm/bundled_modules/d3-interpolate/src/numberArray.js +16 -0
  470. package/dist/esm/bundled_modules/d3-interpolate/src/object.js +25 -0
  471. package/dist/esm/bundled_modules/d3-interpolate/src/piecewise.js +13 -0
  472. package/dist/esm/bundled_modules/d3-interpolate/src/quantize.js +7 -0
  473. package/dist/esm/bundled_modules/d3-interpolate/src/rgb.js +57 -0
  474. package/dist/esm/bundled_modules/d3-interpolate/src/round.js +7 -0
  475. package/dist/esm/bundled_modules/d3-interpolate/src/string.js +66 -0
  476. package/dist/esm/bundled_modules/d3-interpolate/src/transform/decompose.js +28 -0
  477. package/dist/esm/bundled_modules/d3-interpolate/src/transform/index.js +65 -0
  478. package/dist/esm/bundled_modules/d3-interpolate/src/transform/parse.js +20 -0
  479. package/dist/esm/bundled_modules/d3-interpolate/src/value.js +24 -0
  480. package/dist/esm/bundled_modules/d3-interpolate/src/zoom.js +73 -0
  481. package/dist/esm/bundled_modules/d3-path/src/path.js +154 -0
  482. package/dist/esm/bundled_modules/d3-quadtree/src/add.js +86 -0
  483. package/dist/esm/bundled_modules/d3-quadtree/src/cover.js +45 -0
  484. package/dist/esm/bundled_modules/d3-quadtree/src/data.js +9 -0
  485. package/dist/esm/bundled_modules/d3-quadtree/src/extent.js +7 -0
  486. package/dist/esm/bundled_modules/d3-quadtree/src/find.js +72 -0
  487. package/dist/esm/bundled_modules/d3-quadtree/src/quad.js +9 -0
  488. package/dist/esm/bundled_modules/d3-quadtree/src/quadtree.js +75 -0
  489. package/dist/esm/bundled_modules/d3-quadtree/src/remove.js +64 -0
  490. package/dist/esm/bundled_modules/d3-quadtree/src/root.js +5 -0
  491. package/dist/esm/bundled_modules/d3-quadtree/src/size.js +9 -0
  492. package/dist/esm/bundled_modules/d3-quadtree/src/visit.js +18 -0
  493. package/dist/esm/bundled_modules/d3-quadtree/src/visitAfter.js +23 -0
  494. package/dist/esm/bundled_modules/d3-quadtree/src/x.js +9 -0
  495. package/dist/esm/bundled_modules/d3-quadtree/src/y.js +9 -0
  496. package/dist/esm/bundled_modules/d3-scale/src/constant.js +7 -0
  497. package/dist/esm/bundled_modules/d3-scale/src/continuous.js +129 -0
  498. package/dist/esm/bundled_modules/d3-scale/src/diverging.js +108 -0
  499. package/dist/esm/bundled_modules/d3-scale/src/identity.js +30 -0
  500. package/dist/esm/bundled_modules/d3-scale/src/init.js +28 -0
  501. package/dist/esm/bundled_modules/d3-scale/src/linear.js +72 -0
  502. package/dist/esm/bundled_modules/d3-scale/src/log.js +143 -0
  503. package/dist/esm/bundled_modules/d3-scale/src/nice.js +20 -0
  504. package/dist/esm/bundled_modules/d3-scale/src/number.js +5 -0
  505. package/dist/esm/bundled_modules/d3-scale/src/ordinal.js +48 -0
  506. package/dist/esm/bundled_modules/d3-scale/src/pow.js +52 -0
  507. package/dist/esm/bundled_modules/d3-scale/src/quantile.js +61 -0
  508. package/dist/esm/bundled_modules/d3-scale/src/quantize.js +58 -0
  509. package/dist/esm/bundled_modules/d3-scale/src/sequential.js +110 -0
  510. package/dist/esm/bundled_modules/d3-scale/src/symlog.js +37 -0
  511. package/dist/esm/bundled_modules/d3-scale/src/threshold.js +41 -0
  512. package/dist/esm/bundled_modules/d3-scale/src/tickFormat.js +35 -0
  513. package/dist/esm/bundled_modules/d3-scale/src/time.js +80 -0
  514. package/dist/esm/bundled_modules/d3-scale/src/utcTime.js +17 -0
  515. package/dist/esm/bundled_modules/d3-scale-chromatic/src/categorical/Accent.js +5 -0
  516. package/dist/esm/bundled_modules/d3-scale-chromatic/src/categorical/Dark2.js +5 -0
  517. package/dist/esm/bundled_modules/d3-scale-chromatic/src/categorical/Paired.js +5 -0
  518. package/dist/esm/bundled_modules/d3-scale-chromatic/src/categorical/Pastel1.js +5 -0
  519. package/dist/esm/bundled_modules/d3-scale-chromatic/src/categorical/Pastel2.js +5 -0
  520. package/dist/esm/bundled_modules/d3-scale-chromatic/src/categorical/Set1.js +5 -0
  521. package/dist/esm/bundled_modules/d3-scale-chromatic/src/categorical/Set2.js +5 -0
  522. package/dist/esm/bundled_modules/d3-scale-chromatic/src/categorical/Set3.js +5 -0
  523. package/dist/esm/bundled_modules/d3-scale-chromatic/src/categorical/category10.js +5 -0
  524. package/dist/esm/bundled_modules/d3-scale-chromatic/src/categorical/observable10.js +5 -0
  525. package/dist/esm/bundled_modules/d3-scale-chromatic/src/colors.js +7 -0
  526. package/dist/esm/bundled_modules/d3-shape/src/arc.js +270 -0
  527. package/dist/esm/bundled_modules/d3-shape/src/area.js +114 -0
  528. package/dist/esm/bundled_modules/d3-shape/src/array.js +7 -0
  529. package/dist/esm/bundled_modules/d3-shape/src/constant.js +7 -0
  530. package/dist/esm/bundled_modules/d3-shape/src/curve/basis.js +53 -0
  531. package/dist/esm/bundled_modules/d3-shape/src/curve/basisClosed.js +54 -0
  532. package/dist/esm/bundled_modules/d3-shape/src/curve/basisOpen.js +41 -0
  533. package/dist/esm/bundled_modules/d3-shape/src/curve/bundle.js +58 -0
  534. package/dist/esm/bundled_modules/d3-shape/src/curve/cardinal.js +63 -0
  535. package/dist/esm/bundled_modules/d3-shape/src/curve/cardinalClosed.js +63 -0
  536. package/dist/esm/bundled_modules/d3-shape/src/curve/cardinalOpen.js +51 -0
  537. package/dist/esm/bundled_modules/d3-shape/src/curve/catmullRom.js +90 -0
  538. package/dist/esm/bundled_modules/d3-shape/src/curve/catmullRomClosed.js +76 -0
  539. package/dist/esm/bundled_modules/d3-shape/src/curve/catmullRomOpen.js +64 -0
  540. package/dist/esm/bundled_modules/d3-shape/src/curve/linear.js +33 -0
  541. package/dist/esm/bundled_modules/d3-shape/src/curve/linearClosed.js +27 -0
  542. package/dist/esm/bundled_modules/d3-shape/src/curve/monotone.js +106 -0
  543. package/dist/esm/bundled_modules/d3-shape/src/curve/natural.js +67 -0
  544. package/dist/esm/bundled_modules/d3-shape/src/curve/step.js +55 -0
  545. package/dist/esm/bundled_modules/d3-shape/src/line.js +60 -0
  546. package/dist/esm/bundled_modules/d3-shape/src/math.js +22 -0
  547. package/dist/esm/bundled_modules/d3-shape/src/noop.js +3 -0
  548. package/dist/esm/bundled_modules/d3-shape/src/path.js +21 -0
  549. package/dist/esm/bundled_modules/d3-shape/src/point.js +9 -0
  550. package/dist/esm/bundled_modules/d3-shape/src/symbol/circle.js +11 -0
  551. package/dist/esm/bundled_modules/d3-shape/src/symbol.js +34 -0
  552. package/dist/esm/bundled_modules/d3-time/src/day.js +37 -0
  553. package/dist/esm/bundled_modules/d3-time/src/duration.js +9 -0
  554. package/dist/esm/bundled_modules/d3-time/src/hour.js +28 -0
  555. package/dist/esm/bundled_modules/d3-time/src/interval.js +71 -0
  556. package/dist/esm/bundled_modules/d3-time/src/millisecond.js +27 -0
  557. package/dist/esm/bundled_modules/d3-time/src/minute.js +28 -0
  558. package/dist/esm/bundled_modules/d3-time/src/month.js +29 -0
  559. package/dist/esm/bundled_modules/d3-time/src/second.js +16 -0
  560. package/dist/esm/bundled_modules/d3-time/src/ticks.js +59 -0
  561. package/dist/esm/bundled_modules/d3-time/src/week.js +58 -0
  562. package/dist/esm/bundled_modules/d3-time/src/year.js +51 -0
  563. package/dist/esm/bundled_modules/d3-time-format/src/defaultLocale.js +29 -0
  564. package/dist/esm/bundled_modules/d3-time-format/src/locale.js +690 -0
  565. package/dist/esm/bundled_modules/d3-timer/src/interval.js +19 -0
  566. package/dist/esm/bundled_modules/d3-timer/src/timer.js +112 -0
  567. package/dist/esm/bundled_modules/delaunator/index.js +481 -0
  568. package/dist/esm/bundled_modules/internmap/src/index.js +63 -0
  569. package/dist/esm/bundled_modules/json-stringify-pretty-compact/index.js +100 -0
  570. package/dist/esm/bundled_modules/robust-predicates/esm/orient2d.js +182 -0
  571. package/dist/esm/bundled_modules/robust-predicates/esm/util.js +88 -0
  572. package/dist/esm/bundled_modules/topojson-client/src/feature.js +72 -0
  573. package/dist/esm/bundled_modules/topojson-client/src/identity.js +5 -0
  574. package/dist/esm/bundled_modules/topojson-client/src/mesh.js +55 -0
  575. package/dist/esm/bundled_modules/topojson-client/src/reverse.js +6 -0
  576. package/dist/esm/bundled_modules/topojson-client/src/stitch.js +75 -0
  577. package/dist/esm/bundled_modules/topojson-client/src/transform.js +21 -0
  578. package/dist/esm/bundled_modules/vega/build/vega.module.js +38 -0
  579. package/dist/esm/bundled_modules/vega-canvas/build/vega-canvas.browser.js +14 -0
  580. package/dist/esm/bundled_modules/vega-crossfilter/build/vega-crossfilter.js +673 -0
  581. package/dist/esm/bundled_modules/vega-dataflow/build/vega-dataflow.js +2080 -0
  582. package/dist/esm/bundled_modules/vega-embed/build/embed.js +2932 -0
  583. package/dist/esm/bundled_modules/vega-encode/build/vega-encode.js +952 -0
  584. package/dist/esm/bundled_modules/vega-event-selector/build/vega-event-selector.js +190 -0
  585. package/dist/esm/bundled_modules/vega-expression/build/vega-expression.js +1597 -0
  586. package/dist/esm/bundled_modules/vega-force/build/vega-force.js +293 -0
  587. package/dist/esm/bundled_modules/vega-format/build/vega-format.js +191 -0
  588. package/dist/esm/bundled_modules/vega-functions/build/vega-functions.js +779 -0
  589. package/dist/esm/bundled_modules/vega-geo/build/vega-geo.js +1322 -0
  590. package/dist/esm/bundled_modules/vega-hierarchy/build/vega-hierarchy.js +572 -0
  591. package/dist/esm/bundled_modules/vega-interpreter/build/vega-interpreter.js +308 -0
  592. package/dist/esm/bundled_modules/vega-label/build/vega-label.js +874 -0
  593. package/dist/esm/bundled_modules/vega-lite/build/index.js +20110 -0
  594. package/dist/esm/bundled_modules/vega-loader/build/vega-loader.browser.js +328 -0
  595. package/dist/esm/bundled_modules/vega-parser/build/vega-parser.js +3783 -0
  596. package/dist/esm/bundled_modules/vega-projection/build/vega-projection.js +86 -0
  597. package/dist/esm/bundled_modules/vega-regression/build/vega-regression.js +233 -0
  598. package/dist/esm/bundled_modules/vega-runtime/build/vega-runtime.js +586 -0
  599. package/dist/esm/bundled_modules/vega-scale/build/vega-scale.js +799 -0
  600. package/dist/esm/bundled_modules/vega-scenegraph/build/vega-scenegraph.js +4982 -0
  601. package/dist/esm/bundled_modules/vega-schema-url-parser/dist/parser.modern.js +3 -0
  602. package/dist/esm/bundled_modules/vega-selections/build/vega-selection.js +336 -0
  603. package/dist/esm/bundled_modules/vega-statistics/build/vega-statistics.js +1157 -0
  604. package/dist/esm/bundled_modules/vega-themes/build/index.js +837 -0
  605. package/dist/esm/bundled_modules/vega-time/build/vega-time.js +314 -0
  606. package/dist/esm/bundled_modules/vega-tooltip/build/index.js +339 -0
  607. package/dist/esm/bundled_modules/vega-transforms/build/vega-transforms.js +3740 -0
  608. package/dist/esm/bundled_modules/vega-util/build/vega-util.js +753 -0
  609. package/dist/esm/bundled_modules/vega-view/build/vega-view.js +1304 -0
  610. package/dist/esm/bundled_modules/vega-view-transforms/build/vega-view-transforms.js +1306 -0
  611. package/dist/esm/bundled_modules/vega-voronoi/build/vega-voronoi.js +78 -0
  612. package/dist/esm/bundled_modules/vega-wordcloud/build/vega-wordcloud.js +538 -0
  613. package/dist/esm/unstable/extras/chart/BarChart.js +40 -0
  614. package/dist/esm/unstable/extras/chart/Chart.js +96 -0
  615. package/dist/esm/unstable/extras/chart/DistributionChart.js +82 -0
  616. package/dist/esm/unstable/extras/chart/DonutChart.js +41 -0
  617. package/dist/esm/unstable/extras/chart/LineChart.js +43 -0
  618. package/dist/esm/unstable/extras/chart/PieChart.js +37 -0
  619. package/dist/esm/unstable/extras/chart/TimelineChart.js +46 -0
  620. package/dist/esm/unstable/extras/chart/index.js +8 -0
  621. package/dist/types/unstable/extras/chart/BarChart.d.ts +16 -0
  622. package/dist/types/unstable/extras/chart/Chart.d.ts +33 -0
  623. package/dist/types/unstable/extras/chart/DistributionChart.d.ts +18 -0
  624. package/dist/types/unstable/extras/chart/DonutChart.d.ts +16 -0
  625. package/dist/types/unstable/extras/chart/LineChart.d.ts +16 -0
  626. package/dist/types/unstable/extras/chart/PieChart.d.ts +14 -0
  627. package/dist/types/unstable/extras/chart/TimelineChart.d.ts +15 -0
  628. package/dist/types/unstable/extras/chart/index.d.ts +15 -0
  629. package/package.json +1 -1
@@ -0,0 +1,1193 @@
1
+ 'use strict';
2
+
3
+ var deviation = require('../../d3-array/src/deviation.js');
4
+ var ascending = require('../../d3-array/src/ascending.js');
5
+ var quantile = require('../../d3-array/src/quantile.js');
6
+ var median = require('../../d3-array/src/median.js');
7
+
8
+ function* numbers (values, valueof) {
9
+ if (valueof == null) {
10
+ for (let value of values) {
11
+ if (value != null && value !== '' && (value = +value) >= value) {
12
+ yield value;
13
+ }
14
+ }
15
+ } else {
16
+ let index = -1;
17
+ for (let value of values) {
18
+ value = valueof(value, ++index, values);
19
+ if (value != null && value !== '' && (value = +value) >= value) {
20
+ yield value;
21
+ }
22
+ }
23
+ }
24
+ }
25
+
26
+ function quantiles (array, p, f) {
27
+ const values = Float64Array.from(numbers(array, f));
28
+
29
+ // don't depend on return value from typed array sort call
30
+ // protects against undefined sort results in Safari (vega/vega-lite#4964)
31
+ values.sort(ascending.default);
32
+ return p.map(_ => quantile.quantileSorted(values, _));
33
+ }
34
+
35
+ function quartiles (array, f) {
36
+ return quantiles(array, [0.25, 0.50, 0.75], f);
37
+ }
38
+
39
+ // Scott, D. W. (1992) Multivariate Density Estimation:
40
+ // Theory, Practice, and Visualization. Wiley.
41
+ function estimateBandwidth (array, f) {
42
+ const n = array.length,
43
+ d = deviation.default(array, f),
44
+ q = quartiles(array, f),
45
+ h = (q[2] - q[0]) / 1.34,
46
+ v = Math.min(d, h) || d || Math.abs(q[0]) || 1;
47
+ return 1.06 * v * Math.pow(n, -0.2);
48
+ }
49
+
50
+ function bin (_) {
51
+ // determine range
52
+ const maxb = _.maxbins || 20,
53
+ base = _.base || 10,
54
+ logb = Math.log(base),
55
+ div = _.divide || [5, 2];
56
+ let min = _.extent[0],
57
+ max = _.extent[1],
58
+ step,
59
+ level,
60
+ minstep,
61
+ v,
62
+ i,
63
+ n;
64
+ const span = _.span || max - min || Math.abs(min) || 1;
65
+ if (_.step) {
66
+ // if step size is explicitly given, use that
67
+ step = _.step;
68
+ } else if (_.steps) {
69
+ // if provided, limit choice to acceptable step sizes
70
+ v = span / maxb;
71
+ for (i = 0, n = _.steps.length; i < n && _.steps[i] < v; ++i);
72
+ step = _.steps[Math.max(0, i - 1)];
73
+ } else {
74
+ // else use span to determine step size
75
+ level = Math.ceil(Math.log(maxb) / logb);
76
+ minstep = _.minstep || 0;
77
+ step = Math.max(minstep, Math.pow(base, Math.round(Math.log(span) / logb) - level));
78
+
79
+ // increase step size if too many bins
80
+ while (Math.ceil(span / step) > maxb) {
81
+ step *= base;
82
+ }
83
+
84
+ // decrease step size if allowed
85
+ for (i = 0, n = div.length; i < n; ++i) {
86
+ v = step / div[i];
87
+ if (v >= minstep && span / v <= maxb) step = v;
88
+ }
89
+ }
90
+
91
+ // update precision, min and max
92
+ v = Math.log(step);
93
+ const precision = v >= 0 ? 0 : ~~(-v / logb) + 1,
94
+ eps = Math.pow(base, -precision - 1);
95
+ if (_.nice || _.nice === undefined) {
96
+ v = Math.floor(min / step + eps) * step;
97
+ min = min < v ? v - step : v;
98
+ max = Math.ceil(max / step) * step;
99
+ }
100
+ return {
101
+ start: min,
102
+ stop: max === min ? min + step : max,
103
+ step: step
104
+ };
105
+ }
106
+
107
+ exports.random = Math.random;
108
+ function setRandom(r) {
109
+ exports.random = r;
110
+ }
111
+
112
+ function bootstrapCI (array, samples, alpha, f) {
113
+ if (!array.length) return [undefined, undefined];
114
+ const values = Float64Array.from(numbers(array, f)),
115
+ n = values.length,
116
+ m = samples;
117
+ let a, i, j, mu;
118
+ for (j = 0, mu = Array(m); j < m; ++j) {
119
+ for (a = 0, i = 0; i < n; ++i) {
120
+ a += values[~~(exports.random() * n)];
121
+ }
122
+ mu[j] = a / n;
123
+ }
124
+ mu.sort(ascending.default);
125
+ return [quantile.default(mu, alpha / 2), quantile.default(mu, 1 - alpha / 2)];
126
+ }
127
+
128
+ // Dot density binning for dot plot construction.
129
+ // Based on Leland Wilkinson, Dot Plots, The American Statistician, 1999.
130
+ // https://www.cs.uic.edu/~wilkinson/Publications/dotplots.pdf
131
+ function dotbin (array, step, smooth, f) {
132
+ f = f || (_ => _);
133
+ const n = array.length,
134
+ v = new Float64Array(n);
135
+ let i = 0,
136
+ j = 1,
137
+ a = f(array[0]),
138
+ b = a,
139
+ w = a + step,
140
+ x;
141
+ for (; j < n; ++j) {
142
+ x = f(array[j]);
143
+ if (x >= w) {
144
+ b = (a + b) / 2;
145
+ for (; i < j; ++i) v[i] = b;
146
+ w = x + step;
147
+ a = x;
148
+ }
149
+ b = x;
150
+ }
151
+ b = (a + b) / 2;
152
+ for (; i < j; ++i) v[i] = b;
153
+ return smooth ? smoothing(v, step + step / 4) : v;
154
+ }
155
+
156
+ // perform smoothing to reduce variance
157
+ // swap points between "adjacent" stacks
158
+ // Wilkinson defines adjacent as within step/4 units
159
+ function smoothing(v, thresh) {
160
+ const n = v.length;
161
+ let a = 0,
162
+ b = 1,
163
+ c,
164
+ d;
165
+
166
+ // get left stack
167
+ while (v[a] === v[b]) ++b;
168
+ while (b < n) {
169
+ // get right stack
170
+ c = b + 1;
171
+ while (v[b] === v[c]) ++c;
172
+
173
+ // are stacks adjacent?
174
+ // if so, compare sizes and swap as needed
175
+ if (v[b] - v[b - 1] < thresh) {
176
+ d = b + (a + c - b - b >> 1);
177
+ while (d < b) v[d++] = v[b];
178
+ while (d > b) v[d--] = v[a];
179
+ }
180
+
181
+ // update left stack indices
182
+ a = b;
183
+ b = c;
184
+ }
185
+ return v;
186
+ }
187
+
188
+ function lcg (seed) {
189
+ // Random numbers using a Linear Congruential Generator with seed value
190
+ // Uses glibc values from https://en.wikipedia.org/wiki/Linear_congruential_generator
191
+ return function () {
192
+ seed = (1103515245 * seed + 12345) % 2147483647;
193
+ return seed / 2147483647;
194
+ };
195
+ }
196
+
197
+ function integer (min, max) {
198
+ if (max == null) {
199
+ max = min;
200
+ min = 0;
201
+ }
202
+ let a, b, d;
203
+ const dist = {
204
+ min(_) {
205
+ if (arguments.length) {
206
+ a = _ || 0;
207
+ d = b - a;
208
+ return dist;
209
+ } else {
210
+ return a;
211
+ }
212
+ },
213
+ max(_) {
214
+ if (arguments.length) {
215
+ b = _ || 0;
216
+ d = b - a;
217
+ return dist;
218
+ } else {
219
+ return b;
220
+ }
221
+ },
222
+ sample() {
223
+ return a + Math.floor(d * exports.random());
224
+ },
225
+ pdf(x) {
226
+ return x === Math.floor(x) && x >= a && x < b ? 1 / d : 0;
227
+ },
228
+ cdf(x) {
229
+ const v = Math.floor(x);
230
+ return v < a ? 0 : v >= b ? 1 : (v - a + 1) / d;
231
+ },
232
+ icdf(p) {
233
+ return p >= 0 && p <= 1 ? a - 1 + Math.floor(p * d) : NaN;
234
+ }
235
+ };
236
+ return dist.min(min).max(max);
237
+ }
238
+
239
+ const SQRT2PI = Math.sqrt(2 * Math.PI);
240
+ const SQRT2 = Math.SQRT2;
241
+
242
+ let nextSample = NaN;
243
+ function sampleNormal(mean, stdev) {
244
+ mean = mean || 0;
245
+ stdev = stdev == null ? 1 : stdev;
246
+ let x = 0,
247
+ y = 0,
248
+ rds,
249
+ c;
250
+ if (nextSample === nextSample) {
251
+ x = nextSample;
252
+ nextSample = NaN;
253
+ } else {
254
+ do {
255
+ x = exports.random() * 2 - 1;
256
+ y = exports.random() * 2 - 1;
257
+ rds = x * x + y * y;
258
+ } while (rds === 0 || rds > 1);
259
+ c = Math.sqrt(-2 * Math.log(rds) / rds); // Box-Muller transform
260
+ x *= c;
261
+ nextSample = y * c;
262
+ }
263
+ return mean + x * stdev;
264
+ }
265
+ function densityNormal(value, mean, stdev) {
266
+ stdev = stdev == null ? 1 : stdev;
267
+ const z = (value - (mean || 0)) / stdev;
268
+ return Math.exp(-0.5 * z * z) / (stdev * SQRT2PI);
269
+ }
270
+
271
+ // Approximation from West (2009)
272
+ // Better Approximations to Cumulative Normal Functions
273
+ function cumulativeNormal(value, mean, stdev) {
274
+ mean = mean || 0;
275
+ stdev = stdev == null ? 1 : stdev;
276
+ const z = (value - mean) / stdev,
277
+ Z = Math.abs(z);
278
+ let cd;
279
+ if (Z > 37) {
280
+ cd = 0;
281
+ } else {
282
+ const exp = Math.exp(-Z * Z / 2);
283
+ let sum;
284
+ if (Z < 7.07106781186547) {
285
+ sum = 3.52624965998911e-02 * Z + 0.700383064443688;
286
+ sum = sum * Z + 6.37396220353165;
287
+ sum = sum * Z + 33.912866078383;
288
+ sum = sum * Z + 112.079291497871;
289
+ sum = sum * Z + 221.213596169931;
290
+ sum = sum * Z + 220.206867912376;
291
+ cd = exp * sum;
292
+ sum = 8.83883476483184e-02 * Z + 1.75566716318264;
293
+ sum = sum * Z + 16.064177579207;
294
+ sum = sum * Z + 86.7807322029461;
295
+ sum = sum * Z + 296.564248779674;
296
+ sum = sum * Z + 637.333633378831;
297
+ sum = sum * Z + 793.826512519948;
298
+ sum = sum * Z + 440.413735824752;
299
+ cd = cd / sum;
300
+ } else {
301
+ sum = Z + 0.65;
302
+ sum = Z + 4 / sum;
303
+ sum = Z + 3 / sum;
304
+ sum = Z + 2 / sum;
305
+ sum = Z + 1 / sum;
306
+ cd = exp / sum / 2.506628274631;
307
+ }
308
+ }
309
+ return z > 0 ? 1 - cd : cd;
310
+ }
311
+
312
+ // Approximation of Probit function using inverse error function.
313
+ function quantileNormal(p, mean, stdev) {
314
+ if (p < 0 || p > 1) return NaN;
315
+ return (mean || 0) + (stdev == null ? 1 : stdev) * SQRT2 * erfinv(2 * p - 1);
316
+ }
317
+
318
+ // Approximate inverse error function. Implementation from "Approximating
319
+ // the erfinv function" by Mike Giles, GPU Computing Gems, volume 2, 2010.
320
+ // Ported from Apache Commons Math, http://www.apache.org/licenses/LICENSE-2.0
321
+ function erfinv(x) {
322
+ // beware that the logarithm argument must be
323
+ // commputed as (1.0 - x) * (1.0 + x),
324
+ // it must NOT be simplified as 1.0 - x * x as this
325
+ // would induce rounding errors near the boundaries +/-1
326
+ let w = -Math.log((1 - x) * (1 + x)),
327
+ p;
328
+ if (w < 6.25) {
329
+ w -= 3.125;
330
+ p = -364441206401782e-35;
331
+ p = -16850591381820166e-35 + p * w;
332
+ p = 1.2858480715256400167e-18 + p * w;
333
+ p = 1.115787767802518096e-17 + p * w;
334
+ p = -1333171662854621e-31 + p * w;
335
+ p = 2.0972767875968561637e-17 + p * w;
336
+ p = 6.6376381343583238325e-15 + p * w;
337
+ p = -4054566272975207e-29 + p * w;
338
+ p = -8151934197605472e-29 + p * w;
339
+ p = 2.6335093153082322977e-12 + p * w;
340
+ p = -12975133253453532e-27 + p * w;
341
+ p = -5415412054294628e-26 + p * w;
342
+ p = 1.051212273321532285e-09 + p * w;
343
+ p = -4.112633980346984e-9 + p * w;
344
+ p = -2.9070369957882005e-8 + p * w;
345
+ p = 4.2347877827932403518e-07 + p * w;
346
+ p = -13654692000834679e-22 + p * w;
347
+ p = -13882523362786469e-21 + p * w;
348
+ p = 0.0001867342080340571352 + p * w;
349
+ p = -740702534166267e-18 + p * w;
350
+ p = -0.006033670871430149 + p * w;
351
+ p = 0.24015818242558961693 + p * w;
352
+ p = 1.6536545626831027356 + p * w;
353
+ } else if (w < 16.0) {
354
+ w = Math.sqrt(w) - 3.25;
355
+ p = 2.2137376921775787049e-09;
356
+ p = 9.0756561938885390979e-08 + p * w;
357
+ p = -2.7517406297064545e-7 + p * w;
358
+ p = 1.8239629214389227755e-08 + p * w;
359
+ p = 1.5027403968909827627e-06 + p * w;
360
+ p = -4013867526981546e-21 + p * w;
361
+ p = 2.9234449089955446044e-06 + p * w;
362
+ p = 1.2475304481671778723e-05 + p * w;
363
+ p = -47318229009055734e-21 + p * w;
364
+ p = 6.8284851459573175448e-05 + p * w;
365
+ p = 2.4031110387097893999e-05 + p * w;
366
+ p = -3550375203628475e-19 + p * w;
367
+ p = 0.00095328937973738049703 + p * w;
368
+ p = -0.0016882755560235047 + p * w;
369
+ p = 0.0024914420961078508066 + p * w;
370
+ p = -0.003751208507569241 + p * w;
371
+ p = 0.005370914553590063617 + p * w;
372
+ p = 1.0052589676941592334 + p * w;
373
+ p = 3.0838856104922207635 + p * w;
374
+ } else if (Number.isFinite(w)) {
375
+ w = Math.sqrt(w) - 5.0;
376
+ p = -27109920616438573e-27;
377
+ p = -2555641816996525e-25 + p * w;
378
+ p = 1.5076572693500548083e-09 + p * w;
379
+ p = -3.789465440126737e-9 + p * w;
380
+ p = 7.6157012080783393804e-09 + p * w;
381
+ p = -1.496002662714924e-8 + p * w;
382
+ p = 2.9147953450901080826e-08 + p * w;
383
+ p = -6.771199775845234e-8 + p * w;
384
+ p = 2.2900482228026654717e-07 + p * w;
385
+ p = -9.9298272942317e-7 + p * w;
386
+ p = 4.5260625972231537039e-06 + p * w;
387
+ p = -1968177810553167e-20 + p * w;
388
+ p = 7.5995277030017761139e-05 + p * w;
389
+ p = -21503011930044477e-20 + p * w;
390
+ p = -13871931833623122e-20 + p * w;
391
+ p = 1.0103004648645343977 + p * w;
392
+ p = 4.8499064014085844221 + p * w;
393
+ } else {
394
+ p = Infinity;
395
+ }
396
+ return p * x;
397
+ }
398
+ function gaussian (mean, stdev) {
399
+ let mu, sigma;
400
+ const dist = {
401
+ mean(_) {
402
+ if (arguments.length) {
403
+ mu = _ || 0;
404
+ return dist;
405
+ } else {
406
+ return mu;
407
+ }
408
+ },
409
+ stdev(_) {
410
+ if (arguments.length) {
411
+ sigma = _ == null ? 1 : _;
412
+ return dist;
413
+ } else {
414
+ return sigma;
415
+ }
416
+ },
417
+ sample: () => sampleNormal(mu, sigma),
418
+ pdf: value => densityNormal(value, mu, sigma),
419
+ cdf: value => cumulativeNormal(value, mu, sigma),
420
+ icdf: p => quantileNormal(p, mu, sigma)
421
+ };
422
+ return dist.mean(mean).stdev(stdev);
423
+ }
424
+
425
+ function kde (support, bandwidth) {
426
+ const kernel = gaussian();
427
+ let n = 0;
428
+ const dist = {
429
+ data(_) {
430
+ if (arguments.length) {
431
+ support = _;
432
+ n = _ ? _.length : 0;
433
+ return dist.bandwidth(bandwidth);
434
+ } else {
435
+ return support;
436
+ }
437
+ },
438
+ bandwidth(_) {
439
+ if (!arguments.length) return bandwidth;
440
+ bandwidth = _;
441
+ if (!bandwidth && support) bandwidth = estimateBandwidth(support);
442
+ return dist;
443
+ },
444
+ sample() {
445
+ return support[~~(exports.random() * n)] + bandwidth * kernel.sample();
446
+ },
447
+ pdf(x) {
448
+ let y = 0,
449
+ i = 0;
450
+ for (; i < n; ++i) {
451
+ y += kernel.pdf((x - support[i]) / bandwidth);
452
+ }
453
+ return y / bandwidth / n;
454
+ },
455
+ cdf(x) {
456
+ let y = 0,
457
+ i = 0;
458
+ for (; i < n; ++i) {
459
+ y += kernel.cdf((x - support[i]) / bandwidth);
460
+ }
461
+ return y / n;
462
+ },
463
+ icdf() {
464
+ throw Error('KDE icdf not supported.');
465
+ }
466
+ };
467
+ return dist.data(support);
468
+ }
469
+
470
+ function sampleLogNormal(mean, stdev) {
471
+ mean = mean || 0;
472
+ stdev = stdev == null ? 1 : stdev;
473
+ return Math.exp(mean + sampleNormal() * stdev);
474
+ }
475
+ function densityLogNormal(value, mean, stdev) {
476
+ if (value <= 0) return 0;
477
+ mean = mean || 0;
478
+ stdev = stdev == null ? 1 : stdev;
479
+ const z = (Math.log(value) - mean) / stdev;
480
+ return Math.exp(-0.5 * z * z) / (stdev * SQRT2PI * value);
481
+ }
482
+ function cumulativeLogNormal(value, mean, stdev) {
483
+ return cumulativeNormal(Math.log(value), mean, stdev);
484
+ }
485
+ function quantileLogNormal(p, mean, stdev) {
486
+ return Math.exp(quantileNormal(p, mean, stdev));
487
+ }
488
+ function lognormal (mean, stdev) {
489
+ let mu, sigma;
490
+ const dist = {
491
+ mean(_) {
492
+ if (arguments.length) {
493
+ mu = _ || 0;
494
+ return dist;
495
+ } else {
496
+ return mu;
497
+ }
498
+ },
499
+ stdev(_) {
500
+ if (arguments.length) {
501
+ sigma = _ == null ? 1 : _;
502
+ return dist;
503
+ } else {
504
+ return sigma;
505
+ }
506
+ },
507
+ sample: () => sampleLogNormal(mu, sigma),
508
+ pdf: value => densityLogNormal(value, mu, sigma),
509
+ cdf: value => cumulativeLogNormal(value, mu, sigma),
510
+ icdf: p => quantileLogNormal(p, mu, sigma)
511
+ };
512
+ return dist.mean(mean).stdev(stdev);
513
+ }
514
+
515
+ function mixture (dists, weights) {
516
+ let m = 0,
517
+ w;
518
+ function normalize(x) {
519
+ const w = [];
520
+ let sum = 0,
521
+ i;
522
+ for (i = 0; i < m; ++i) {
523
+ sum += w[i] = x[i] == null ? 1 : +x[i];
524
+ }
525
+ for (i = 0; i < m; ++i) {
526
+ w[i] /= sum;
527
+ }
528
+ return w;
529
+ }
530
+ const dist = {
531
+ weights(_) {
532
+ if (arguments.length) {
533
+ w = normalize(weights = _ || []);
534
+ return dist;
535
+ }
536
+ return weights;
537
+ },
538
+ distributions(_) {
539
+ if (arguments.length) {
540
+ if (_) {
541
+ m = _.length;
542
+ dists = _;
543
+ } else {
544
+ m = 0;
545
+ dists = [];
546
+ }
547
+ return dist.weights(weights);
548
+ }
549
+ return dists;
550
+ },
551
+ sample() {
552
+ const r = exports.random();
553
+ let d = dists[m - 1],
554
+ v = w[0],
555
+ i = 0;
556
+
557
+ // first select distribution
558
+ for (; i < m - 1; v += w[++i]) {
559
+ if (r < v) {
560
+ d = dists[i];
561
+ break;
562
+ }
563
+ }
564
+ // then sample from it
565
+ return d.sample();
566
+ },
567
+ pdf(x) {
568
+ let p = 0,
569
+ i = 0;
570
+ for (; i < m; ++i) {
571
+ p += w[i] * dists[i].pdf(x);
572
+ }
573
+ return p;
574
+ },
575
+ cdf(x) {
576
+ let p = 0,
577
+ i = 0;
578
+ for (; i < m; ++i) {
579
+ p += w[i] * dists[i].cdf(x);
580
+ }
581
+ return p;
582
+ },
583
+ icdf() {
584
+ throw Error('Mixture icdf not supported.');
585
+ }
586
+ };
587
+ return dist.distributions(dists).weights(weights);
588
+ }
589
+
590
+ function sampleUniform(min, max) {
591
+ if (max == null) {
592
+ max = min == null ? 1 : min;
593
+ min = 0;
594
+ }
595
+ return min + (max - min) * exports.random();
596
+ }
597
+ function densityUniform(value, min, max) {
598
+ if (max == null) {
599
+ max = min == null ? 1 : min;
600
+ min = 0;
601
+ }
602
+ return value >= min && value <= max ? 1 / (max - min) : 0;
603
+ }
604
+ function cumulativeUniform(value, min, max) {
605
+ if (max == null) {
606
+ max = min == null ? 1 : min;
607
+ min = 0;
608
+ }
609
+ return value < min ? 0 : value > max ? 1 : (value - min) / (max - min);
610
+ }
611
+ function quantileUniform(p, min, max) {
612
+ if (max == null) {
613
+ max = min == null ? 1 : min;
614
+ min = 0;
615
+ }
616
+ return p >= 0 && p <= 1 ? min + p * (max - min) : NaN;
617
+ }
618
+ function uniform (min, max) {
619
+ let a, b;
620
+ const dist = {
621
+ min(_) {
622
+ if (arguments.length) {
623
+ a = _ || 0;
624
+ return dist;
625
+ } else {
626
+ return a;
627
+ }
628
+ },
629
+ max(_) {
630
+ if (arguments.length) {
631
+ b = _ == null ? 1 : _;
632
+ return dist;
633
+ } else {
634
+ return b;
635
+ }
636
+ },
637
+ sample: () => sampleUniform(a, b),
638
+ pdf: value => densityUniform(value, a, b),
639
+ cdf: value => cumulativeUniform(value, a, b),
640
+ icdf: p => quantileUniform(p, a, b)
641
+ };
642
+ if (max == null) {
643
+ max = min == null ? 1 : min;
644
+ min = 0;
645
+ }
646
+ return dist.min(min).max(max);
647
+ }
648
+
649
+ function constant (data, x, y) {
650
+ let mean = 0,
651
+ n = 0;
652
+ for (const d of data) {
653
+ const val = y(d);
654
+ if (x(d) == null || val == null || isNaN(val)) continue;
655
+ mean += (val - mean) / ++n;
656
+ }
657
+ return {
658
+ coef: [mean],
659
+ predict: () => mean,
660
+ rSquared: 0
661
+ };
662
+ }
663
+
664
+ // Ordinary Least Squares
665
+ function ols (uX, uY, uXY, uX2) {
666
+ const delta = uX2 - uX * uX,
667
+ slope = Math.abs(delta) < 1e-24 ? 0 : (uXY - uX * uY) / delta,
668
+ intercept = uY - slope * uX;
669
+ return [intercept, slope];
670
+ }
671
+
672
+ function points(data, x, y, sort) {
673
+ data = data.filter(d => {
674
+ let u = x(d),
675
+ v = y(d);
676
+ return u != null && (u = +u) >= u && v != null && (v = +v) >= v;
677
+ });
678
+ if (sort) {
679
+ data.sort((a, b) => x(a) - x(b));
680
+ }
681
+ const n = data.length,
682
+ X = new Float64Array(n),
683
+ Y = new Float64Array(n);
684
+
685
+ // extract values, calculate means
686
+ let i = 0,
687
+ ux = 0,
688
+ uy = 0,
689
+ xv,
690
+ yv,
691
+ d;
692
+ for (d of data) {
693
+ X[i] = xv = +x(d);
694
+ Y[i] = yv = +y(d);
695
+ ++i;
696
+ ux += (xv - ux) / i;
697
+ uy += (yv - uy) / i;
698
+ }
699
+
700
+ // mean center the data
701
+ for (i = 0; i < n; ++i) {
702
+ X[i] -= ux;
703
+ Y[i] -= uy;
704
+ }
705
+ return [X, Y, ux, uy];
706
+ }
707
+ function visitPoints(data, x, y, callback) {
708
+ let i = -1,
709
+ u,
710
+ v;
711
+ for (const d of data) {
712
+ u = x(d);
713
+ v = y(d);
714
+ if (u != null && (u = +u) >= u && v != null && (v = +v) >= v) {
715
+ callback(u, v, ++i);
716
+ }
717
+ }
718
+ }
719
+
720
+ // Adapted from d3-regression by Harry Stevens
721
+ // License: https://github.com/HarryStevens/d3-regression/blob/master/LICENSE
722
+ function rSquared (data, x, y, uY, predict) {
723
+ let SSE = 0,
724
+ SST = 0;
725
+ visitPoints(data, x, y, (dx, dy) => {
726
+ const sse = dy - predict(dx),
727
+ sst = dy - uY;
728
+ SSE += sse * sse;
729
+ SST += sst * sst;
730
+ });
731
+ return 1 - SSE / SST;
732
+ }
733
+
734
+ // Adapted from d3-regression by Harry Stevens
735
+ // License: https://github.com/HarryStevens/d3-regression/blob/master/LICENSE
736
+ function linear (data, x, y) {
737
+ let X = 0,
738
+ Y = 0,
739
+ XY = 0,
740
+ X2 = 0,
741
+ n = 0;
742
+ visitPoints(data, x, y, (dx, dy) => {
743
+ ++n;
744
+ X += (dx - X) / n;
745
+ Y += (dy - Y) / n;
746
+ XY += (dx * dy - XY) / n;
747
+ X2 += (dx * dx - X2) / n;
748
+ });
749
+ const coef = ols(X, Y, XY, X2),
750
+ predict = x => coef[0] + coef[1] * x;
751
+ return {
752
+ coef: coef,
753
+ predict: predict,
754
+ rSquared: rSquared(data, x, y, Y, predict)
755
+ };
756
+ }
757
+
758
+ // Adapted from d3-regression by Harry Stevens
759
+ // License: https://github.com/HarryStevens/d3-regression/blob/master/LICENSE
760
+ function log (data, x, y) {
761
+ let X = 0,
762
+ Y = 0,
763
+ XY = 0,
764
+ X2 = 0,
765
+ n = 0;
766
+ visitPoints(data, x, y, (dx, dy) => {
767
+ ++n;
768
+ dx = Math.log(dx);
769
+ X += (dx - X) / n;
770
+ Y += (dy - Y) / n;
771
+ XY += (dx * dy - XY) / n;
772
+ X2 += (dx * dx - X2) / n;
773
+ });
774
+ const coef = ols(X, Y, XY, X2),
775
+ predict = x => coef[0] + coef[1] * Math.log(x);
776
+ return {
777
+ coef: coef,
778
+ predict: predict,
779
+ rSquared: rSquared(data, x, y, Y, predict)
780
+ };
781
+ }
782
+
783
+ function exp (data, x, y) {
784
+ const [xv, yv, ux, uy] = points(data, x, y);
785
+ let YL = 0,
786
+ XY = 0,
787
+ XYL = 0,
788
+ X2Y = 0,
789
+ n = 0,
790
+ dx,
791
+ ly,
792
+ xy;
793
+ visitPoints(data, x, y, (_, dy) => {
794
+ dx = xv[n++];
795
+ ly = Math.log(dy);
796
+ xy = dx * dy;
797
+ YL += (dy * ly - YL) / n;
798
+ XY += (xy - XY) / n;
799
+ XYL += (xy * ly - XYL) / n;
800
+ X2Y += (dx * xy - X2Y) / n;
801
+ });
802
+ const [c0, c1] = ols(XY / uy, YL / uy, XYL / uy, X2Y / uy),
803
+ predict = x => Math.exp(c0 + c1 * (x - ux));
804
+ return {
805
+ coef: [Math.exp(c0 - c1 * ux), c1],
806
+ predict: predict,
807
+ rSquared: rSquared(data, x, y, uy, predict)
808
+ };
809
+ }
810
+
811
+ // Adapted from d3-regression by Harry Stevens
812
+ // License: https://github.com/HarryStevens/d3-regression/blob/master/LICENSE
813
+ function pow (data, x, y) {
814
+ let X = 0,
815
+ Y = 0,
816
+ XY = 0,
817
+ X2 = 0,
818
+ YS = 0,
819
+ n = 0;
820
+ visitPoints(data, x, y, (dx, dy) => {
821
+ const lx = Math.log(dx),
822
+ ly = Math.log(dy);
823
+ ++n;
824
+ X += (lx - X) / n;
825
+ Y += (ly - Y) / n;
826
+ XY += (lx * ly - XY) / n;
827
+ X2 += (lx * lx - X2) / n;
828
+ YS += (dy - YS) / n;
829
+ });
830
+ const coef = ols(X, Y, XY, X2),
831
+ predict = x => coef[0] * Math.pow(x, coef[1]);
832
+ coef[0] = Math.exp(coef[0]);
833
+ return {
834
+ coef: coef,
835
+ predict: predict,
836
+ rSquared: rSquared(data, x, y, YS, predict)
837
+ };
838
+ }
839
+
840
+ function quad (data, x, y) {
841
+ const [xv, yv, ux, uy] = points(data, x, y),
842
+ n = xv.length;
843
+ let X2 = 0,
844
+ X3 = 0,
845
+ X4 = 0,
846
+ XY = 0,
847
+ X2Y = 0,
848
+ i,
849
+ dx,
850
+ dy,
851
+ x2;
852
+ for (i = 0; i < n;) {
853
+ dx = xv[i];
854
+ dy = yv[i++];
855
+ x2 = dx * dx;
856
+ X2 += (x2 - X2) / i;
857
+ X3 += (x2 * dx - X3) / i;
858
+ X4 += (x2 * x2 - X4) / i;
859
+ XY += (dx * dy - XY) / i;
860
+ X2Y += (x2 * dy - X2Y) / i;
861
+ }
862
+ const X2X2 = X4 - X2 * X2,
863
+ d = X2 * X2X2 - X3 * X3,
864
+ a = (X2Y * X2 - XY * X3) / d,
865
+ b = (XY * X2X2 - X2Y * X3) / d,
866
+ c = -a * X2,
867
+ predict = x => {
868
+ x = x - ux;
869
+ return a * x * x + b * x + c + uy;
870
+ };
871
+
872
+ // transform coefficients back from mean-centered space
873
+ return {
874
+ coef: [c - b * ux + a * ux * ux + uy, b - 2 * a * ux, a],
875
+ predict: predict,
876
+ rSquared: rSquared(data, x, y, uy, predict)
877
+ };
878
+ }
879
+
880
+ // Adapted from d3-regression by Harry Stevens
881
+ // License: https://github.com/HarryStevens/d3-regression/blob/master/LICENSE
882
+ // ... which was adapted from regression-js by Tom Alexander
883
+ // Source: https://github.com/Tom-Alexander/regression-js/blob/master/src/regression.js#L246
884
+ // License: https://github.com/Tom-Alexander/regression-js/blob/master/LICENSE
885
+ function poly (data, x, y, order) {
886
+ // use more efficient methods for lower orders
887
+ if (order === 0) return constant(data, x, y);
888
+ if (order === 1) return linear(data, x, y);
889
+ if (order === 2) return quad(data, x, y);
890
+ const [xv, yv, ux, uy] = points(data, x, y),
891
+ n = xv.length,
892
+ lhs = [],
893
+ rhs = [],
894
+ k = order + 1;
895
+ let i, j, l, v, c;
896
+ for (i = 0; i < k; ++i) {
897
+ for (l = 0, v = 0; l < n; ++l) {
898
+ v += Math.pow(xv[l], i) * yv[l];
899
+ }
900
+ lhs.push(v);
901
+ c = new Float64Array(k);
902
+ for (j = 0; j < k; ++j) {
903
+ for (l = 0, v = 0; l < n; ++l) {
904
+ v += Math.pow(xv[l], i + j);
905
+ }
906
+ c[j] = v;
907
+ }
908
+ rhs.push(c);
909
+ }
910
+ rhs.push(lhs);
911
+ const coef = gaussianElimination(rhs),
912
+ predict = x => {
913
+ x -= ux;
914
+ let y = uy + coef[0] + coef[1] * x + coef[2] * x * x;
915
+ for (i = 3; i < k; ++i) y += coef[i] * Math.pow(x, i);
916
+ return y;
917
+ };
918
+ return {
919
+ coef: uncenter(k, coef, -ux, uy),
920
+ predict: predict,
921
+ rSquared: rSquared(data, x, y, uy, predict)
922
+ };
923
+ }
924
+ function uncenter(k, a, x, y) {
925
+ const z = Array(k);
926
+ let i, j, v, c;
927
+
928
+ // initialize to zero
929
+ for (i = 0; i < k; ++i) z[i] = 0;
930
+
931
+ // polynomial expansion
932
+ for (i = k - 1; i >= 0; --i) {
933
+ v = a[i];
934
+ c = 1;
935
+ z[i] += v;
936
+ for (j = 1; j <= i; ++j) {
937
+ c *= (i + 1 - j) / j; // binomial coefficent
938
+ z[i - j] += v * Math.pow(x, j) * c;
939
+ }
940
+ }
941
+
942
+ // bias term
943
+ z[0] += y;
944
+ return z;
945
+ }
946
+
947
+ // Given an array for a two-dimensional matrix and the polynomial order,
948
+ // solve A * x = b using Gaussian elimination.
949
+ function gaussianElimination(matrix) {
950
+ const n = matrix.length - 1,
951
+ coef = [];
952
+ let i, j, k, r, t;
953
+ for (i = 0; i < n; ++i) {
954
+ r = i; // max row
955
+ for (j = i + 1; j < n; ++j) {
956
+ if (Math.abs(matrix[i][j]) > Math.abs(matrix[i][r])) {
957
+ r = j;
958
+ }
959
+ }
960
+ for (k = i; k < n + 1; ++k) {
961
+ t = matrix[k][i];
962
+ matrix[k][i] = matrix[k][r];
963
+ matrix[k][r] = t;
964
+ }
965
+ for (j = i + 1; j < n; ++j) {
966
+ for (k = n; k >= i; k--) {
967
+ matrix[k][j] -= matrix[k][i] * matrix[i][j] / matrix[i][i];
968
+ }
969
+ }
970
+ }
971
+ for (j = n - 1; j >= 0; --j) {
972
+ t = 0;
973
+ for (k = j + 1; k < n; ++k) {
974
+ t += matrix[k][j] * coef[k];
975
+ }
976
+ coef[j] = (matrix[n][j] - t) / matrix[j][j];
977
+ }
978
+ return coef;
979
+ }
980
+
981
+ const maxiters = 2,
982
+ epsilon = 1e-12;
983
+
984
+ // Adapted from science.js by Jason Davies
985
+ // Source: https://github.com/jasondavies/science.js/blob/master/src/stats/loess.js
986
+ // License: https://github.com/jasondavies/science.js/blob/master/LICENSE
987
+ function loess (data, x, y, bandwidth) {
988
+ const [xv, yv, ux, uy] = points(data, x, y, true),
989
+ n = xv.length,
990
+ bw = Math.max(2, ~~(bandwidth * n)),
991
+ // # nearest neighbors
992
+ yhat = new Float64Array(n),
993
+ residuals = new Float64Array(n),
994
+ robustWeights = new Float64Array(n).fill(1);
995
+ for (let iter = -1; ++iter <= maxiters;) {
996
+ const interval = [0, bw - 1];
997
+ for (let i = 0; i < n; ++i) {
998
+ const dx = xv[i],
999
+ i0 = interval[0],
1000
+ i1 = interval[1],
1001
+ edge = dx - xv[i0] > xv[i1] - dx ? i0 : i1;
1002
+ let W = 0,
1003
+ X = 0,
1004
+ Y = 0,
1005
+ XY = 0,
1006
+ X2 = 0;
1007
+ const denom = 1 / Math.abs(xv[edge] - dx || 1); // avoid singularity!
1008
+
1009
+ for (let k = i0; k <= i1; ++k) {
1010
+ const xk = xv[k],
1011
+ yk = yv[k],
1012
+ w = tricube(Math.abs(dx - xk) * denom) * robustWeights[k],
1013
+ xkw = xk * w;
1014
+ W += w;
1015
+ X += xkw;
1016
+ Y += yk * w;
1017
+ XY += yk * xkw;
1018
+ X2 += xk * xkw;
1019
+ }
1020
+
1021
+ // linear regression fit
1022
+ const [a, b] = ols(X / W, Y / W, XY / W, X2 / W);
1023
+ yhat[i] = a + b * dx;
1024
+ residuals[i] = Math.abs(yv[i] - yhat[i]);
1025
+ updateInterval(xv, i + 1, interval);
1026
+ }
1027
+ if (iter === maxiters) {
1028
+ break;
1029
+ }
1030
+ const medianResidual = median.default(residuals);
1031
+ if (Math.abs(medianResidual) < epsilon) break;
1032
+ for (let i = 0, arg, w; i < n; ++i) {
1033
+ arg = residuals[i] / (6 * medianResidual);
1034
+ // default to epsilon (rather than zero) for large deviations
1035
+ // keeping weights tiny but non-zero prevents singularites
1036
+ robustWeights[i] = arg >= 1 ? epsilon : (w = 1 - arg * arg) * w;
1037
+ }
1038
+ }
1039
+ return output(xv, yhat, ux, uy);
1040
+ }
1041
+
1042
+ // weighting kernel for local regression
1043
+ function tricube(x) {
1044
+ return (x = 1 - x * x * x) * x * x;
1045
+ }
1046
+
1047
+ // advance sliding window interval of nearest neighbors
1048
+ function updateInterval(xv, i, interval) {
1049
+ const val = xv[i];
1050
+ let left = interval[0],
1051
+ right = interval[1] + 1;
1052
+ if (right >= xv.length) return;
1053
+
1054
+ // step right if distance to new right edge is <= distance to old left edge
1055
+ // step when distance is equal to ensure movement over duplicate x values
1056
+ while (i > left && xv[right] - val <= val - xv[left]) {
1057
+ interval[0] = ++left;
1058
+ interval[1] = right;
1059
+ ++right;
1060
+ }
1061
+ }
1062
+
1063
+ // generate smoothed output points
1064
+ // average points with repeated x values
1065
+ function output(xv, yhat, ux, uy) {
1066
+ const n = xv.length,
1067
+ out = [];
1068
+ let i = 0,
1069
+ cnt = 0,
1070
+ prev = [],
1071
+ v;
1072
+ for (; i < n; ++i) {
1073
+ v = xv[i] + ux;
1074
+ if (prev[0] === v) {
1075
+ // average output values via online update
1076
+ prev[1] += (yhat[i] - prev[1]) / ++cnt;
1077
+ } else {
1078
+ // add new output point
1079
+ cnt = 0;
1080
+ prev[1] += uy;
1081
+ prev = [v, yhat[i]];
1082
+ out.push(prev);
1083
+ }
1084
+ }
1085
+ prev[1] += uy;
1086
+ return out;
1087
+ }
1088
+
1089
+ // subdivide up to accuracy of 0.5 degrees
1090
+ const MIN_RADIANS = 0.5 * Math.PI / 180;
1091
+
1092
+ // Adaptively sample an interpolated function over a domain extent
1093
+ function sampleCurve (f, extent, minSteps, maxSteps) {
1094
+ minSteps = minSteps || 25;
1095
+ maxSteps = Math.max(minSteps, maxSteps || 200);
1096
+ const point = x => [x, f(x)],
1097
+ minX = extent[0],
1098
+ maxX = extent[1],
1099
+ span = maxX - minX,
1100
+ stop = span / maxSteps,
1101
+ prev = [point(minX)],
1102
+ next = [];
1103
+ if (minSteps === maxSteps) {
1104
+ // no adaptation, sample uniform grid directly and return
1105
+ for (let i = 1; i < maxSteps; ++i) {
1106
+ prev.push(point(minX + i / minSteps * span));
1107
+ }
1108
+ prev.push(point(maxX));
1109
+ return prev;
1110
+ } else {
1111
+ // sample minimum points on uniform grid
1112
+ // then move on to perform adaptive refinement
1113
+ next.push(point(maxX));
1114
+ for (let i = minSteps; --i > 0;) {
1115
+ next.push(point(minX + i / minSteps * span));
1116
+ }
1117
+ }
1118
+ let p0 = prev[0];
1119
+ let p1 = next[next.length - 1];
1120
+ const sx = 1 / span;
1121
+ const sy = scaleY(p0[1], next);
1122
+ while (p1) {
1123
+ // midpoint for potential curve subdivision
1124
+ const pm = point((p0[0] + p1[0]) / 2);
1125
+ const dx = pm[0] - p0[0] >= stop;
1126
+ if (dx && angleDelta(p0, pm, p1, sx, sy) > MIN_RADIANS) {
1127
+ // maximum resolution has not yet been met, and
1128
+ // subdivision midpoint is sufficiently different from endpoint
1129
+ // save subdivision, push midpoint onto the visitation stack
1130
+ next.push(pm);
1131
+ } else {
1132
+ // subdivision midpoint sufficiently similar to endpoint
1133
+ // skip subdivision, store endpoint, move to next point on the stack
1134
+ p0 = p1;
1135
+ prev.push(p1);
1136
+ next.pop();
1137
+ }
1138
+ p1 = next[next.length - 1];
1139
+ }
1140
+ return prev;
1141
+ }
1142
+ function scaleY(init, points) {
1143
+ let ymin = init;
1144
+ let ymax = init;
1145
+ const n = points.length;
1146
+ for (let i = 0; i < n; ++i) {
1147
+ const y = points[i][1];
1148
+ if (y < ymin) ymin = y;
1149
+ if (y > ymax) ymax = y;
1150
+ }
1151
+ return 1 / (ymax - ymin);
1152
+ }
1153
+ function angleDelta(p, q, r, sx, sy) {
1154
+ const a0 = Math.atan2(sy * (r[1] - p[1]), sx * (r[0] - p[0])),
1155
+ a1 = Math.atan2(sy * (q[1] - p[1]), sx * (q[0] - p[0]));
1156
+ return Math.abs(a0 - a1);
1157
+ }
1158
+
1159
+ exports.bandwidthNRD = estimateBandwidth;
1160
+ exports.bin = bin;
1161
+ exports.bootstrapCI = bootstrapCI;
1162
+ exports.cumulativeLogNormal = cumulativeLogNormal;
1163
+ exports.cumulativeNormal = cumulativeNormal;
1164
+ exports.cumulativeUniform = cumulativeUniform;
1165
+ exports.densityLogNormal = densityLogNormal;
1166
+ exports.densityNormal = densityNormal;
1167
+ exports.densityUniform = densityUniform;
1168
+ exports.dotbin = dotbin;
1169
+ exports.quantileLogNormal = quantileLogNormal;
1170
+ exports.quantileNormal = quantileNormal;
1171
+ exports.quantileUniform = quantileUniform;
1172
+ exports.quantiles = quantiles;
1173
+ exports.quartiles = quartiles;
1174
+ exports.randomInteger = integer;
1175
+ exports.randomKDE = kde;
1176
+ exports.randomLCG = lcg;
1177
+ exports.randomLogNormal = lognormal;
1178
+ exports.randomMixture = mixture;
1179
+ exports.randomNormal = gaussian;
1180
+ exports.randomUniform = uniform;
1181
+ exports.regressionConstant = constant;
1182
+ exports.regressionExp = exp;
1183
+ exports.regressionLinear = linear;
1184
+ exports.regressionLoess = loess;
1185
+ exports.regressionLog = log;
1186
+ exports.regressionPoly = poly;
1187
+ exports.regressionPow = pow;
1188
+ exports.regressionQuad = quad;
1189
+ exports.sampleCurve = sampleCurve;
1190
+ exports.sampleLogNormal = sampleLogNormal;
1191
+ exports.sampleNormal = sampleNormal;
1192
+ exports.sampleUniform = sampleUniform;
1193
+ exports.setRandom = setRandom;