@hpcc-js/dataflow 9.2.0 → 9.2.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.
Files changed (349) hide show
  1. package/LICENSE +43 -43
  2. package/README.md +530 -530
  3. package/dist/index.js +557 -1
  4. package/dist/index.js.map +1 -7
  5. package/dist/index.min.js +2 -0
  6. package/dist/index.min.js.map +1 -0
  7. package/lib-es6/__package__.js +4 -0
  8. package/lib-es6/__package__.js.map +1 -0
  9. package/lib-es6/__tests__/chain.js +49 -0
  10. package/lib-es6/__tests__/chain.js.map +1 -0
  11. package/lib-es6/__tests__/concat.js +17 -0
  12. package/lib-es6/__tests__/concat.js.map +1 -0
  13. package/lib-es6/__tests__/count.js +19 -0
  14. package/lib-es6/__tests__/count.js.map +1 -0
  15. package/lib-es6/__tests__/data.js +56 -0
  16. package/lib-es6/__tests__/data.js.map +1 -0
  17. package/lib-es6/__tests__/deviation.js +13 -0
  18. package/lib-es6/__tests__/deviation.js.map +1 -0
  19. package/lib-es6/__tests__/distribution.js +19 -0
  20. package/lib-es6/__tests__/distribution.js.map +1 -0
  21. package/lib-es6/__tests__/each.js +12 -0
  22. package/lib-es6/__tests__/each.js.map +1 -0
  23. package/lib-es6/__tests__/entries.js +13 -0
  24. package/lib-es6/__tests__/entries.js.map +1 -0
  25. package/lib-es6/__tests__/extent.js +19 -0
  26. package/lib-es6/__tests__/extent.js.map +1 -0
  27. package/lib-es6/__tests__/filter.js +14 -0
  28. package/lib-es6/__tests__/filter.js.map +1 -0
  29. package/lib-es6/__tests__/first.js +14 -0
  30. package/lib-es6/__tests__/first.js.map +1 -0
  31. package/lib-es6/__tests__/generate.js +8 -0
  32. package/lib-es6/__tests__/generate.js.map +1 -0
  33. package/lib-es6/__tests__/group.js +18 -0
  34. package/lib-es6/__tests__/group.js.map +1 -0
  35. package/lib-es6/__tests__/histogram.js +42 -0
  36. package/lib-es6/__tests__/histogram.js.map +1 -0
  37. package/lib-es6/__tests__/index.js +28 -0
  38. package/lib-es6/__tests__/index.js.map +1 -0
  39. package/lib-es6/__tests__/join.js +16 -0
  40. package/lib-es6/__tests__/join.js.map +1 -0
  41. package/lib-es6/__tests__/map.js +14 -0
  42. package/lib-es6/__tests__/map.js.map +1 -0
  43. package/lib-es6/__tests__/max.js +30 -0
  44. package/lib-es6/__tests__/max.js.map +1 -0
  45. package/lib-es6/__tests__/mean.js +10 -0
  46. package/lib-es6/__tests__/mean.js.map +1 -0
  47. package/lib-es6/__tests__/median.js +13 -0
  48. package/lib-es6/__tests__/median.js.map +1 -0
  49. package/lib-es6/__tests__/min.js +30 -0
  50. package/lib-es6/__tests__/min.js.map +1 -0
  51. package/lib-es6/__tests__/normalize.js +12 -0
  52. package/lib-es6/__tests__/normalize.js.map +1 -0
  53. package/lib-es6/__tests__/quartile.js +12 -0
  54. package/lib-es6/__tests__/quartile.js.map +1 -0
  55. package/lib-es6/__tests__/readme.js +96 -0
  56. package/lib-es6/__tests__/readme.js.map +1 -0
  57. package/lib-es6/__tests__/reduce.js +15 -0
  58. package/lib-es6/__tests__/reduce.js.map +1 -0
  59. package/lib-es6/__tests__/skip.js +14 -0
  60. package/lib-es6/__tests__/skip.js.map +1 -0
  61. package/lib-es6/__tests__/sort.js +19 -0
  62. package/lib-es6/__tests__/sort.js.map +1 -0
  63. package/lib-es6/__tests__/variance.js +13 -0
  64. package/lib-es6/__tests__/variance.js.map +1 -0
  65. package/lib-es6/activities/activity.js +4 -0
  66. package/lib-es6/activities/activity.js.map +1 -0
  67. package/lib-es6/activities/concat.js +10 -0
  68. package/lib-es6/activities/concat.js.map +1 -0
  69. package/lib-es6/activities/each.js +14 -0
  70. package/lib-es6/activities/each.js.map +1 -0
  71. package/lib-es6/activities/entries.js +13 -0
  72. package/lib-es6/activities/entries.js.map +1 -0
  73. package/lib-es6/activities/filter.js +15 -0
  74. package/lib-es6/activities/filter.js.map +1 -0
  75. package/lib-es6/activities/first.js +18 -0
  76. package/lib-es6/activities/first.js.map +1 -0
  77. package/lib-es6/activities/group.js +21 -0
  78. package/lib-es6/activities/group.js.map +1 -0
  79. package/lib-es6/activities/histogram.js +64 -0
  80. package/lib-es6/activities/histogram.js.map +1 -0
  81. package/lib-es6/activities/join.js +14 -0
  82. package/lib-es6/activities/join.js.map +1 -0
  83. package/lib-es6/activities/map.js +13 -0
  84. package/lib-es6/activities/map.js.map +1 -0
  85. package/lib-es6/activities/normalize.js +18 -0
  86. package/lib-es6/activities/normalize.js.map +1 -0
  87. package/lib-es6/activities/skip.js +15 -0
  88. package/lib-es6/activities/skip.js.map +1 -0
  89. package/lib-es6/activities/sort.js +10 -0
  90. package/lib-es6/activities/sort.js.map +1 -0
  91. package/lib-es6/index.js +28 -0
  92. package/lib-es6/index.js.map +1 -0
  93. package/lib-es6/observers/count.js +13 -0
  94. package/lib-es6/observers/count.js.map +1 -0
  95. package/lib-es6/observers/deviation.js +18 -0
  96. package/lib-es6/observers/deviation.js.map +1 -0
  97. package/lib-es6/observers/distribution.js +36 -0
  98. package/lib-es6/observers/distribution.js.map +1 -0
  99. package/lib-es6/observers/extent.js +18 -0
  100. package/lib-es6/observers/extent.js.map +1 -0
  101. package/lib-es6/observers/max.js +19 -0
  102. package/lib-es6/observers/max.js.map +1 -0
  103. package/lib-es6/observers/mean.js +21 -0
  104. package/lib-es6/observers/mean.js.map +1 -0
  105. package/lib-es6/observers/median.js +26 -0
  106. package/lib-es6/observers/median.js.map +1 -0
  107. package/lib-es6/observers/min.js +19 -0
  108. package/lib-es6/observers/min.js.map +1 -0
  109. package/lib-es6/observers/observer.js +35 -0
  110. package/lib-es6/observers/observer.js.map +1 -0
  111. package/lib-es6/observers/quartile.js +38 -0
  112. package/lib-es6/observers/quartile.js.map +1 -0
  113. package/lib-es6/observers/reduce.js +18 -0
  114. package/lib-es6/observers/reduce.js.map +1 -0
  115. package/lib-es6/observers/variance.js +23 -0
  116. package/lib-es6/observers/variance.js.map +1 -0
  117. package/lib-es6/utils/generate.js +7 -0
  118. package/lib-es6/utils/generate.js.map +1 -0
  119. package/lib-es6/utils/pipe.js +32 -0
  120. package/lib-es6/utils/pipe.js.map +1 -0
  121. package/package.json +37 -28
  122. package/src/__package__.ts +3 -3
  123. package/src/__tests__/chain.ts +85 -0
  124. package/src/__tests__/concat.ts +18 -0
  125. package/src/__tests__/count.ts +25 -0
  126. package/src/__tests__/data.ts +64 -0
  127. package/src/__tests__/deviation.ts +14 -0
  128. package/src/__tests__/distribution.ts +21 -0
  129. package/src/__tests__/each.ts +13 -0
  130. package/src/__tests__/entries.ts +14 -0
  131. package/src/__tests__/extent.ts +25 -0
  132. package/src/__tests__/filter.ts +16 -0
  133. package/src/__tests__/first.ts +15 -0
  134. package/src/__tests__/generate.ts +9 -0
  135. package/src/__tests__/group.ts +19 -0
  136. package/src/__tests__/histogram.ts +47 -0
  137. package/src/__tests__/index.ts +27 -0
  138. package/src/__tests__/join.ts +20 -0
  139. package/src/__tests__/map.ts +16 -0
  140. package/src/__tests__/max.ts +42 -0
  141. package/src/__tests__/mean.ts +11 -0
  142. package/src/__tests__/median.ts +14 -0
  143. package/src/__tests__/min.ts +42 -0
  144. package/src/__tests__/normalize.ts +14 -0
  145. package/src/__tests__/quartile.ts +14 -0
  146. package/src/__tests__/readme.ts +113 -0
  147. package/src/__tests__/reduce.ts +17 -0
  148. package/src/__tests__/skip.ts +15 -0
  149. package/src/__tests__/sort.ts +21 -0
  150. package/src/__tests__/variance.ts +14 -0
  151. package/src/activities/activity.ts +8 -8
  152. package/src/activities/concat.ts +14 -14
  153. package/src/activities/each.ts +19 -19
  154. package/src/activities/entries.ts +17 -17
  155. package/src/activities/filter.ts +20 -20
  156. package/src/activities/first.ts +20 -20
  157. package/src/activities/group.ts +27 -27
  158. package/src/activities/histogram.ts +78 -78
  159. package/src/activities/join.ts +19 -19
  160. package/src/activities/map.ts +18 -18
  161. package/src/activities/normalize.ts +21 -21
  162. package/src/activities/skip.ts +18 -18
  163. package/src/activities/sort.ts +16 -16
  164. package/src/index.ts +27 -27
  165. package/src/observers/count.ts +15 -15
  166. package/src/observers/deviation.ts +24 -24
  167. package/src/observers/distribution.ts +51 -51
  168. package/src/observers/extent.ts +24 -24
  169. package/src/observers/max.ts +24 -24
  170. package/src/observers/mean.ts +26 -26
  171. package/src/observers/median.ts +30 -30
  172. package/src/observers/min.ts +24 -24
  173. package/src/observers/observer.ts +52 -52
  174. package/src/observers/quartile.ts +43 -43
  175. package/src/observers/reduce.ts +22 -22
  176. package/src/observers/variance.ts +29 -29
  177. package/src/utils/generate.ts +6 -6
  178. package/src/utils/pipe.ts +74 -74
  179. package/types/__package__.d.ts +4 -0
  180. package/types/__package__.d.ts.map +1 -0
  181. package/types/__tests__/chain.d.ts +2 -0
  182. package/types/__tests__/chain.d.ts.map +1 -0
  183. package/types/__tests__/concat.d.ts +2 -0
  184. package/types/__tests__/concat.d.ts.map +1 -0
  185. package/types/__tests__/count.d.ts +2 -0
  186. package/types/__tests__/count.d.ts.map +1 -0
  187. package/types/__tests__/data.d.ts +62 -0
  188. package/types/__tests__/data.d.ts.map +1 -0
  189. package/types/__tests__/deviation.d.ts +2 -0
  190. package/types/__tests__/deviation.d.ts.map +1 -0
  191. package/types/__tests__/distribution.d.ts +2 -0
  192. package/types/__tests__/distribution.d.ts.map +1 -0
  193. package/types/__tests__/each.d.ts +2 -0
  194. package/types/__tests__/each.d.ts.map +1 -0
  195. package/types/__tests__/entries.d.ts +2 -0
  196. package/types/__tests__/entries.d.ts.map +1 -0
  197. package/types/__tests__/extent.d.ts +2 -0
  198. package/types/__tests__/extent.d.ts.map +1 -0
  199. package/types/__tests__/filter.d.ts +2 -0
  200. package/types/__tests__/filter.d.ts.map +1 -0
  201. package/types/__tests__/first.d.ts +2 -0
  202. package/types/__tests__/first.d.ts.map +1 -0
  203. package/types/__tests__/generate.d.ts +2 -0
  204. package/types/__tests__/generate.d.ts.map +1 -0
  205. package/types/__tests__/group.d.ts +2 -0
  206. package/types/__tests__/group.d.ts.map +1 -0
  207. package/types/__tests__/histogram.d.ts +2 -0
  208. package/types/__tests__/histogram.d.ts.map +1 -0
  209. package/types/__tests__/index.d.ts +28 -0
  210. package/types/__tests__/index.d.ts.map +1 -0
  211. package/types/__tests__/join.d.ts +2 -0
  212. package/types/__tests__/join.d.ts.map +1 -0
  213. package/types/__tests__/map.d.ts +2 -0
  214. package/types/__tests__/map.d.ts.map +1 -0
  215. package/types/__tests__/max.d.ts +2 -0
  216. package/types/__tests__/max.d.ts.map +1 -0
  217. package/types/__tests__/mean.d.ts +2 -0
  218. package/types/__tests__/mean.d.ts.map +1 -0
  219. package/types/__tests__/median.d.ts +2 -0
  220. package/types/__tests__/median.d.ts.map +1 -0
  221. package/types/__tests__/min.d.ts +2 -0
  222. package/types/__tests__/min.d.ts.map +1 -0
  223. package/types/__tests__/normalize.d.ts +2 -0
  224. package/types/__tests__/normalize.d.ts.map +1 -0
  225. package/types/__tests__/quartile.d.ts +2 -0
  226. package/types/__tests__/quartile.d.ts.map +1 -0
  227. package/types/__tests__/readme.d.ts +2 -0
  228. package/types/__tests__/readme.d.ts.map +1 -0
  229. package/types/__tests__/reduce.d.ts +2 -0
  230. package/types/__tests__/reduce.d.ts.map +1 -0
  231. package/types/__tests__/skip.d.ts +2 -0
  232. package/types/__tests__/skip.d.ts.map +1 -0
  233. package/types/__tests__/sort.d.ts +2 -0
  234. package/types/__tests__/sort.d.ts.map +1 -0
  235. package/types/__tests__/variance.d.ts +2 -0
  236. package/types/__tests__/variance.d.ts.map +1 -0
  237. package/types/activities/activity.d.ts +1 -0
  238. package/types/activities/activity.d.ts.map +1 -0
  239. package/types/activities/concat.d.ts +2 -1
  240. package/types/activities/concat.d.ts.map +1 -0
  241. package/types/activities/each.d.ts +2 -1
  242. package/types/activities/each.d.ts.map +1 -0
  243. package/types/activities/entries.d.ts +2 -1
  244. package/types/activities/entries.d.ts.map +1 -0
  245. package/types/activities/filter.d.ts +2 -1
  246. package/types/activities/filter.d.ts.map +1 -0
  247. package/types/activities/first.d.ts +2 -1
  248. package/types/activities/first.d.ts.map +1 -0
  249. package/types/activities/group.d.ts +2 -1
  250. package/types/activities/group.d.ts.map +1 -0
  251. package/types/activities/histogram.d.ts +2 -1
  252. package/types/activities/histogram.d.ts.map +1 -0
  253. package/types/activities/join.d.ts +2 -1
  254. package/types/activities/join.d.ts.map +1 -0
  255. package/types/activities/map.d.ts +2 -1
  256. package/types/activities/map.d.ts.map +1 -0
  257. package/types/activities/normalize.d.ts +2 -1
  258. package/types/activities/normalize.d.ts.map +1 -0
  259. package/types/activities/skip.d.ts +2 -1
  260. package/types/activities/skip.d.ts.map +1 -0
  261. package/types/activities/sort.d.ts +2 -1
  262. package/types/activities/sort.d.ts.map +1 -0
  263. package/types/index.d.ts +28 -27
  264. package/types/index.d.ts.map +1 -0
  265. package/types/observers/count.d.ts +2 -1
  266. package/types/observers/count.d.ts.map +1 -0
  267. package/types/observers/deviation.d.ts +2 -1
  268. package/types/observers/deviation.d.ts.map +1 -0
  269. package/types/observers/distribution.d.ts +2 -1
  270. package/types/observers/distribution.d.ts.map +1 -0
  271. package/types/observers/extent.d.ts +2 -1
  272. package/types/observers/extent.d.ts.map +1 -0
  273. package/types/observers/max.d.ts +2 -1
  274. package/types/observers/max.d.ts.map +1 -0
  275. package/types/observers/mean.d.ts +2 -1
  276. package/types/observers/mean.d.ts.map +1 -0
  277. package/types/observers/median.d.ts +2 -1
  278. package/types/observers/median.d.ts.map +1 -0
  279. package/types/observers/min.d.ts +2 -1
  280. package/types/observers/min.d.ts.map +1 -0
  281. package/types/observers/observer.d.ts +3 -2
  282. package/types/observers/observer.d.ts.map +1 -0
  283. package/types/observers/quartile.d.ts +2 -1
  284. package/types/observers/quartile.d.ts.map +1 -0
  285. package/types/observers/reduce.d.ts +2 -1
  286. package/types/observers/reduce.d.ts.map +1 -0
  287. package/types/observers/variance.d.ts +2 -1
  288. package/types/observers/variance.d.ts.map +1 -0
  289. package/types/utils/generate.d.ts +1 -0
  290. package/types/utils/generate.d.ts.map +1 -0
  291. package/types/utils/pipe.d.ts +2 -1
  292. package/types/utils/pipe.d.ts.map +1 -0
  293. package/types-3.4/__package__.d.ts +4 -0
  294. package/types-3.4/__tests__/chain.d.ts +2 -0
  295. package/types-3.4/__tests__/concat.d.ts +2 -0
  296. package/types-3.4/__tests__/count.d.ts +2 -0
  297. package/types-3.4/__tests__/data.d.ts +62 -0
  298. package/types-3.4/__tests__/deviation.d.ts +2 -0
  299. package/types-3.4/__tests__/distribution.d.ts +2 -0
  300. package/types-3.4/__tests__/each.d.ts +2 -0
  301. package/types-3.4/__tests__/entries.d.ts +2 -0
  302. package/types-3.4/__tests__/extent.d.ts +2 -0
  303. package/types-3.4/__tests__/filter.d.ts +2 -0
  304. package/types-3.4/__tests__/first.d.ts +2 -0
  305. package/types-3.4/__tests__/generate.d.ts +2 -0
  306. package/types-3.4/__tests__/group.d.ts +2 -0
  307. package/types-3.4/__tests__/histogram.d.ts +2 -0
  308. package/types-3.4/__tests__/index.d.ts +28 -0
  309. package/types-3.4/__tests__/join.d.ts +2 -0
  310. package/types-3.4/__tests__/map.d.ts +2 -0
  311. package/types-3.4/__tests__/max.d.ts +2 -0
  312. package/types-3.4/__tests__/mean.d.ts +2 -0
  313. package/types-3.4/__tests__/median.d.ts +2 -0
  314. package/types-3.4/__tests__/min.d.ts +2 -0
  315. package/types-3.4/__tests__/normalize.d.ts +2 -0
  316. package/types-3.4/__tests__/quartile.d.ts +2 -0
  317. package/types-3.4/__tests__/readme.d.ts +2 -0
  318. package/types-3.4/__tests__/reduce.d.ts +2 -0
  319. package/types-3.4/__tests__/skip.d.ts +2 -0
  320. package/types-3.4/__tests__/sort.d.ts +2 -0
  321. package/types-3.4/__tests__/variance.d.ts +2 -0
  322. package/types-3.4/activities/activity.d.ts +6 -0
  323. package/types-3.4/activities/concat.d.ts +4 -0
  324. package/types-3.4/activities/each.d.ts +5 -0
  325. package/types-3.4/activities/entries.d.ts +10 -0
  326. package/types-3.4/activities/filter.d.ts +5 -0
  327. package/types-3.4/activities/first.d.ts +4 -0
  328. package/types-3.4/activities/group.d.ts +9 -0
  329. package/types-3.4/activities/histogram.d.ts +18 -0
  330. package/types-3.4/activities/join.d.ts +5 -0
  331. package/types-3.4/activities/map.d.ts +5 -0
  332. package/types-3.4/activities/normalize.d.ts +4 -0
  333. package/types-3.4/activities/skip.d.ts +4 -0
  334. package/types-3.4/activities/sort.d.ts +5 -0
  335. package/types-3.4/index.d.ts +28 -0
  336. package/types-3.4/observers/count.d.ts +3 -0
  337. package/types-3.4/observers/deviation.d.ts +5 -0
  338. package/types-3.4/observers/distribution.d.ts +13 -0
  339. package/types-3.4/observers/extent.d.ts +11 -0
  340. package/types-3.4/observers/max.d.ts +5 -0
  341. package/types-3.4/observers/mean.d.ts +5 -0
  342. package/types-3.4/observers/median.d.ts +5 -0
  343. package/types-3.4/observers/min.d.ts +5 -0
  344. package/types-3.4/observers/observer.d.ts +14 -0
  345. package/types-3.4/observers/quartile.d.ts +12 -0
  346. package/types-3.4/observers/reduce.d.ts +4 -0
  347. package/types-3.4/observers/variance.d.ts +5 -0
  348. package/types-3.4/utils/generate.d.ts +2 -0
  349. package/types-3.4/utils/pipe.d.ts +42 -0
@@ -0,0 +1,47 @@
1
+ import { expect } from "chai";
2
+ import { histogram } from "../index";
3
+ import { people, Person, population } from "./data";
4
+
5
+ describe("histogram", () => {
6
+ it("generator", () => {
7
+ const h = [...histogram<Person>(row => row.age, { buckets: 10 })(population)];
8
+ expect(h).to.have.length;
9
+ expect(h.length).to.equal(10);
10
+ expect(h[0].from).to.exist;
11
+ expect(h[0].to).to.exist;
12
+ expect(h[0].value).to.have.length;
13
+
14
+ const h2 = [...histogram<Person>(row => row.age, { min: 15, range: 5 })(population)];
15
+ expect(h2).to.have.length;
16
+ expect(h2.length).to.equal(11);
17
+ });
18
+
19
+ it("generator 2", () => {
20
+ const h = [...histogram<Person>(row => row.age, { buckets: 10 })(people())];
21
+ expect(h).to.have.length;
22
+ expect(h.length).to.equal(10);
23
+ expect(h[0].from).to.exist;
24
+ expect(h[0].to).to.exist;
25
+ expect(h[0].value).to.have.length;
26
+
27
+ const h2 = [...histogram<Person>(row => row.age, { min: 15, range: 5 })(people())];
28
+ expect(h2).to.have.length;
29
+ expect(h2.length).to.equal(11);
30
+ });
31
+
32
+ it("scalarActivity", () => {
33
+ const h = [...histogram(population, row => row.age, { buckets: 10 })];
34
+ expect(h).to.have.length;
35
+ expect(h[0].from).to.exist;
36
+ expect(h[0].to).to.exist;
37
+ expect(h[0].value).to.have.length;
38
+ });
39
+
40
+ it("readme", () => {
41
+ const data = [1, 12, 13, 13, 3, 14, 19, 6];
42
+ const h = [...histogram(data, n => n, { buckets: 3 })];
43
+ expect(h).to.have.length;
44
+ const h2 = [...histogram(data, n => n, { min: 0, range: 5 })];
45
+ expect(h2).to.have.length;
46
+ });
47
+ });
@@ -0,0 +1,27 @@
1
+ export * from "./chain";
2
+ export * from "./concat";
3
+ export * from "./count";
4
+ export * from "./data";
5
+ export * from "./deviation";
6
+ export * from "./distribution";
7
+ export * from "./each";
8
+ export * from "./entries";
9
+ export * from "./extent";
10
+ export * from "./filter";
11
+ export * from "./first";
12
+ export * from "./generate";
13
+ export * from "./group";
14
+ export * from "./histogram";
15
+ export * from "./join";
16
+ export * from "./map";
17
+ export * from "./max";
18
+ export * from "./mean";
19
+ export * from "./median";
20
+ export * from "./min";
21
+ export * from "./normalize";
22
+ export * from "./quartile";
23
+ export * from "./readme";
24
+ export * from "./reduce";
25
+ export * from "./skip";
26
+ export * from "./sort";
27
+ export * from "./variance";
@@ -0,0 +1,20 @@
1
+ import { expect } from "chai";
2
+ import { each, join, map, normalize } from "../index";
3
+ import { Person, population } from "./data";
4
+
5
+ interface PersonEx extends Person {
6
+ normalizedAge: number;
7
+ }
8
+
9
+ describe("join", () => {
10
+ it("normalize", () => {
11
+ const extractAge = map<Person, number>(row => row.age);
12
+ const normalizeFn = normalize();
13
+ const joinNormalizeAges = join(normalizeFn(extractAge(population)), (row: Person, age: number): PersonEx => ({ ...row, normalizedAge: age }));
14
+ const doTest = each(row => {
15
+ expect(row.normalizedAge).to.be.greaterThanOrEqual(0);
16
+ expect(row.normalizedAge).to.be.lessThanOrEqual(1);
17
+ });
18
+ [...doTest(joinNormalizeAges(population))];
19
+ });
20
+ });
@@ -0,0 +1,16 @@
1
+ import { expect } from "chai";
2
+ import { map } from "../index";
3
+ import { population } from "./data";
4
+
5
+ const testMap = row => ({ ...row.address });
6
+ const expected = population.map(testMap);
7
+
8
+ describe("map", () => {
9
+ it("generator", () => {
10
+ expect([...map(testMap)(population)]).to.deep.equal(expected);
11
+ });
12
+
13
+ it("scalarActivity", () => {
14
+ expect([...map(population, testMap)]).to.deep.equal(expected);
15
+ });
16
+ });
@@ -0,0 +1,42 @@
1
+ import { expect } from "chai";
2
+ import { pipe, filter, max, scalar, sensor } from "../index";
3
+ import { population } from "./data";
4
+
5
+ describe("max", () => {
6
+ it("NumberArray", () => {
7
+ const s1 = max();
8
+ const s2 = max();
9
+ const p1 = pipe(
10
+ sensor(s1),
11
+ filter(r => r < 3),
12
+ sensor(s2),
13
+ );
14
+ const data = [...p1([1, 2, 3, 4, 5, 0])];
15
+ expect(data.length).to.equal(3);
16
+ expect(s1.peek()).to.equal(5);
17
+ expect(s2.peek()).to.equal(2);
18
+ });
19
+
20
+ it("Population", () => {
21
+ const s1 = max(r => r.age);
22
+ const s2 = max(r => r.age);
23
+ const p1 = pipe(
24
+ sensor(s1),
25
+ filter(r => r.age < 30),
26
+ sensor(s2),
27
+ );
28
+ const data = [...p1(population)];
29
+ expect(data.length).to.equal(286);
30
+ expect(s1.peek()).to.equal(66);
31
+ expect(s2.peek()).to.equal(29);
32
+ });
33
+
34
+ it("scalarActivity", () => {
35
+ const s1 = scalar(max());
36
+ expect(s1([1, 2, 3, 4, 5, 0])).to.equal(5);
37
+
38
+ const s2 = scalar(max(r => r.age));
39
+ expect(s2(population)).to.equal(66);
40
+ });
41
+ });
42
+
@@ -0,0 +1,11 @@
1
+ import { expect } from "chai";
2
+ import { mean, scalar } from "../index";
3
+
4
+ describe("mean", () => {
5
+ it("scalarActivity", () => {
6
+ const a1 = scalar(mean());
7
+ expect(a1([5, -6, 1, 2, -2])).to.equal(0);
8
+ expect(a1([9])).to.deep.equal(9);
9
+ });
10
+ });
11
+
@@ -0,0 +1,14 @@
1
+ import { expect } from "chai";
2
+ import { median, scalar } from "../index";
3
+
4
+ describe("median", () => {
5
+
6
+ it("scalarActivity", () => {
7
+ const calcMedian = scalar(median());
8
+ expect(calcMedian([-6, -2, 1, 2, 5])).to.equal(1);
9
+ expect(calcMedian([5, -6, 1, 2, -2])).to.equal(1);
10
+ expect(calcMedian([-6, -2, 1, 2, 5, 6])).to.equal(1.5);
11
+ expect(calcMedian([5, -6, 1, 2, -2, 6])).to.equal(1.5);
12
+ expect(calcMedian([9])).to.deep.equal(9);
13
+ });
14
+ });
@@ -0,0 +1,42 @@
1
+ import { expect } from "chai";
2
+ import { pipe, filter, min, scalar, sensor } from "../index";
3
+ import { population } from "./data";
4
+
5
+ describe("min", () => {
6
+ it("NumberArray", () => {
7
+ const s1 = min();
8
+ const s2 = min();
9
+ const p1 = pipe(
10
+ sensor(s1),
11
+ filter(r => r > 3),
12
+ sensor(s2),
13
+ );
14
+ const data = [...p1([1, 2, 3, 4, 5, 0])];
15
+ expect(data.length).to.equal(2);
16
+ expect(s1.peek()).to.equal(0);
17
+ expect(s2.peek()).to.equal(4);
18
+ });
19
+
20
+ it("Population", () => {
21
+ const s1 = min(r => r.age);
22
+ const s2 = min(r => r.age);
23
+ const p1 = pipe(
24
+ sensor(s1),
25
+ filter(r => r.age > 30),
26
+ sensor(s2),
27
+ );
28
+ const data = [...p1(population)];
29
+ expect(data.length).to.equal(699);
30
+ expect(s1.peek()).to.equal(16);
31
+ expect(s2.peek()).to.equal(31);
32
+ });
33
+
34
+ it("scalarActivity", () => {
35
+ const a1 = scalar(min());
36
+ expect(a1([1, 2, 3, 4, 5, 0])).to.equal(0);
37
+
38
+ const a2 = scalar(min(r => r.age));
39
+ expect(a2(population)).to.equal(16);
40
+ });
41
+ });
42
+
@@ -0,0 +1,14 @@
1
+ import { expect } from "chai";
2
+ import { normalize } from "../index";
3
+
4
+ describe("normalize", () => {
5
+
6
+ it("numberArray", () => {
7
+ const normFunc = normalize();
8
+ expect([...normFunc([0, 5, 10])]).to.deep.equal([0, .5, 1]);
9
+ expect([...normFunc([0, 10, 20])]).to.deep.equal([0, .5, 1]);
10
+ expect([...normFunc([0, 1, 2, 3, 4])]).to.deep.equal([0, .25, .5, .75, 1]);
11
+ expect([...normFunc([0, 10, 20, 30, 40])]).to.deep.equal([0, .25, .5, .75, 1]);
12
+ });
13
+ });
14
+
@@ -0,0 +1,14 @@
1
+ import { expect } from "chai";
2
+ import { quartile, scalar } from "../index";
3
+
4
+ describe("quartile", () => {
5
+
6
+ it("scalarActivity", () => {
7
+ const calcQuartile = scalar(quartile());
8
+ expect(calcQuartile([6, 7, 15, 36, 39, 40, 41, 42, 43, 47, 49])).to.deep.equal([6, 15, 40, 43, 49]);
9
+ expect(calcQuartile([7, 15, 36, 39, 40, 41])).to.deep.equal([7, 15, 37.5, 40, 41]);
10
+ expect(calcQuartile([1, 22, 133])).to.deep.equal([1, 1, 22, 133, 133]);
11
+ expect(calcQuartile([2, 144, 33])).to.deep.equal([2, 2, 33, 144, 144]);
12
+ });
13
+ });
14
+
@@ -0,0 +1,113 @@
1
+ import { expect } from "chai";
2
+
3
+ import { count, filter, first, generate, map, max, pipe, sensor } from "../index";
4
+
5
+ describe("readme", () => {
6
+
7
+ it("quick example", () => {
8
+
9
+ const c1 = count();
10
+ const c2 = count();
11
+ const c3 = count();
12
+ const m1 = max(row => row.value);
13
+
14
+ const p1 = pipe(
15
+ sensor(c1), // Keep running count of input
16
+ filter(n => n <= 0.5), // Filter out numbers > 0.5
17
+ sensor(c2), // Keep running count of filtered rows
18
+ map((n, idx) => // Convert to JSON Object
19
+ ({ index: idx, value: n })),
20
+ filter(row => row.index % 2 === 0), // Filter even row indecies
21
+ sensor(c3), // Keep running count of final rows
22
+ sensor(m1), // Track largest value
23
+ first(3) // Take first 3 rows
24
+ );
25
+
26
+ console.info(`Counts: ${c1.peek()}, ${c2.peek()}, ${c3.peek()}`);
27
+ // [1] => Counts: undefined, undefined, undefined
28
+ const outIterable = p1(generate(Math.random, 1000));
29
+ console.info(`Counts: ${c1.peek()}, ${c2.peek()}, ${c3.peek()}`);
30
+ // [2] => Counts: undefined, undefined, undefined
31
+ console.info(JSON.stringify([...outIterable]));
32
+ // [3] => [{"index":0,"value":0.19075931906641008},{"index":2,"value":0.4873469062925415},{"index":4,"value":0.4412516774100035}]
33
+ console.info(`Counts: ${c1.peek()}, ${c2.peek()}, ${c3.peek()}, ${m1.peek()}`);
34
+ // [4] => Counts: 6, 5, 3, 0.4873469062925415
35
+
36
+ const outArray = [...p1([0.7, 0.5, 0.4, 0.8, 0.3, 1])];
37
+ console.info(JSON.stringify(outArray));
38
+ // [5] => [{"index":0,"value":0.5},{"index":2,"value":0.3}]
39
+ console.info(`Counts: ${c1.peek()}, ${c2.peek()}, ${c3.peek()}, ${m1.peek()}`);
40
+ // [6] => Counts: 6, 3, 2, 0.5
41
+
42
+ expect(outArray.length).to.equal(2);
43
+
44
+ for (const row of p1(generate(Math.random, 1000000))) {
45
+ console.info(`${row.index}: ${c1.peek()}, ${c2.peek()}, ${c3.peek()}, ${m1.peek()}`);
46
+ }
47
+ });
48
+
49
+ it("interesting example", () => {
50
+ const c1 = count();
51
+ const c2 = count();
52
+ const c3 = count();
53
+ const m1 = max(row => row.value);
54
+
55
+ const p1 = pipe(
56
+ sensor(c1), // Keep running count of input
57
+ filter(n => n <= 0.5), // Filter out numbers > 0.5
58
+ sensor(c2), // Keep running count of filtered rows
59
+ map((n, idx) => // Convert to JSON Object
60
+ ({ index: idx, value: n })),
61
+ filter(row => row.index % 2 === 0), // Filter even row indecies
62
+ sensor(c3), // Keep running count of final rows
63
+ sensor(m1), // Track largest value
64
+ );
65
+
66
+ for (const row of p1(generate(Math.random, 1000000))) {
67
+ if (row.index % 100000 === 0) {
68
+ console.info(`${row.index}: ${c1.peek()}, ${c2.peek()}, ${c3.peek()}, ${m1.peek()}`);
69
+ }
70
+ }
71
+ });
72
+ });
73
+
74
+ /*
75
+ const process3 = pipe(
76
+ filter(n => n <= 0.5),
77
+ map((n, idx) => ({ index: idx, value: n })),
78
+ filter(row => row.index % 2 === 0),
79
+ sort((l, r) => l.value - r.value),
80
+ first(3)
81
+ );
82
+ console.log(...process3([]));
83
+
84
+ // Iterable output
85
+ pipe([0, 1, 2, 3, 4, 5, 6, 7, 8, 9],
86
+ filter(n => n <= 5),
87
+ map((n, idx) => ({ index: idx, value: n })),
88
+ filter(row => row.index % 2 === 0),
89
+ sort((l, r) => l.value - r.value),
90
+ first(3)
91
+ ); // => { index: 0, value: 0 }, { index: 2, value: 2 }, { index: 4, value: 4 }
92
+
93
+ const process = pipe(
94
+ filter(n => n <= 5),
95
+ map((n, idx) => ({ index: idx, value: n })),
96
+ filter(row => row.index % 2 === 0),
97
+ sort((l, r) => l.value - r.value),
98
+ first(3)
99
+ );
100
+ console.log([...process([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])]); // => { index: 0, value: 0 }, { index: 2, value: 2 }, { index: 4, value: 4 }
101
+
102
+ // Scalar output
103
+ pipe([0, 1, 2, 3, 4, 5, 6, 7, 8, 9],
104
+ process,
105
+ scalar(max(row => row.value))
106
+ ); // => 4
107
+
108
+ const process_2 = pipe(
109
+ process,
110
+ scalar(min(row => row.value))
111
+ );
112
+ console.log(process_2([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])); // => 0
113
+ */
@@ -0,0 +1,17 @@
1
+ import { expect } from "chai";
2
+ import { reduce, scalar } from "../index";
3
+
4
+ const data = [1, 2, 3, 4, 5];
5
+ const reduceFunc = (prev, row) => prev + row;
6
+ const expectedA = data.reduce(reduceFunc);
7
+ const expectedB = data.reduce(reduceFunc, 10);
8
+
9
+ describe("reduce", () => {
10
+
11
+ it("scalarActivity", () => {
12
+ const calcReduce = scalar(reduce(reduceFunc));
13
+ const calcReduce2 = scalar(reduce(reduceFunc, 10));
14
+ expect(calcReduce(data)).to.equal(expectedA);
15
+ expect(calcReduce2(data)).to.equal(expectedB);
16
+ });
17
+ });
@@ -0,0 +1,15 @@
1
+ import { expect } from "chai";
2
+ import { skip } from "../index";
3
+
4
+ describe("skip", () => {
5
+ it("generator", () => {
6
+ expect([...skip(2)([])]).to.deep.equal([]);
7
+ expect([...skip(2)(["a", "b", "c"])]).to.deep.equal(["c"]);
8
+ });
9
+
10
+ it("scalarActivity", () => {
11
+ expect([...skip([], 22)]).to.deep.equal([]);
12
+ expect([...skip(["a", "b", "c"], 2)]).to.deep.equal(["c"]);
13
+ expect([...skip(["a", "b", "c"], 22)]).to.deep.equal([]);
14
+ });
15
+ });
@@ -0,0 +1,21 @@
1
+ import { expect } from "chai";
2
+ import { sort } from "../index";
3
+ import { Person, population } from "./data";
4
+
5
+ function sortFunc(l: Person, r: Person): number {
6
+ const retVal = l.lname.localeCompare(r.lname);
7
+ if (retVal === 0) return l.fname.localeCompare(r.fname);
8
+ return retVal;
9
+ }
10
+
11
+ const expected = [...population].sort(sortFunc);
12
+
13
+ describe("sort", () => {
14
+ it("generator", () => {
15
+ expect([...sort(sortFunc)(population)]).to.deep.equal(expected);
16
+ });
17
+
18
+ it("scalarActivity", () => {
19
+ expect([...sort(population, sortFunc)]).to.deep.equal(expected);
20
+ });
21
+ });
@@ -0,0 +1,14 @@
1
+ import { expect } from "chai";
2
+ import { variance, scalar } from "../index";
3
+
4
+ describe("variance", () => {
5
+ it("scalarActivity", () => {
6
+ const calcVariance = scalar(variance());
7
+ expect(calcVariance([5, 1, 2, 3, 4])).to.equal(2.5);
8
+ });
9
+
10
+ it("empty array", () => {
11
+ const varianceActivity = scalar(variance());
12
+ expect(varianceActivity([])).to.be.undefined;
13
+ });
14
+ });
@@ -1,8 +1,8 @@
1
- export type Source<T> = IterableIterator<T> | T[];
2
- export type IterableActivity<T, U = T> = (source: Source<T>) => IterableIterator<U>;
3
- export type ScalarActivity<T, U = T> = (source: Source<T>) => U;
4
- export type Activity<T, U = T> = IterableActivity<T, U> | ScalarActivity<T, U>;
5
-
6
- export function isSource<T>(source: Source<T> | any): source is Source<T> {
7
- return source && (typeof source[Symbol.iterator] === "function" || Array.isArray(source));
8
- }
1
+ export type Source<T> = IterableIterator<T> | T[];
2
+ export type IterableActivity<T, U = T> = (source: Source<T>) => IterableIterator<U>;
3
+ export type ScalarActivity<T, U = T> = (source: Source<T>) => U;
4
+ export type Activity<T, U = T> = IterableActivity<T, U> | ScalarActivity<T, U>;
5
+
6
+ export function isSource<T>(source: Source<T> | any): source is Source<T> {
7
+ return source && (typeof source[Symbol.iterator] === "function" || Array.isArray(source));
8
+ }
@@ -1,14 +1,14 @@
1
- import { Source, IterableActivity } from "./activity.ts";
2
-
3
- function concatGen<T = any>(concatSource: Source<T>): IterableActivity<T> {
4
- return function* (source: Source<T>) {
5
- yield* source;
6
- yield* concatSource;
7
- };
8
- }
9
-
10
- export function concat<T = any>(concatSource: Source<T>): IterableActivity<T, T>;
11
- export function concat<T>(source: Source<T>, concatSource: Source<T>): IterableIterator<T>;
12
- export function concat<T = any>(s_or_n: Source<T>, concatSource?: Source<T>): IterableActivity<T, T> | IterableIterator<T> {
13
- return concatSource !== undefined ? concatGen<T>(concatSource!)(s_or_n) : concatGen<T>(s_or_n);
14
- }
1
+ import { Source, IterableActivity } from "./activity";
2
+
3
+ function concatGen<T = any>(concatSource: Source<T>): IterableActivity<T> {
4
+ return function* (source: Source<T>) {
5
+ yield* source;
6
+ yield* concatSource;
7
+ };
8
+ }
9
+
10
+ export function concat<T = any>(concatSource: Source<T>): IterableActivity<T, T>;
11
+ export function concat<T>(source: Source<T>, concatSource: Source<T>): IterableIterator<T>;
12
+ export function concat<T = any>(s_or_n: Source<T>, concatSource?: Source<T>): IterableActivity<T, T> | IterableIterator<T> {
13
+ return concatSource !== undefined ? concatGen<T>(concatSource!)(s_or_n) : concatGen<T>(s_or_n);
14
+ }
@@ -1,19 +1,19 @@
1
- import { IterableActivity, Source, isSource } from "./activity.ts";
2
-
3
- export type EachCallback<T> = (value: T, index: number) => void;
4
-
5
- function eachGen<T = any>(callbackFn: EachCallback<T>): IterableActivity<T> {
6
- return function* (source: Source<T>) {
7
- let i = -1;
8
- for (const item of source) {
9
- callbackFn(item, ++i);
10
- yield item;
11
- }
12
- };
13
- }
14
-
15
- export function each<T = any>(callbackFn: EachCallback<T>): IterableActivity<T>;
16
- export function each<T>(source: Source<T>, callbackFn: EachCallback<T>): IterableIterator<T>;
17
- export function each<T>(s_or_cb: Source<T> | EachCallback<T>, callbackFn?: EachCallback<T>): IterableActivity<T> | IterableIterator<T> {
18
- return isSource(s_or_cb) ? eachGen(callbackFn!)(s_or_cb) : eachGen(s_or_cb);
19
- }
1
+ import { IterableActivity, Source, isSource } from "./activity";
2
+
3
+ export type EachCallback<T> = (value: T, index: number) => void;
4
+
5
+ function eachGen<T = any>(callbackFn: EachCallback<T>): IterableActivity<T> {
6
+ return function* (source: Source<T>) {
7
+ let i = -1;
8
+ for (const item of source) {
9
+ callbackFn(item, ++i);
10
+ yield item;
11
+ }
12
+ };
13
+ }
14
+
15
+ export function each<T = any>(callbackFn: EachCallback<T>): IterableActivity<T>;
16
+ export function each<T>(source: Source<T>, callbackFn: EachCallback<T>): IterableIterator<T>;
17
+ export function each<T>(s_or_cb: Source<T> | EachCallback<T>, callbackFn?: EachCallback<T>): IterableActivity<T> | IterableIterator<T> {
18
+ return isSource(s_or_cb) ? eachGen(callbackFn!)(s_or_cb) : eachGen(s_or_cb);
19
+ }
@@ -1,17 +1,17 @@
1
- import { IterableActivity, Source } from "./activity.ts";
2
-
3
- // Array.entries
4
- function entriesGen<T = any>(): IterableActivity<T, [number, T]> {
5
- return function* (source: Source<T>) {
6
- let i = -1;
7
- for (const item of source) {
8
- yield [++i, item];
9
- }
10
- };
11
- }
12
-
13
- export function entries<T = any>(): IterableActivity<T, [number, T]>;
14
- export function entries<T>(source: Source<T>): IterableIterator<[number, T]>;
15
- export function entries<T>(source?: Source<T>): IterableActivity<T, [number, T]> | IterableIterator<[number, T]> {
16
- return source ? entriesGen<T>()(source) : entriesGen<T>();
17
- }
1
+ import { IterableActivity, Source } from "./activity";
2
+
3
+ // Array.entries
4
+ function entriesGen<T = any>(): IterableActivity<T, [number, T]> {
5
+ return function* (source: Source<T>) {
6
+ let i = -1;
7
+ for (const item of source) {
8
+ yield [++i, item];
9
+ }
10
+ };
11
+ }
12
+
13
+ export function entries<T = any>(): IterableActivity<T, [number, T]>;
14
+ export function entries<T>(source: Source<T>): IterableIterator<[number, T]>;
15
+ export function entries<T>(source?: Source<T>): IterableActivity<T, [number, T]> | IterableIterator<[number, T]> {
16
+ return source ? entriesGen<T>()(source) : entriesGen<T>();
17
+ }
@@ -1,20 +1,20 @@
1
- import { IterableActivity, Source, isSource } from "./activity.ts";
2
-
3
- export type FilterCallback<T> = (value: T, index: number) => boolean;
4
-
5
- function filterGen<T = any>(callbackFn: FilterCallback<T>): IterableActivity<T> {
6
- return function* (source: Source<T>) {
7
- let i = -1;
8
- for (const item of source) {
9
- if (callbackFn(item, ++i)) {
10
- yield item;
11
- }
12
- }
13
- };
14
- }
15
-
16
- export function filter<T = any>(callbackFn: FilterCallback<T>): IterableActivity<T>;
17
- export function filter<T>(source: Source<T>, callbackFn: FilterCallback<T>): IterableIterator<T>;
18
- export function filter<T>(s_or_cb: Source<T> | FilterCallback<T>, callbackFn?: FilterCallback<T>): IterableActivity<T> | IterableIterator<T> {
19
- return isSource(s_or_cb) ? filterGen(callbackFn!)(s_or_cb) : filterGen(s_or_cb);
20
- }
1
+ import { IterableActivity, Source, isSource } from "./activity";
2
+
3
+ export type FilterCallback<T> = (value: T, index: number) => boolean;
4
+
5
+ function filterGen<T = any>(callbackFn: FilterCallback<T>): IterableActivity<T> {
6
+ return function* (source: Source<T>) {
7
+ let i = -1;
8
+ for (const item of source) {
9
+ if (callbackFn(item, ++i)) {
10
+ yield item;
11
+ }
12
+ }
13
+ };
14
+ }
15
+
16
+ export function filter<T = any>(callbackFn: FilterCallback<T>): IterableActivity<T>;
17
+ export function filter<T>(source: Source<T>, callbackFn: FilterCallback<T>): IterableIterator<T>;
18
+ export function filter<T>(s_or_cb: Source<T> | FilterCallback<T>, callbackFn?: FilterCallback<T>): IterableActivity<T> | IterableIterator<T> {
19
+ return isSource(s_or_cb) ? filterGen(callbackFn!)(s_or_cb) : filterGen(s_or_cb);
20
+ }
@@ -1,20 +1,20 @@
1
- import { IterableActivity, isSource, Source } from "./activity.ts";
2
-
3
- function firstGen<T = any>(n: number): IterableActivity<T, T> {
4
- return function* (source: Source<T>) {
5
- let i = 0;
6
- for (const item of source) {
7
- yield item;
8
- if (++i >= n) {
9
- break;
10
- }
11
- }
12
- };
13
- }
14
-
15
- export function first<T = any>(n: number): IterableActivity<T, T>;
16
- export function first<T>(source: Source<T>, n: number): IterableIterator<T>;
17
- export function first<T = any>(s_or_n: Source<T> | number, n?: number): IterableActivity<T, T> | IterableIterator<T> {
18
- if (!isSource(s_or_n)) return firstGen<T>(s_or_n);
19
- return firstGen<T>(n!)(s_or_n);
20
- }
1
+ import { IterableActivity, isSource, Source } from "./activity";
2
+
3
+ function firstGen<T = any>(n: number): IterableActivity<T, T> {
4
+ return function* (source: Source<T>) {
5
+ let i = 0;
6
+ for (const item of source) {
7
+ yield item;
8
+ if (++i >= n) {
9
+ break;
10
+ }
11
+ }
12
+ };
13
+ }
14
+
15
+ export function first<T = any>(n: number): IterableActivity<T, T>;
16
+ export function first<T>(source: Source<T>, n: number): IterableIterator<T>;
17
+ export function first<T = any>(s_or_n: Source<T> | number, n?: number): IterableActivity<T, T> | IterableIterator<T> {
18
+ if (!isSource(s_or_n)) return firstGen<T>(s_or_n);
19
+ return firstGen<T>(n!)(s_or_n);
20
+ }