@trebco/treb 36.1.4 → 37.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (552) hide show
  1. package/api-config.json +1 -1
  2. package/build/package.json +119 -0
  3. package/build/treb-base-types/src/api_types.d.ts +11 -0
  4. package/build/treb-base-types/src/api_types.js +22 -0
  5. package/build/treb-base-types/src/api_types.js.map +1 -0
  6. package/build/treb-base-types/src/area-utils.d.ts +9 -0
  7. package/build/treb-base-types/src/area-utils.js +50 -0
  8. package/build/treb-base-types/src/area-utils.js.map +1 -0
  9. package/build/treb-base-types/src/area.d.ts +182 -0
  10. package/build/treb-base-types/src/area.js +715 -0
  11. package/build/treb-base-types/src/area.js.map +1 -0
  12. package/build/treb-base-types/src/basic_types.d.ts +20 -0
  13. package/build/treb-base-types/src/basic_types.js +22 -0
  14. package/build/treb-base-types/src/basic_types.js.map +1 -0
  15. package/build/treb-base-types/src/cell.d.ts +167 -0
  16. package/build/treb-base-types/src/cell.js +432 -0
  17. package/build/treb-base-types/src/cell.js.map +1 -0
  18. package/build/treb-base-types/src/cells.d.ts +251 -0
  19. package/build/treb-base-types/src/cells.js +1136 -0
  20. package/build/treb-base-types/src/cells.js.map +1 -0
  21. package/build/treb-base-types/src/color.d.ts +35 -0
  22. package/build/treb-base-types/src/color.js +162 -0
  23. package/build/treb-base-types/src/color.js.map +1 -0
  24. package/build/treb-base-types/src/dom-utilities.d.ts +70 -0
  25. package/build/treb-base-types/src/dom-utilities.js +144 -0
  26. package/build/treb-base-types/src/dom-utilities.js.map +1 -0
  27. package/build/treb-base-types/src/evaluate-options.d.ts +35 -0
  28. package/build/treb-base-types/src/evaluate-options.js +22 -0
  29. package/build/treb-base-types/src/evaluate-options.js.map +1 -0
  30. package/build/treb-base-types/src/font-stack.d.ts +37 -0
  31. package/build/treb-base-types/src/font-stack.js +93 -0
  32. package/build/treb-base-types/src/font-stack.js.map +1 -0
  33. package/build/treb-base-types/src/gradient.d.ts +18 -0
  34. package/build/treb-base-types/src/gradient.js +86 -0
  35. package/build/treb-base-types/src/gradient.js.map +1 -0
  36. package/build/treb-base-types/src/import.d.ts +48 -0
  37. package/build/treb-base-types/src/import.js +22 -0
  38. package/build/treb-base-types/src/import.js.map +1 -0
  39. package/build/treb-base-types/src/index-standalone.d.ts +6 -0
  40. package/build/treb-base-types/src/index-standalone.js +27 -0
  41. package/build/treb-base-types/src/index-standalone.js.map +1 -0
  42. package/build/treb-base-types/src/index.d.ts +22 -0
  43. package/build/treb-base-types/src/index.js +45 -0
  44. package/build/treb-base-types/src/index.js.map +1 -0
  45. package/build/treb-base-types/src/layout.d.ts +22 -0
  46. package/build/treb-base-types/src/layout.js +22 -0
  47. package/build/treb-base-types/src/layout.js.map +1 -0
  48. package/build/treb-base-types/src/localization.d.ts +37 -0
  49. package/build/treb-base-types/src/localization.js +157 -0
  50. package/build/treb-base-types/src/localization.js.map +1 -0
  51. package/build/treb-base-types/src/rectangle.d.ts +51 -0
  52. package/build/treb-base-types/src/rectangle.js +123 -0
  53. package/build/treb-base-types/src/rectangle.js.map +1 -0
  54. package/build/treb-base-types/src/render_text.d.ts +34 -0
  55. package/build/treb-base-types/src/render_text.js +22 -0
  56. package/build/treb-base-types/src/render_text.js.map +1 -0
  57. package/build/treb-base-types/src/style.d.ts +214 -0
  58. package/build/treb-base-types/src/style.js +373 -0
  59. package/build/treb-base-types/src/style.js.map +1 -0
  60. package/build/treb-base-types/src/table.d.ts +58 -0
  61. package/build/treb-base-types/src/table.js +27 -0
  62. package/build/treb-base-types/src/table.js.map +1 -0
  63. package/build/treb-base-types/src/text_part.d.ts +26 -0
  64. package/build/treb-base-types/src/text_part.js +47 -0
  65. package/build/treb-base-types/src/text_part.js.map +1 -0
  66. package/build/treb-base-types/src/theme.d.ts +120 -0
  67. package/build/treb-base-types/src/theme.js +460 -0
  68. package/build/treb-base-types/src/theme.js.map +1 -0
  69. package/build/treb-base-types/src/union.d.ts +73 -0
  70. package/build/treb-base-types/src/union.js +61 -0
  71. package/build/treb-base-types/src/union.js.map +1 -0
  72. package/build/treb-base-types/src/value-type.d.ts +86 -0
  73. package/build/treb-base-types/src/value-type.js +168 -0
  74. package/build/treb-base-types/src/value-type.js.map +1 -0
  75. package/build/treb-base-types/src/worker-proxy.d.ts +95 -0
  76. package/build/treb-base-types/src/worker-proxy.js +221 -0
  77. package/build/treb-base-types/src/worker-proxy.js.map +1 -0
  78. package/build/treb-calculator/src/calculator.d.ts +249 -0
  79. package/build/treb-calculator/src/calculator.js +2755 -0
  80. package/build/treb-calculator/src/calculator.js.map +1 -0
  81. package/build/treb-calculator/src/complex-math.d.ts +75 -0
  82. package/build/treb-calculator/src/complex-math.js +559 -0
  83. package/build/treb-calculator/src/complex-math.js.map +1 -0
  84. package/build/treb-calculator/src/dag/array-vertex.d.ts +71 -0
  85. package/build/treb-calculator/src/dag/array-vertex.js +156 -0
  86. package/build/treb-calculator/src/dag/array-vertex.js.map +1 -0
  87. package/build/treb-calculator/src/dag/calculation_leaf_vertex.d.ts +48 -0
  88. package/build/treb-calculator/src/dag/calculation_leaf_vertex.js +84 -0
  89. package/build/treb-calculator/src/dag/calculation_leaf_vertex.js.map +1 -0
  90. package/build/treb-calculator/src/dag/graph.d.ts +134 -0
  91. package/build/treb-calculator/src/dag/graph.js +842 -0
  92. package/build/treb-calculator/src/dag/graph.js.map +1 -0
  93. package/build/treb-calculator/src/dag/spreadsheet_vertex.d.ts +58 -0
  94. package/build/treb-calculator/src/dag/spreadsheet_vertex.js +232 -0
  95. package/build/treb-calculator/src/dag/spreadsheet_vertex.js.map +1 -0
  96. package/build/treb-calculator/src/dag/spreadsheet_vertex_base.d.ts +20 -0
  97. package/build/treb-calculator/src/dag/spreadsheet_vertex_base.js +25 -0
  98. package/build/treb-calculator/src/dag/spreadsheet_vertex_base.js.map +1 -0
  99. package/build/treb-calculator/src/dag/state_leaf_vertex.d.ts +43 -0
  100. package/build/treb-calculator/src/dag/state_leaf_vertex.js +81 -0
  101. package/build/treb-calculator/src/dag/state_leaf_vertex.js.map +1 -0
  102. package/build/treb-calculator/src/dag/vertex.d.ts +71 -0
  103. package/build/treb-calculator/src/dag/vertex.js +274 -0
  104. package/build/treb-calculator/src/dag/vertex.js.map +1 -0
  105. package/build/treb-calculator/src/descriptors.d.ts +189 -0
  106. package/build/treb-calculator/src/descriptors.js +22 -0
  107. package/build/treb-calculator/src/descriptors.js.map +1 -0
  108. package/build/treb-calculator/src/expression-calculator.d.ts +127 -0
  109. package/build/treb-calculator/src/expression-calculator.js +1033 -0
  110. package/build/treb-calculator/src/expression-calculator.js.map +1 -0
  111. package/build/treb-calculator/src/function-error.d.ts +35 -0
  112. package/build/treb-calculator/src/function-error.js +85 -0
  113. package/build/treb-calculator/src/function-error.js.map +1 -0
  114. package/build/treb-calculator/src/function-library.d.ts +22 -0
  115. package/build/treb-calculator/src/function-library.js +96 -0
  116. package/build/treb-calculator/src/function-library.js.map +1 -0
  117. package/build/treb-calculator/src/functions/base-functions.d.ts +7 -0
  118. package/build/treb-calculator/src/functions/base-functions.js +2611 -0
  119. package/build/treb-calculator/src/functions/base-functions.js.map +1 -0
  120. package/build/treb-calculator/src/functions/beta.d.ts +17 -0
  121. package/build/treb-calculator/src/functions/beta.js +201 -0
  122. package/build/treb-calculator/src/functions/beta.js.map +1 -0
  123. package/build/treb-calculator/src/functions/checkbox.d.ts +3 -0
  124. package/build/treb-calculator/src/functions/checkbox.js +128 -0
  125. package/build/treb-calculator/src/functions/checkbox.js.map +1 -0
  126. package/build/treb-calculator/src/functions/complex-functions.d.ts +2 -0
  127. package/build/treb-calculator/src/functions/complex-functions.js +217 -0
  128. package/build/treb-calculator/src/functions/complex-functions.js.map +1 -0
  129. package/build/treb-calculator/src/functions/date-utils.d.ts +3 -0
  130. package/build/treb-calculator/src/functions/date-utils.js +59 -0
  131. package/build/treb-calculator/src/functions/date-utils.js.map +1 -0
  132. package/build/treb-calculator/src/functions/finance-functions.d.ts +2 -0
  133. package/build/treb-calculator/src/functions/finance-functions.js +547 -0
  134. package/build/treb-calculator/src/functions/finance-functions.js.map +1 -0
  135. package/build/treb-calculator/src/functions/fp.d.ts +2 -0
  136. package/build/treb-calculator/src/functions/fp.js +463 -0
  137. package/build/treb-calculator/src/functions/fp.js.map +1 -0
  138. package/build/treb-calculator/src/functions/function-utilities.d.ts +2 -0
  139. package/build/treb-calculator/src/functions/function-utilities.js +36 -0
  140. package/build/treb-calculator/src/functions/function-utilities.js.map +1 -0
  141. package/build/treb-calculator/src/functions/gamma.d.ts +20 -0
  142. package/build/treb-calculator/src/functions/gamma.js +142 -0
  143. package/build/treb-calculator/src/functions/gamma.js.map +1 -0
  144. package/build/treb-calculator/src/functions/information-functions.d.ts +2 -0
  145. package/build/treb-calculator/src/functions/information-functions.js +71 -0
  146. package/build/treb-calculator/src/functions/information-functions.js.map +1 -0
  147. package/build/treb-calculator/src/functions/lambda-functions.d.ts +2 -0
  148. package/build/treb-calculator/src/functions/lambda-functions.js +85 -0
  149. package/build/treb-calculator/src/functions/lambda-functions.js.map +1 -0
  150. package/build/treb-calculator/src/functions/matrix-functions.d.ts +2 -0
  151. package/build/treb-calculator/src/functions/matrix-functions.js +144 -0
  152. package/build/treb-calculator/src/functions/matrix-functions.js.map +1 -0
  153. package/build/treb-calculator/src/functions/normal.d.ts +2 -0
  154. package/build/treb-calculator/src/functions/normal.js +32 -0
  155. package/build/treb-calculator/src/functions/normal.js.map +1 -0
  156. package/build/treb-calculator/src/functions/regex-functions.d.ts +2 -0
  157. package/build/treb-calculator/src/functions/regex-functions.js +188 -0
  158. package/build/treb-calculator/src/functions/regex-functions.js.map +1 -0
  159. package/build/treb-calculator/src/functions/sparkline.d.ts +37 -0
  160. package/build/treb-calculator/src/functions/sparkline.js +264 -0
  161. package/build/treb-calculator/src/functions/sparkline.js.map +1 -0
  162. package/build/treb-calculator/src/functions/statistics-functions.d.ts +6 -0
  163. package/build/treb-calculator/src/functions/statistics-functions.js +989 -0
  164. package/build/treb-calculator/src/functions/statistics-functions.js.map +1 -0
  165. package/build/treb-calculator/src/functions/students-t.d.ts +3 -0
  166. package/build/treb-calculator/src/functions/students-t.js +64 -0
  167. package/build/treb-calculator/src/functions/students-t.js.map +1 -0
  168. package/build/treb-calculator/src/functions/text-functions.d.ts +3 -0
  169. package/build/treb-calculator/src/functions/text-functions.js +320 -0
  170. package/build/treb-calculator/src/functions/text-functions.js.map +1 -0
  171. package/build/treb-calculator/src/index.d.ts +2 -0
  172. package/build/treb-calculator/src/index.js +22 -0
  173. package/build/treb-calculator/src/index.js.map +1 -0
  174. package/build/treb-calculator/src/notifier-types.d.ts +26 -0
  175. package/build/treb-calculator/src/notifier-types.js +22 -0
  176. package/build/treb-calculator/src/notifier-types.js.map +1 -0
  177. package/build/treb-calculator/src/primitives.d.ts +15 -0
  178. package/build/treb-calculator/src/primitives.js +398 -0
  179. package/build/treb-calculator/src/primitives.js.map +1 -0
  180. package/build/treb-calculator/src/utilities.d.ts +68 -0
  181. package/build/treb-calculator/src/utilities.js +324 -0
  182. package/build/treb-calculator/src/utilities.js.map +1 -0
  183. package/build/treb-charts/src/chart-functions.d.ts +8 -0
  184. package/build/treb-charts/src/chart-functions.js +209 -0
  185. package/build/treb-charts/src/chart-functions.js.map +1 -0
  186. package/build/treb-charts/src/chart-types.d.ts +233 -0
  187. package/build/treb-charts/src/chart-types.js +57 -0
  188. package/build/treb-charts/src/chart-types.js.map +1 -0
  189. package/build/treb-charts/src/chart-utils.d.ts +106 -0
  190. package/build/treb-charts/src/chart-utils.js +1060 -0
  191. package/build/treb-charts/src/chart-utils.js.map +1 -0
  192. package/build/treb-charts/src/chart.d.ts +23 -0
  193. package/build/treb-charts/src/chart.js +94 -0
  194. package/build/treb-charts/src/chart.js.map +1 -0
  195. package/build/treb-charts/src/default-chart-renderer.d.ts +16 -0
  196. package/build/treb-charts/src/default-chart-renderer.js +533 -0
  197. package/build/treb-charts/src/default-chart-renderer.js.map +1 -0
  198. package/build/treb-charts/src/index.d.ts +5 -0
  199. package/build/treb-charts/src/index.js +24 -0
  200. package/build/treb-charts/src/index.js.map +1 -0
  201. package/build/treb-charts/src/main.d.ts +1 -0
  202. package/build/treb-charts/src/main.js +34 -0
  203. package/build/treb-charts/src/main.js.map +1 -0
  204. package/build/treb-charts/src/quicksort.d.ts +1 -0
  205. package/build/treb-charts/src/quicksort.js +49 -0
  206. package/build/treb-charts/src/quicksort.js.map +1 -0
  207. package/build/treb-charts/src/rectangle.d.ts +18 -0
  208. package/build/treb-charts/src/rectangle.js +41 -0
  209. package/build/treb-charts/src/rectangle.js.map +1 -0
  210. package/build/treb-charts/src/renderer-type.d.ts +24 -0
  211. package/build/treb-charts/src/renderer-type.js +22 -0
  212. package/build/treb-charts/src/renderer-type.js.map +1 -0
  213. package/build/treb-charts/src/renderer.d.ts +127 -0
  214. package/build/treb-charts/src/renderer.js +1518 -0
  215. package/build/treb-charts/src/renderer.js.map +1 -0
  216. package/build/treb-charts/src/util.d.ts +18 -0
  217. package/build/treb-charts/src/util.js +71 -0
  218. package/build/treb-charts/src/util.js.map +1 -0
  219. package/build/treb-data-model/src/annotation.d.ts +167 -0
  220. package/build/treb-data-model/src/annotation.js +120 -0
  221. package/build/treb-data-model/src/annotation.js.map +1 -0
  222. package/build/treb-data-model/src/conditional_format.d.ts +155 -0
  223. package/build/treb-data-model/src/conditional_format.js +62 -0
  224. package/build/treb-data-model/src/conditional_format.js.map +1 -0
  225. package/build/treb-data-model/src/data-validation.d.ts +28 -0
  226. package/build/treb-data-model/src/data-validation.js +22 -0
  227. package/build/treb-data-model/src/data-validation.js.map +1 -0
  228. package/build/treb-data-model/src/data_model.d.ts +173 -0
  229. package/build/treb-data-model/src/data_model.js +637 -0
  230. package/build/treb-data-model/src/data_model.js.map +1 -0
  231. package/build/treb-data-model/src/index.d.ts +13 -0
  232. package/build/treb-data-model/src/index.js +28 -0
  233. package/build/treb-data-model/src/index.js.map +1 -0
  234. package/build/treb-data-model/src/language-model.d.ts +22 -0
  235. package/build/treb-data-model/src/language-model.js +22 -0
  236. package/build/treb-data-model/src/language-model.js.map +1 -0
  237. package/build/treb-data-model/src/named.d.ts +124 -0
  238. package/build/treb-data-model/src/named.js +372 -0
  239. package/build/treb-data-model/src/named.js.map +1 -0
  240. package/build/treb-data-model/src/serialize_options.d.ts +49 -0
  241. package/build/treb-data-model/src/serialize_options.js +22 -0
  242. package/build/treb-data-model/src/serialize_options.js.map +1 -0
  243. package/build/treb-data-model/src/sheet.d.ts +499 -0
  244. package/build/treb-data-model/src/sheet.js +2904 -0
  245. package/build/treb-data-model/src/sheet.js.map +1 -0
  246. package/build/treb-data-model/src/sheet_collection.d.ts +58 -0
  247. package/build/treb-data-model/src/sheet_collection.js +112 -0
  248. package/build/treb-data-model/src/sheet_collection.js.map +1 -0
  249. package/build/treb-data-model/src/sheet_selection.d.ts +42 -0
  250. package/build/treb-data-model/src/sheet_selection.js +39 -0
  251. package/build/treb-data-model/src/sheet_selection.js.map +1 -0
  252. package/build/treb-data-model/src/sheet_types.d.ts +104 -0
  253. package/build/treb-data-model/src/sheet_types.js +22 -0
  254. package/build/treb-data-model/src/sheet_types.js.map +1 -0
  255. package/build/treb-data-model/src/types.d.ts +59 -0
  256. package/build/treb-data-model/src/types.js +22 -0
  257. package/build/treb-data-model/src/types.js.map +1 -0
  258. package/build/treb-embed/src/custom-element/spreadsheet-constructor.d.ts +75 -0
  259. package/build/treb-embed/src/custom-element/spreadsheet-constructor.js +1144 -0
  260. package/build/treb-embed/src/custom-element/spreadsheet-constructor.js.map +1 -0
  261. package/build/treb-embed/src/custom-element/treb-global.d.ts +36 -0
  262. package/build/treb-embed/src/custom-element/treb-global.js +64 -0
  263. package/build/treb-embed/src/custom-element/treb-global.js.map +1 -0
  264. package/build/treb-embed/src/custom-element/treb-spreadsheet-element.d.ts +1 -0
  265. package/build/treb-embed/src/custom-element/treb-spreadsheet-element.js +61 -0
  266. package/build/treb-embed/src/custom-element/treb-spreadsheet-element.js.map +1 -0
  267. package/build/treb-embed/src/embedded-spreadsheet.d.ts +1358 -0
  268. package/build/treb-embed/src/embedded-spreadsheet.js +5205 -0
  269. package/build/treb-embed/src/embedded-spreadsheet.js.map +1 -0
  270. package/build/treb-embed/src/index.d.ts +12 -0
  271. package/build/treb-embed/src/index.js +34 -0
  272. package/build/treb-embed/src/index.js.map +1 -0
  273. package/build/treb-embed/src/options.d.ts +266 -0
  274. package/build/treb-embed/src/options.js +56 -0
  275. package/build/treb-embed/src/options.js.map +1 -0
  276. package/build/treb-embed/src/plugin.d.ts +9 -0
  277. package/build/treb-embed/src/plugin.js +22 -0
  278. package/build/treb-embed/src/plugin.js.map +1 -0
  279. package/build/treb-embed/src/progress-dialog.d.ts +49 -0
  280. package/build/treb-embed/src/progress-dialog.js +178 -0
  281. package/build/treb-embed/src/progress-dialog.js.map +1 -0
  282. package/build/treb-embed/src/selection-state.d.ts +15 -0
  283. package/build/treb-embed/src/selection-state.js +22 -0
  284. package/build/treb-embed/src/selection-state.js.map +1 -0
  285. package/build/treb-embed/src/spinner.d.ts +8 -0
  286. package/build/treb-embed/src/spinner.js +40 -0
  287. package/build/treb-embed/src/spinner.js.map +1 -0
  288. package/build/treb-embed/src/toolbar-message.d.ts +72 -0
  289. package/build/treb-embed/src/toolbar-message.js +22 -0
  290. package/build/treb-embed/src/toolbar-message.js.map +1 -0
  291. package/build/treb-embed/src/types.d.ts +185 -0
  292. package/build/treb-embed/src/types.js +45 -0
  293. package/build/treb-embed/src/types.js.map +1 -0
  294. package/build/treb-embed/tsconfig.tsbuildinfo +1 -0
  295. package/build/treb-export/src/address-type.d.ts +34 -0
  296. package/build/treb-export/src/address-type.js +53 -0
  297. package/build/treb-export/src/address-type.js.map +1 -0
  298. package/build/treb-export/src/base-template.d.ts +1 -0
  299. package/build/treb-export/src/base-template.js +22 -0
  300. package/build/treb-export/src/base-template.js.map +1 -0
  301. package/build/treb-export/src/column-width.d.ts +2 -0
  302. package/build/treb-export/src/column-width.js +80 -0
  303. package/build/treb-export/src/column-width.js.map +1 -0
  304. package/build/treb-export/src/drawing/bubble-chart-template.d.ts +514 -0
  305. package/build/treb-export/src/drawing/bubble-chart-template.js +544 -0
  306. package/build/treb-export/src/drawing/bubble-chart-template.js.map +1 -0
  307. package/build/treb-export/src/drawing/chart-template-components2.d.ts +365 -0
  308. package/build/treb-export/src/drawing/chart-template-components2.js +386 -0
  309. package/build/treb-export/src/drawing/chart-template-components2.js.map +1 -0
  310. package/build/treb-export/src/drawing/chart.d.ts +26 -0
  311. package/build/treb-export/src/drawing/chart.js +247 -0
  312. package/build/treb-export/src/drawing/chart.js.map +1 -0
  313. package/build/treb-export/src/drawing/column-chart-template2.d.ts +490 -0
  314. package/build/treb-export/src/drawing/column-chart-template2.js +518 -0
  315. package/build/treb-export/src/drawing/column-chart-template2.js.map +1 -0
  316. package/build/treb-export/src/drawing/donut-chart-template2.d.ts +272 -0
  317. package/build/treb-export/src/drawing/donut-chart-template2.js +293 -0
  318. package/build/treb-export/src/drawing/donut-chart-template2.js.map +1 -0
  319. package/build/treb-export/src/drawing/drawing.d.ts +49 -0
  320. package/build/treb-export/src/drawing/drawing.js +193 -0
  321. package/build/treb-export/src/drawing/drawing.js.map +1 -0
  322. package/build/treb-export/src/drawing/embedded-image.d.ts +12 -0
  323. package/build/treb-export/src/drawing/embedded-image.js +54 -0
  324. package/build/treb-export/src/drawing/embedded-image.js.map +1 -0
  325. package/build/treb-export/src/drawing/scatter-chart-template2.d.ts +520 -0
  326. package/build/treb-export/src/drawing/scatter-chart-template2.js +551 -0
  327. package/build/treb-export/src/drawing/scatter-chart-template2.js.map +1 -0
  328. package/build/treb-export/src/export.d.ts +72 -0
  329. package/build/treb-export/src/export.js +2039 -0
  330. package/build/treb-export/src/export.js.map +1 -0
  331. package/build/treb-export/src/import-export-messages.d.ts +31 -0
  332. package/build/treb-export/src/import-export-messages.js +22 -0
  333. package/build/treb-export/src/import-export-messages.js.map +1 -0
  334. package/build/treb-export/src/import.d.ts +33 -0
  335. package/build/treb-export/src/import.js +1258 -0
  336. package/build/treb-export/src/import.js.map +1 -0
  337. package/build/treb-export/src/index.worker.d.ts +1 -0
  338. package/build/treb-export/src/index.worker.js +93 -0
  339. package/build/treb-export/src/index.worker.js.map +1 -0
  340. package/build/treb-export/src/metadata.d.ts +51 -0
  341. package/build/treb-export/src/metadata.js +153 -0
  342. package/build/treb-export/src/metadata.js.map +1 -0
  343. package/build/treb-export/src/ooxml.d.ts +7 -0
  344. package/build/treb-export/src/ooxml.js +41 -0
  345. package/build/treb-export/src/ooxml.js.map +1 -0
  346. package/build/treb-export/src/relationship.d.ts +8 -0
  347. package/build/treb-export/src/relationship.js +27 -0
  348. package/build/treb-export/src/relationship.js.map +1 -0
  349. package/build/treb-export/src/shared-strings.d.ts +11 -0
  350. package/build/treb-export/src/shared-strings.js +105 -0
  351. package/build/treb-export/src/shared-strings.js.map +1 -0
  352. package/build/treb-export/src/template-2.d.ts +1 -0
  353. package/build/treb-export/src/template-2.js +22 -0
  354. package/build/treb-export/src/template-2.js.map +1 -0
  355. package/build/treb-export/src/unescape_xml.d.ts +1 -0
  356. package/build/treb-export/src/unescape_xml.js +61 -0
  357. package/build/treb-export/src/unescape_xml.js.map +1 -0
  358. package/build/treb-export/src/workbook-sheet.d.ts +75 -0
  359. package/build/treb-export/src/workbook-sheet.js +128 -0
  360. package/build/treb-export/src/workbook-sheet.js.map +1 -0
  361. package/build/treb-export/src/workbook-style.d.ts +110 -0
  362. package/build/treb-export/src/workbook-style.js +1134 -0
  363. package/build/treb-export/src/workbook-style.js.map +1 -0
  364. package/build/treb-export/src/workbook-theme.d.ts +13 -0
  365. package/build/treb-export/src/workbook-theme.js +85 -0
  366. package/build/treb-export/src/workbook-theme.js.map +1 -0
  367. package/build/treb-export/src/workbook.d.ts +123 -0
  368. package/build/treb-export/src/workbook.js +644 -0
  369. package/build/treb-export/src/workbook.js.map +1 -0
  370. package/build/treb-export/src/xml-test.d.ts +9 -0
  371. package/build/treb-export/src/xml-test.js +52 -0
  372. package/build/treb-export/src/xml-test.js.map +1 -0
  373. package/build/treb-export/src/xml-utils.d.ts +76 -0
  374. package/build/treb-export/src/xml-utils.js +223 -0
  375. package/build/treb-export/src/xml-utils.js.map +1 -0
  376. package/build/treb-export/src/zip-wrapper.d.ts +22 -0
  377. package/build/treb-export/src/zip-wrapper.js +93 -0
  378. package/build/treb-export/src/zip-wrapper.js.map +1 -0
  379. package/build/treb-format/src/format.d.ts +130 -0
  380. package/build/treb-format/src/format.js +805 -0
  381. package/build/treb-format/src/format.js.map +1 -0
  382. package/build/treb-format/src/format_cache.d.ts +55 -0
  383. package/build/treb-format/src/format_cache.js +166 -0
  384. package/build/treb-format/src/format_cache.js.map +1 -0
  385. package/build/treb-format/src/format_parser.d.ts +70 -0
  386. package/build/treb-format/src/format_parser.js +618 -0
  387. package/build/treb-format/src/format_parser.js.map +1 -0
  388. package/build/treb-format/src/index.d.ts +4 -0
  389. package/build/treb-format/src/index.js +25 -0
  390. package/build/treb-format/src/index.js.map +1 -0
  391. package/build/treb-format/src/number_format_section.d.ts +58 -0
  392. package/build/treb-format/src/number_format_section.js +78 -0
  393. package/build/treb-format/src/number_format_section.js.map +1 -0
  394. package/build/treb-format/src/value_parser.d.ts +48 -0
  395. package/build/treb-format/src/value_parser.js +244 -0
  396. package/build/treb-format/src/value_parser.js.map +1 -0
  397. package/build/treb-grid/src/editors/autocomplete.d.ts +39 -0
  398. package/build/treb-grid/src/editors/autocomplete.js +316 -0
  399. package/build/treb-grid/src/editors/autocomplete.js.map +1 -0
  400. package/build/treb-grid/src/editors/autocomplete_matcher.d.ts +74 -0
  401. package/build/treb-grid/src/editors/autocomplete_matcher.js +212 -0
  402. package/build/treb-grid/src/editors/autocomplete_matcher.js.map +1 -0
  403. package/build/treb-grid/src/editors/editor.d.ts +214 -0
  404. package/build/treb-grid/src/editors/editor.js +879 -0
  405. package/build/treb-grid/src/editors/editor.js.map +1 -0
  406. package/build/treb-grid/src/editors/external_editor.d.ts +11 -0
  407. package/build/treb-grid/src/editors/external_editor.js +118 -0
  408. package/build/treb-grid/src/editors/external_editor.js.map +1 -0
  409. package/build/treb-grid/src/editors/formula_bar.d.ts +85 -0
  410. package/build/treb-grid/src/editors/formula_bar.js +444 -0
  411. package/build/treb-grid/src/editors/formula_bar.js.map +1 -0
  412. package/build/treb-grid/src/editors/overlay_editor.d.ts +85 -0
  413. package/build/treb-grid/src/editors/overlay_editor.js +353 -0
  414. package/build/treb-grid/src/editors/overlay_editor.js.map +1 -0
  415. package/build/treb-grid/src/index.d.ts +12 -0
  416. package/build/treb-grid/src/index.js +28 -0
  417. package/build/treb-grid/src/index.js.map +1 -0
  418. package/build/treb-grid/src/layout/base_layout.d.ts +346 -0
  419. package/build/treb-grid/src/layout/base_layout.js +2050 -0
  420. package/build/treb-grid/src/layout/base_layout.js.map +1 -0
  421. package/build/treb-grid/src/layout/grid_layout.d.ts +19 -0
  422. package/build/treb-grid/src/layout/grid_layout.js +235 -0
  423. package/build/treb-grid/src/layout/grid_layout.js.map +1 -0
  424. package/build/treb-grid/src/layout/mock-layout.d.ts +10 -0
  425. package/build/treb-grid/src/layout/mock-layout.js +37 -0
  426. package/build/treb-grid/src/layout/mock-layout.js.map +1 -0
  427. package/build/treb-grid/src/render/selection-renderer.d.ts +97 -0
  428. package/build/treb-grid/src/render/selection-renderer.js +315 -0
  429. package/build/treb-grid/src/render/selection-renderer.js.map +1 -0
  430. package/build/treb-grid/src/render/svg_header_overlay.d.ts +20 -0
  431. package/build/treb-grid/src/render/svg_header_overlay.js +76 -0
  432. package/build/treb-grid/src/render/svg_header_overlay.js.map +1 -0
  433. package/build/treb-grid/src/render/svg_selection_block.d.ts +27 -0
  434. package/build/treb-grid/src/render/svg_selection_block.js +106 -0
  435. package/build/treb-grid/src/render/svg_selection_block.js.map +1 -0
  436. package/build/treb-grid/src/render/tile_renderer.d.ts +121 -0
  437. package/build/treb-grid/src/render/tile_renderer.js +1609 -0
  438. package/build/treb-grid/src/render/tile_renderer.js.map +1 -0
  439. package/build/treb-grid/src/types/border_constants.d.ts +9 -0
  440. package/build/treb-grid/src/types/border_constants.js +34 -0
  441. package/build/treb-grid/src/types/border_constants.js.map +1 -0
  442. package/build/treb-grid/src/types/clipboard_data.d.ts +11 -0
  443. package/build/treb-grid/src/types/clipboard_data.js +22 -0
  444. package/build/treb-grid/src/types/clipboard_data.js.map +1 -0
  445. package/build/treb-grid/src/types/clipboard_data2.d.ts +46 -0
  446. package/build/treb-grid/src/types/clipboard_data2.js +22 -0
  447. package/build/treb-grid/src/types/clipboard_data2.js.map +1 -0
  448. package/build/treb-grid/src/types/drag_mask.d.ts +10 -0
  449. package/build/treb-grid/src/types/drag_mask.js +78 -0
  450. package/build/treb-grid/src/types/drag_mask.js.map +1 -0
  451. package/build/treb-grid/src/types/external_editor_config.d.ts +33 -0
  452. package/build/treb-grid/src/types/external_editor_config.js +22 -0
  453. package/build/treb-grid/src/types/external_editor_config.js.map +1 -0
  454. package/build/treb-grid/src/types/grid.d.ts +806 -0
  455. package/build/treb-grid/src/types/grid.js +6410 -0
  456. package/build/treb-grid/src/types/grid.js.map +1 -0
  457. package/build/treb-grid/src/types/grid_base.d.ts +442 -0
  458. package/build/treb-grid/src/types/grid_base.js +3523 -0
  459. package/build/treb-grid/src/types/grid_base.js.map +1 -0
  460. package/build/treb-grid/src/types/grid_command.d.ts +408 -0
  461. package/build/treb-grid/src/types/grid_command.js +75 -0
  462. package/build/treb-grid/src/types/grid_command.js.map +1 -0
  463. package/build/treb-grid/src/types/grid_events.d.ts +93 -0
  464. package/build/treb-grid/src/types/grid_events.js +36 -0
  465. package/build/treb-grid/src/types/grid_events.js.map +1 -0
  466. package/build/treb-grid/src/types/grid_options.d.ts +50 -0
  467. package/build/treb-grid/src/types/grid_options.js +34 -0
  468. package/build/treb-grid/src/types/grid_options.js.map +1 -0
  469. package/build/treb-grid/src/types/scale-control.d.ts +21 -0
  470. package/build/treb-grid/src/types/scale-control.js +148 -0
  471. package/build/treb-grid/src/types/scale-control.js.map +1 -0
  472. package/build/treb-grid/src/types/set_range_options.d.ts +24 -0
  473. package/build/treb-grid/src/types/set_range_options.js +22 -0
  474. package/build/treb-grid/src/types/set_range_options.js.map +1 -0
  475. package/build/treb-grid/src/types/tab_bar.d.ts +84 -0
  476. package/build/treb-grid/src/types/tab_bar.js +426 -0
  477. package/build/treb-grid/src/types/tab_bar.js.map +1 -0
  478. package/build/treb-grid/src/types/tile.d.ts +29 -0
  479. package/build/treb-grid/src/types/tile.js +22 -0
  480. package/build/treb-grid/src/types/tile.js.map +1 -0
  481. package/build/treb-grid/src/types/update_flags.d.ts +48 -0
  482. package/build/treb-grid/src/types/update_flags.js +22 -0
  483. package/build/treb-grid/src/types/update_flags.js.map +1 -0
  484. package/build/treb-grid/src/util/fontmetrics.d.ts +21 -0
  485. package/build/treb-grid/src/util/fontmetrics.js +82 -0
  486. package/build/treb-grid/src/util/fontmetrics.js.map +1 -0
  487. package/build/treb-grid/src/util/ua.d.ts +33 -0
  488. package/build/treb-grid/src/util/ua.js +86 -0
  489. package/build/treb-grid/src/util/ua.js.map +1 -0
  490. package/build/treb-parser/src/csv-parser.d.ts +13 -0
  491. package/build/treb-parser/src/csv-parser.js +107 -0
  492. package/build/treb-parser/src/csv-parser.js.map +1 -0
  493. package/build/treb-parser/src/index.d.ts +4 -0
  494. package/build/treb-parser/src/index.js +25 -0
  495. package/build/treb-parser/src/index.js.map +1 -0
  496. package/build/treb-parser/src/md-parser.d.ts +97 -0
  497. package/build/treb-parser/src/md-parser.js +403 -0
  498. package/build/treb-parser/src/md-parser.js.map +1 -0
  499. package/build/treb-parser/src/parser-types.d.ts +345 -0
  500. package/build/treb-parser/src/parser-types.js +53 -0
  501. package/build/treb-parser/src/parser-types.js.map +1 -0
  502. package/build/treb-parser/src/parser.d.ts +422 -0
  503. package/build/treb-parser/src/parser.js +2418 -0
  504. package/build/treb-parser/src/parser.js.map +1 -0
  505. package/build/treb-utils/src/event_source.d.ts +34 -0
  506. package/build/treb-utils/src/event_source.js +110 -0
  507. package/build/treb-utils/src/event_source.js.map +1 -0
  508. package/build/treb-utils/src/ievent_source.d.ts +9 -0
  509. package/build/treb-utils/src/ievent_source.js +22 -0
  510. package/build/treb-utils/src/ievent_source.js.map +1 -0
  511. package/build/treb-utils/src/index.d.ts +6 -0
  512. package/build/treb-utils/src/index.js +30 -0
  513. package/build/treb-utils/src/index.js.map +1 -0
  514. package/build/treb-utils/src/measurement.d.ts +42 -0
  515. package/build/treb-utils/src/measurement.js +145 -0
  516. package/build/treb-utils/src/measurement.js.map +1 -0
  517. package/build/treb-utils/src/scale.d.ts +16 -0
  518. package/build/treb-utils/src/scale.js +106 -0
  519. package/build/treb-utils/src/scale.js.map +1 -0
  520. package/build/treb-utils/src/serialize_html.d.ts +5 -0
  521. package/build/treb-utils/src/serialize_html.js +128 -0
  522. package/build/treb-utils/src/serialize_html.js.map +1 -0
  523. package/build/treb-utils/src/validate_uri.d.ts +20 -0
  524. package/build/treb-utils/src/validate_uri.js +55 -0
  525. package/build/treb-utils/src/validate_uri.js.map +1 -0
  526. package/dist/{chunk-Z4XFMZ2X.mjs → chunk-E35ONJUS.mjs} +1 -1
  527. package/dist/treb-export-worker.mjs +2 -2
  528. package/dist/treb-spreadsheet.mjs +4 -4
  529. package/dist/treb.d.ts +1 -1
  530. package/esbuild-composite.mjs +5 -1
  531. package/package.json +67 -3
  532. package/treb-embed/src/custom-element/spreadsheet-constructor.ts +7 -3
  533. package/treb-embed/src/embedded-spreadsheet.ts +1 -1
  534. package/treb-grid/src/types/grid_options.ts +1 -1
  535. package/tsproject.json +1 -2
  536. package/dist/chunk-43DLP2OX.mjs +0 -11
  537. package/dist/chunk-4CKS56PE.mjs +0 -11
  538. package/dist/chunk-75PARUQE.mjs +0 -11
  539. package/dist/chunk-7QD63AZS.mjs +0 -24601
  540. package/dist/chunk-A55ARVRD.mjs +0 -11
  541. package/dist/chunk-DESAKYW4.mjs +0 -11
  542. package/dist/chunk-EQ2R5W6P.mjs +0 -24565
  543. package/dist/chunk-IYJU2J6D.mjs +0 -24601
  544. package/dist/chunk-KSJFPGXT.mjs +0 -11
  545. package/dist/chunk-MQK4DNXI.mjs +0 -11
  546. package/dist/chunk-ORQFKLXM.mjs +0 -24601
  547. package/dist/chunk-SFDNNDHY.mjs +0 -11
  548. package/dist/chunk-T47DX5MI.mjs +0 -11
  549. package/dist/chunk-T6ILBVEX.mjs +0 -11
  550. package/dist/chunk-TPRCDYYG.mjs +0 -11
  551. package/dist/chunk-YAHNOOHO.mjs +0 -11
  552. package/dist/chunk-YLCFKX2G.mjs +0 -24601
@@ -0,0 +1,989 @@
1
+ /*
2
+ * This file is part of TREB.
3
+ *
4
+ * TREB is free software: you can redistribute it and/or modify it under the
5
+ * terms of the GNU General Public License as published by the Free Software
6
+ * Foundation, either version 3 of the License, or (at your option) any
7
+ * later version.
8
+ *
9
+ * TREB is distributed in the hope that it will be useful, but WITHOUT ANY
10
+ * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
11
+ * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
12
+ * details.
13
+ *
14
+ * You should have received a copy of the GNU General Public License along
15
+ * with TREB. If not, see <https://www.gnu.org/licenses/>.
16
+ *
17
+ * Copyright 2022-2026 trebco, llc.
18
+ * info@treb.app
19
+ *
20
+ */
21
+ import * as Utils from '../utilities';
22
+ import { ValueError, ArgumentError, NAError } from '../function-error';
23
+ import { ValueType, ComplexOrReal } from 'treb-base-types';
24
+ import * as ComplexMath from '../complex-math';
25
+ import { BetaCDF, BetaPDF, InverseBeta, LnGamma } from './beta';
26
+ import { gamma_p } from './gamma';
27
+ import { InverseNormal } from './normal';
28
+ import { tCDF, tInverse, tPDF } from './students-t';
29
+ /** error function (for gaussian distribution) */
30
+ const erf = (x) => {
31
+ const a1 = 0.254829592;
32
+ const a2 = -0.284496736;
33
+ const a3 = 1.421413741;
34
+ const a4 = -1.453152027;
35
+ const a5 = 1.061405429;
36
+ const p = 0.3275911;
37
+ x = Math.abs(x);
38
+ const t = 1 / (1 + p * x);
39
+ return 1 - ((((((a5 * t + a4) * t) + a3) * t + a2) * t) + a1) * t * Math.exp(-1 * x * x);
40
+ };
41
+ const sqrt2pi = Math.sqrt(2 * Math.PI);
42
+ const norm_dist = (x, mean, stdev, cumulative) => {
43
+ let value = 0;
44
+ if (cumulative) {
45
+ const sign = (x < mean) ? -1 : 1;
46
+ value = 0.5 * (1.0 + sign * erf((Math.abs(x - mean)) / (stdev * Math.sqrt(2))));
47
+ }
48
+ else {
49
+ value = Math.exp(-1 / 2 * Math.pow((x - mean) / stdev, 2)) / (stdev * sqrt2pi);
50
+ }
51
+ return value;
52
+ };
53
+ const Median = (data) => {
54
+ const n = data.length;
55
+ if (n % 2) {
56
+ return data[Math.floor(n / 2)];
57
+ }
58
+ else {
59
+ return (data[n / 2] + data[n / 2 - 1]) / 2;
60
+ }
61
+ };
62
+ const InterpolatedQuartiles = (data, include_median = true) => {
63
+ data.sort((a, b) => a - b);
64
+ const n = data.length;
65
+ const interp = (p, base, skip) => {
66
+ const index = base * p + skip;
67
+ const offset = index % 1;
68
+ if (offset) {
69
+ const a = data[Math.floor(index)];
70
+ const b = data[Math.ceil(index)];
71
+ return a + (b - a) * offset;
72
+ }
73
+ else {
74
+ return data[index];
75
+ }
76
+ };
77
+ if (include_median) {
78
+ return [data[0], interp(.25, n - 1, 0), Median(data), interp(.75, n - 1, 0), data[n - 1]];
79
+ }
80
+ else {
81
+ if (n % 1) {
82
+ return [data[0], interp(.25, n - 2, 0), Median(data), interp(.75, n - 2, 1), data[n - 1]];
83
+ }
84
+ else {
85
+ return [data[0], interp(.25, n - 3, 0), Median(data), interp(.75, n - 3, 2), data[n - 1]];
86
+ }
87
+ }
88
+ };
89
+ /**
90
+ * this is a Lanczos approximation. could be cleaned up.
91
+ * @param z
92
+ * @returns
93
+ */
94
+ const Gamma = (z) => {
95
+ const coefficients = [
96
+ 0.99999999999980993,
97
+ 676.5203681218851,
98
+ -1259.1392167224028,
99
+ 771.32342877765313,
100
+ -176.61502916214059,
101
+ 12.507343278686905,
102
+ -0.13857109526572012,
103
+ 9.9843695780195716e-6,
104
+ 1.5056327351493116e-7
105
+ ];
106
+ // generally speaking I'm against operator overloading but
107
+ // it would be a big help for complex math
108
+ // how about a class based on the complex type? then you could
109
+ // use class methods on values. would be a little cleaner?
110
+ const pi = Math.PI;
111
+ const sin = ComplexMath.Sin;
112
+ const div = ComplexMath.Divide;
113
+ const mul = ComplexMath.Multiply;
114
+ const cpx = (a) => ({ real: a, imaginary: 0 });
115
+ const add = (a, b) => ({ real: a.real + b.real, imaginary: a.imaginary + b.imaginary });
116
+ const pow = ComplexMath.Power;
117
+ const exp = ComplexMath.Exp;
118
+ const inv = (a) => ({ real: -a.real, imaginary: -a.imaginary });
119
+ const prod = ComplexMath.Product;
120
+ if (z.real < 0.5) {
121
+ return div(cpx(pi), mul(sin(mul(cpx(pi), z)), Gamma({ real: 1 - z.real, imaginary: -z.imaginary })));
122
+ }
123
+ z.real -= 1;
124
+ let x = cpx(coefficients[0]);
125
+ for (let i = 1; i < coefficients.length; i++) {
126
+ x = add(x, div(cpx(coefficients[i]), add(z, cpx(i))));
127
+ }
128
+ const t = add(z, cpx(7.5));
129
+ return prod(cpx(Math.sqrt(2 * pi)), pow(t, add(z, cpx(0.5))), exp(inv(t)), x);
130
+ };
131
+ const GammaPDF = (x, alpha, beta) => {
132
+ const gamma_alpha = Gamma({ real: alpha, imaginary: 0 }).real;
133
+ return (Math.pow(x, alpha - 1) * Math.exp(-x / beta)) / (gamma_alpha * Math.pow(beta, alpha));
134
+ };
135
+ /** bisection */
136
+ const InverseGamma = (p, alpha, beta) => {
137
+ let lower = 0;
138
+ let upper = alpha * 10;
139
+ const tolerance = 1e-6;
140
+ let iterations = 0;
141
+ while (upper - lower > tolerance) {
142
+ iterations++;
143
+ const mid = (upper + lower) / 2;
144
+ const f_lower = gamma_p(alpha, lower / beta);
145
+ const f_mid = gamma_p(alpha, mid / beta);
146
+ if (f_lower === false || f_mid === false) {
147
+ return false;
148
+ }
149
+ if ((f_mid - p) * (f_lower - p) < 0) {
150
+ upper = mid;
151
+ }
152
+ else {
153
+ lower = mid;
154
+ }
155
+ }
156
+ return (lower + upper) / 2;
157
+ };
158
+ export const Variance = (data, sample = false) => {
159
+ const len = data.length;
160
+ let m = 0;
161
+ let v = 0;
162
+ // let k = 0;
163
+ // let s = 0;
164
+ for (let i = 0; i < len; i++)
165
+ m += data[i];
166
+ m /= len;
167
+ // const mean = m;
168
+ for (let i = 0; i < len; i++) {
169
+ const d = data[i] - m;
170
+ v += (d * d);
171
+ // s += (d * d * d);
172
+ // k += (d * d * d * d);
173
+ }
174
+ // const N = len;
175
+ // const variance = v / len;
176
+ // const stdev = Math.sqrt(v / len);
177
+ return sample ? (v / (len - 1)) : (v / len);
178
+ };
179
+ export const StatisticsFunctionLibrary = {
180
+ Slope: {
181
+ arguments: [
182
+ { name: 'known_y' },
183
+ { name: 'known_x' },
184
+ ],
185
+ fn: (y, x) => {
186
+ const flat_x = Utils.FlattenNumbers(x);
187
+ const flat_y = Utils.FlattenNumbers(y);
188
+ if (flat_x.length !== flat_y.length) {
189
+ return ArgumentError();
190
+ }
191
+ let sum_x = 0;
192
+ let sum_y = 0;
193
+ let sum_products = 0;
194
+ let sum_squared_x = 0;
195
+ for (let i = 0; i < flat_x.length; i++) {
196
+ const x = flat_x[i];
197
+ const y = flat_y[i];
198
+ sum_products += (x * y);
199
+ sum_x += x;
200
+ sum_y += y;
201
+ sum_squared_x += (x * x);
202
+ // sum_squared_y += (y * y);
203
+ }
204
+ const value = ((flat_x.length * sum_products) - (sum_x * sum_y)) /
205
+ ((flat_x.length * sum_squared_x) - (sum_x * sum_x));
206
+ return {
207
+ type: ValueType.number,
208
+ value,
209
+ };
210
+ },
211
+ },
212
+ Intercept: {
213
+ arguments: [
214
+ { name: 'known_y' },
215
+ { name: 'known_x' },
216
+ ],
217
+ fn: (y, x) => {
218
+ const flat_x = Utils.FlattenNumbers(x);
219
+ const flat_y = Utils.FlattenNumbers(y);
220
+ if (flat_x.length !== flat_y.length) {
221
+ return ArgumentError();
222
+ }
223
+ const N = flat_x.length;
224
+ let sum_x = 0;
225
+ let sum_y = 0;
226
+ let sum_products = 0;
227
+ let sum_squared_x = 0;
228
+ for (let i = 0; i < N; i++) {
229
+ const x = flat_x[i];
230
+ const y = flat_y[i];
231
+ sum_products += (x * y);
232
+ sum_x += x;
233
+ sum_y += y;
234
+ sum_squared_x += (x * x);
235
+ }
236
+ let m = ((N * sum_products) - (sum_x * sum_y));
237
+ m /= ((N * sum_squared_x) - (sum_x * sum_x));
238
+ return {
239
+ type: ValueType.number, value: (sum_y - (m * sum_x)) / N,
240
+ };
241
+ },
242
+ },
243
+ Phi: {
244
+ arguments: [
245
+ { name: 'x', boxed: true, unroll: true }
246
+ ],
247
+ fn: (x) => {
248
+ if (x.type === ValueType.number) {
249
+ return {
250
+ type: ValueType.number,
251
+ value: (1 / Math.sqrt(Math.PI * 2)) * Math.exp(-x.value * x.value / 2),
252
+ };
253
+ }
254
+ return ArgumentError();
255
+ }
256
+ },
257
+ 'Z.Test': {
258
+ arguments: [
259
+ { name: 'Array', boxed: true, },
260
+ { name: 'x', boxed: true, unroll: true, },
261
+ { name: 'Sigma', boxed: true, unroll: true, },
262
+ ],
263
+ fn: (array, x, sigma) => {
264
+ const data = [];
265
+ if (array.type === ValueType.array) {
266
+ for (const row of array.value) {
267
+ for (const cell of row) {
268
+ if (cell.type === ValueType.number) {
269
+ data.push(cell.value);
270
+ }
271
+ }
272
+ }
273
+ }
274
+ else if (array.type === ValueType.number) {
275
+ data.push(array.value);
276
+ }
277
+ if (data.length && x.type === ValueType.number) {
278
+ let average = 0;
279
+ const n = data.length;
280
+ for (const value of data) {
281
+ average += value;
282
+ }
283
+ average /= n;
284
+ const s = sigma?.type === ValueType.number ? sigma.value :
285
+ Math.sqrt(Variance(data, true));
286
+ return {
287
+ type: ValueType.number,
288
+ value: 1 - norm_dist((average - x.value) / (s / Math.sqrt(n)), 0, 1, true),
289
+ };
290
+ }
291
+ return ArgumentError();
292
+ },
293
+ },
294
+ 'Beta.Dist': {
295
+ description: 'beta distribution',
296
+ arguments: [
297
+ { name: 'x', unroll: true },
298
+ { name: 'a', },
299
+ { name: 'b', },
300
+ { name: 'cumulative', },
301
+ ],
302
+ fn: (x, a, b, cumulative) => {
303
+ if (a < 0 || b < 0) {
304
+ return ArgumentError();
305
+ }
306
+ if (cumulative) {
307
+ return {
308
+ type: ValueType.number,
309
+ value: BetaCDF(x, a, b),
310
+ };
311
+ }
312
+ else {
313
+ return {
314
+ type: ValueType.number,
315
+ value: BetaPDF(x, a, b),
316
+ };
317
+ }
318
+ return ArgumentError();
319
+ }
320
+ },
321
+ 'Beta.Inv': {
322
+ description: 'Inverse of the beta distribution',
323
+ arguments: [
324
+ { name: 'probability', unroll: true },
325
+ { name: 'a', },
326
+ { name: 'b', },
327
+ ],
328
+ fn: (x, a, b) => {
329
+ if (a < 0 || b < 0) {
330
+ return ArgumentError();
331
+ }
332
+ return {
333
+ type: ValueType.number,
334
+ value: InverseBeta(x, a, b),
335
+ };
336
+ }
337
+ },
338
+ Erf: {
339
+ fn: (a) => {
340
+ return { type: ValueType.number, value: erf(a) };
341
+ },
342
+ },
343
+ /* use alias instead
344
+ 'NormsInv': {
345
+
346
+ description: 'Inverse of the normal cumulative distribution',
347
+ arguments: [
348
+ {name: 'probability'},
349
+ ],
350
+
351
+ fn: (q: number): UnionValue => {
352
+ return {
353
+ type: ValueType.number,
354
+ value: inverse_normal(q),
355
+ }
356
+ }
357
+ },
358
+ */
359
+ 'Norm.Inv': {
360
+ description: 'Inverse of the normal cumulative distribution',
361
+ arguments: [
362
+ { name: 'probability' },
363
+ { name: 'mean', default: 0 },
364
+ { name: 'standard deviation', default: 1 },
365
+ ],
366
+ xlfn: true,
367
+ fn: (q, mean = 0, stdev = 1) => {
368
+ return {
369
+ type: ValueType.number,
370
+ value: InverseNormal(q) * stdev + mean,
371
+ };
372
+ }
373
+ },
374
+ 'Norm.S.Inv': {
375
+ description: 'Inverse of the standard normal cumulative distribution',
376
+ arguments: [
377
+ { name: 'probability', unroll: true },
378
+ ],
379
+ xlfn: true,
380
+ fn: (q) => {
381
+ return {
382
+ type: ValueType.number,
383
+ value: InverseNormal(q),
384
+ };
385
+ }
386
+ },
387
+ 'Norm.Dist': {
388
+ description: 'Cumulative normal distribution',
389
+ arguments: [
390
+ { name: 'value' },
391
+ { name: 'mean', default: 0 },
392
+ { name: 'standard deviation', default: 1 },
393
+ { name: 'cumulative', default: true },
394
+ ],
395
+ // this does need xlfn but it also requires four parameters
396
+ // (we have three and they are not required).
397
+ xlfn: true,
398
+ fn: (x, mean = 0, stdev = 1, cumulative = true) => {
399
+ return { type: ValueType.number, value: norm_dist(x, mean, stdev, cumulative) };
400
+ },
401
+ },
402
+ 'Norm.S.Dist': {
403
+ description: 'Cumulative normal distribution',
404
+ arguments: [
405
+ { name: 'value' },
406
+ { name: 'cumulative', default: true },
407
+ ],
408
+ xlfn: true,
409
+ fn: (x, cumulative = true) => {
410
+ return { type: ValueType.number, value: norm_dist(x, 0, 1, cumulative) };
411
+ },
412
+ },
413
+ 'StDev.P': {
414
+ description: 'Returns the standard deviation of a set of values, corresponding to a population',
415
+ arguments: [{ name: 'data', }],
416
+ fn: (...args) => {
417
+ return { type: ValueType.number, value: Math.sqrt(Variance(Utils.FlattenNumbers(args), false)) };
418
+ },
419
+ },
420
+ 'StDev.S': {
421
+ description: 'Returns the standard deviation of a set of values, corresponding to a sample of a population',
422
+ arguments: [{ name: 'data', }],
423
+ fn: (...args) => {
424
+ return { type: ValueType.number, value: Math.sqrt(Variance(Utils.FlattenNumbers(args), true)) };
425
+ },
426
+ },
427
+ 'Var.P': {
428
+ description: 'Returns the variance of a set of values, corresponding to a population',
429
+ arguments: [{ name: 'data', }],
430
+ fn: (...args) => {
431
+ return { type: ValueType.number, value: Variance(Utils.FlattenNumbers(args), false) };
432
+ },
433
+ },
434
+ 'Var.S': {
435
+ description: 'Returns the variance of a set of values, corresponding to a sample of a population',
436
+ arguments: [{ name: 'data', }],
437
+ fn: (...args) => {
438
+ return { type: ValueType.number, value: Variance(Utils.FlattenNumbers(args), true) };
439
+ },
440
+ },
441
+ Covar: {
442
+ description: 'Returns the covariance between two ranges of values',
443
+ arguments: [{
444
+ name: 'A',
445
+ }, {
446
+ name: 'B',
447
+ }],
448
+ fn: (x, y) => {
449
+ // both must be 2d arrays, we're assuming the same or mostly similar shape
450
+ if (!Array.isArray(x) || !Array.isArray(y)) {
451
+ return ValueError();
452
+ }
453
+ if (!Array.isArray(x[0]) || !Array.isArray(y[0])) {
454
+ return ValueError();
455
+ }
456
+ if (x.length !== y.length) {
457
+ return ArgumentError();
458
+ }
459
+ let sum = 0;
460
+ let length = 0;
461
+ const mean = { x: 0, y: 0 };
462
+ const data = { x: [], y: [] };
463
+ for (let j = 0; j < x.length; j++) {
464
+ if (!x[j] || !y[j]) {
465
+ continue;
466
+ }
467
+ if (x[j].length !== y[j].length) {
468
+ return ArgumentError();
469
+ }
470
+ const len = x[j].length;
471
+ length += len;
472
+ for (let i = 0; i < len; i++) {
473
+ mean.x += (x[j][i] || 0);
474
+ mean.y += (y[j][i] || 0);
475
+ data.x.push(x[j][i] || 0);
476
+ data.y.push(y[j][i] || 0);
477
+ }
478
+ }
479
+ if (length === 0) {
480
+ return NAError();
481
+ }
482
+ mean.x /= length;
483
+ mean.y /= length;
484
+ for (let i = 0; i < length; i++) {
485
+ sum += (data.x[i] - mean.x) * (data.y[i] - mean.y);
486
+ }
487
+ return { type: ValueType.number, value: sum / length, };
488
+ },
489
+ },
490
+ Correl: {
491
+ description: 'Returns the correlation between two ranges of values',
492
+ arguments: [{
493
+ name: 'A',
494
+ }, {
495
+ name: 'B',
496
+ }],
497
+ fn: (x, y) => {
498
+ // both must be 2d arrays, we're assuming the same or mostly similar shape
499
+ if (!Array.isArray(x) || !Array.isArray(y)) {
500
+ return ValueError();
501
+ }
502
+ if (!Array.isArray(x[0]) || !Array.isArray(y[0])) {
503
+ return ValueError();
504
+ }
505
+ let rslt = 0;
506
+ let sumProduct = 0;
507
+ let sumX = 0;
508
+ let sumY = 0;
509
+ let sumSquaredX = 0;
510
+ let sumSquaredY = 0;
511
+ let count = 0;
512
+ for (let j = 0; j < x.length; j++) {
513
+ if (!x[j] || !y[j]) {
514
+ continue;
515
+ }
516
+ const len = x[j].length;
517
+ for (let i = 0; i < len; i++) {
518
+ const a = Number(x[j][i]);
519
+ const b = Number(y[j][i]);
520
+ if (isNaN(a) || isNaN(b)) {
521
+ continue;
522
+ }
523
+ sumProduct += (a * b);
524
+ sumX += a;
525
+ sumY += b;
526
+ sumSquaredX += (a * a);
527
+ sumSquaredY += (b * b);
528
+ count++;
529
+ }
530
+ }
531
+ rslt = ((count * sumProduct) - (sumX * sumY));
532
+ if (rslt) {
533
+ rslt /= Math.sqrt(((count * sumSquaredX) - (sumX * sumX)) * ((count * sumSquaredY) - (sumY * sumY)));
534
+ }
535
+ return { type: ValueType.number, value: rslt };
536
+ },
537
+ },
538
+ GeoMean: {
539
+ description: 'Returns the geometric mean of all numeric arguments',
540
+ arguments: [{ boxed: true }],
541
+ fn: (...args) => {
542
+ args = Utils.FlattenBoxed(args);
543
+ let count = 0;
544
+ let product = { real: 1, imaginary: 0 };
545
+ let complex = false;
546
+ let negative = false;
547
+ for (const arg of args) {
548
+ if (arg.type === ValueType.complex) {
549
+ complex = true;
550
+ product = ComplexMath.Multiply(product, arg.value);
551
+ count++;
552
+ }
553
+ else if (arg.type === ValueType.number) {
554
+ if (arg.value < 0) {
555
+ negative = true;
556
+ }
557
+ count++;
558
+ // product = ComplexMath.Multiply(product, {real: arg.value, imaginary: 0});
559
+ product.real *= arg.value;
560
+ product.imaginary *= arg.value;
561
+ }
562
+ }
563
+ if (complex) {
564
+ const value = ComplexMath.Power(product, { real: 1 / count, imaginary: 0 });
565
+ if (value.imaginary) {
566
+ return { type: ValueType.complex, value };
567
+ }
568
+ return { type: ValueType.number, value: value.real };
569
+ }
570
+ else {
571
+ if (negative) {
572
+ return ValueError();
573
+ }
574
+ return { type: ValueType.number, value: Math.pow(product.real, 1 / count) };
575
+ }
576
+ /*
577
+ for (const arg of args) {
578
+ if (typeof arg === 'undefined') { continue; }
579
+ const value = Number(arg);
580
+ if (value < 0) { return ValueError(); }
581
+ count++;
582
+ product *= value;
583
+ }
584
+ return { type: ValueType.number, value: Math.pow(product, 1 / count) };
585
+ */
586
+ },
587
+ },
588
+ LCM: {
589
+ description: 'Retuns the least common mulitple of the arguments',
590
+ arguments: [{ boxed: true }],
591
+ fn: (...args) => {
592
+ args = Utils.FlattenBoxed(args);
593
+ const list = [];
594
+ for (const ref of args) {
595
+ if (ref.type === ValueType.error) {
596
+ return ref;
597
+ }
598
+ if (ref.type === ValueType.number) {
599
+ list.push(ref.value);
600
+ }
601
+ else if (ref.type !== ValueType.undefined) {
602
+ console.info("RT", ref.type);
603
+ return ArgumentError();
604
+ }
605
+ }
606
+ const gcd = (x, y) => {
607
+ if (x % y == 0) {
608
+ return y; // Base case
609
+ }
610
+ else {
611
+ return gcd(y, x % y); // Recusrsive case
612
+ }
613
+ };
614
+ if (list.length === 0) {
615
+ return { type: ValueType.number, value: 0 };
616
+ }
617
+ let lcm = list[0];
618
+ for (let i = 1; i < list.length; i++) {
619
+ lcm = (lcm * list[i]) / gcd(lcm, list[i]);
620
+ }
621
+ return {
622
+ type: ValueType.number,
623
+ value: lcm,
624
+ };
625
+ },
626
+ },
627
+ 'Gamma.Inv': {
628
+ description: 'Returns the inverse of the gamma distribution',
629
+ arguments: [
630
+ { name: 'probability', unroll: true },
631
+ { name: 'alpha', },
632
+ { name: 'beta', },
633
+ ],
634
+ fn: (p, alpha, beta) => {
635
+ if (p < 0 || p > 1) {
636
+ return ArgumentError();
637
+ }
638
+ const value = InverseGamma(p, alpha, beta);
639
+ if (value === false) {
640
+ return ValueError();
641
+ }
642
+ return {
643
+ type: ValueType.number,
644
+ value,
645
+ };
646
+ },
647
+ },
648
+ 'Gamma.Dist': {
649
+ fn: (x, alpha, beta, cumulative) => {
650
+ if (x < 0 || alpha <= 0 || beta <= 0) {
651
+ return ArgumentError();
652
+ }
653
+ const value = cumulative ? gamma_p(alpha, x / beta) : GammaPDF(x, alpha, beta);
654
+ if (value === false) {
655
+ return ValueError();
656
+ }
657
+ return {
658
+ type: ValueType.number,
659
+ value,
660
+ };
661
+ }
662
+ },
663
+ 'T.DIST': {
664
+ description: `Returns the left-tailed Student's t-distribution`,
665
+ arguments: [
666
+ { name: 'X', unroll: true, boxed: true, },
667
+ { name: 'degrees of freedom', unroll: true, boxed: true, },
668
+ { name: 'cumulative', unroll: true, boxed: true, },
669
+ ],
670
+ fn: (x, df, cumulative) => {
671
+ const cum = cumulative ? !!cumulative.value : false;
672
+ if (df.type !== ValueType.number || x.type !== ValueType.number || df.value < 1) {
673
+ return ArgumentError();
674
+ }
675
+ return {
676
+ type: ValueType.number,
677
+ value: cum ? tCDF(x.value, df.value) : tPDF(x.value, df.value),
678
+ };
679
+ },
680
+ },
681
+ 'T.Inv': {
682
+ description: `Returns the left-tailed inverse of the Student's t-distribution`,
683
+ arguments: [
684
+ {
685
+ name: 'Probability', boxed: true, unroll: true,
686
+ },
687
+ {
688
+ name: 'Degrees of freedom', boxed: true, unroll: true,
689
+ },
690
+ ],
691
+ fn: (p, df) => {
692
+ if (df.type !== ValueType.number || df.value < 1 || p.type !== ValueType.number || p.value <= 0 || p.value >= 1) {
693
+ return ArgumentError();
694
+ }
695
+ return {
696
+ type: ValueType.number,
697
+ value: tInverse(p.value, df.value),
698
+ };
699
+ },
700
+ },
701
+ 'T.Inv.2T': {
702
+ description: `Returns the two-tailed inverse of the Student's t-distribution`,
703
+ arguments: [
704
+ {
705
+ name: 'Probability', boxed: true, unroll: true,
706
+ },
707
+ {
708
+ name: 'Degrees of freedom', boxed: true, unroll: true,
709
+ },
710
+ ],
711
+ fn: (p, df) => {
712
+ if (df.type !== ValueType.number || df.value < 1 || p.type !== ValueType.number || p.value <= 0 || p.value >= 1) {
713
+ return ArgumentError();
714
+ }
715
+ return {
716
+ type: ValueType.number,
717
+ value: Math.abs(tInverse(1 - p.value / 2, df.value)),
718
+ };
719
+ },
720
+ },
721
+ GammaLn: {
722
+ description: 'Returns the natural log of the gamma function',
723
+ arguments: [{ name: 'value', boxed: true, unroll: true }],
724
+ fn: (value) => {
725
+ if (value.type === ValueType.number) {
726
+ return {
727
+ type: ValueType.number,
728
+ value: LnGamma(value.value),
729
+ };
730
+ }
731
+ return ArgumentError();
732
+ },
733
+ },
734
+ 'GammaLn.Precise': {
735
+ description: 'Returns the natural log of the gamma function',
736
+ arguments: [{ name: 'value', boxed: true, unroll: true }],
737
+ fn: (value) => {
738
+ let cpx;
739
+ if (value.type === ValueType.number) {
740
+ cpx = { real: value.value, imaginary: 0 };
741
+ }
742
+ else if (value.type === ValueType.complex) {
743
+ cpx = value.value;
744
+ }
745
+ if (cpx) {
746
+ const gamma = Gamma(cpx);
747
+ return ComplexOrReal(ComplexMath.Log(gamma));
748
+ }
749
+ return ArgumentError();
750
+ },
751
+ },
752
+ Gamma: {
753
+ description: 'Returns the gamma function for the given value',
754
+ arguments: [{ name: 'value', boxed: true, unroll: true }],
755
+ fn: (value) => {
756
+ let complex = { real: 0, imaginary: 0 };
757
+ if (value.type === ValueType.complex) {
758
+ complex = { ...value.value };
759
+ }
760
+ else if (value.type === ValueType.number) {
761
+ complex.real = value.value;
762
+ }
763
+ else {
764
+ return ArgumentError();
765
+ }
766
+ if (complex.imaginary === 0 && complex.real % 1 === 0 && complex.real <= 0) {
767
+ return ValueError();
768
+ }
769
+ const gamma = Gamma(complex);
770
+ if (Math.abs(gamma.imaginary) <= 1e-7) {
771
+ return { type: ValueType.number, value: gamma.real };
772
+ }
773
+ return { type: ValueType.complex, value: gamma };
774
+ },
775
+ },
776
+ Delta: {
777
+ arguments: [{ name: 'number', }, { name: 'number', default: 0 }],
778
+ fn: (a, b = 0) => {
779
+ if (typeof a !== 'number' || typeof b !== 'number') {
780
+ return ValueError();
781
+ }
782
+ return { type: ValueType.number, value: (a === b) ? 1 : 0 };
783
+ },
784
+ },
785
+ GCD: {
786
+ description: 'Finds the greatest common divisor of the arguments',
787
+ arguments: [{ boxed: true }],
788
+ fn: (...args) => {
789
+ args = Utils.FlattenBoxed(args);
790
+ const list = [];
791
+ for (const ref of args) {
792
+ if (ref.type === ValueType.error) {
793
+ return ref;
794
+ }
795
+ if (ref.type === ValueType.number) {
796
+ list.push(ref.value);
797
+ }
798
+ else if (ref.type !== ValueType.undefined) {
799
+ console.info("RT", ref.type);
800
+ return ArgumentError();
801
+ }
802
+ }
803
+ const gcd = (x, y) => {
804
+ if (x % y == 0) {
805
+ return y; // Base case
806
+ }
807
+ else {
808
+ return gcd(y, x % y); // Recusrsive case
809
+ }
810
+ };
811
+ if (list.length === 0) {
812
+ return ValueError();
813
+ }
814
+ if (list.length === 1) {
815
+ return {
816
+ type: ValueType.number,
817
+ value: list[0],
818
+ };
819
+ }
820
+ let value = list[0];
821
+ for (let i = 1; i < list.length; i++) {
822
+ value = gcd(value, list[i]);
823
+ }
824
+ return {
825
+ type: ValueType.number,
826
+ value,
827
+ };
828
+ }
829
+ },
830
+ HarMean: {
831
+ description: 'Returns the harmonic mean of the arguments',
832
+ arguments: [{ boxed: true }],
833
+ fn: (...args) => {
834
+ args = Utils.FlattenBoxed(args);
835
+ const result = { real: 0, imaginary: 0 };
836
+ let count = 0;
837
+ for (const ref of args) {
838
+ if (ref.type === ValueType.error) {
839
+ return ref;
840
+ }
841
+ if (ref.type === ValueType.number) {
842
+ result.real += (1 / ref.value);
843
+ count++;
844
+ }
845
+ if (ref.type === ValueType.complex) {
846
+ const reciprocal = ComplexMath.Divide({ real: 1, imaginary: 0 }, ref.value);
847
+ result.real += reciprocal.real;
848
+ result.imaginary += reciprocal.imaginary;
849
+ count++;
850
+ }
851
+ }
852
+ if (result.imaginary) {
853
+ return { type: ValueType.complex, value: ComplexMath.Divide({ real: count, imaginary: 0 }, result), };
854
+ }
855
+ return { type: ValueType.number, value: count / result.real };
856
+ },
857
+ },
858
+ Average: {
859
+ description: 'Returns the arithmetic mean of all numeric arguments',
860
+ arguments: [{ boxed: true }],
861
+ fn: (...args) => {
862
+ args = Utils.FlattenBoxed(args);
863
+ const result = { real: 0, imaginary: 0 };
864
+ let count = 0;
865
+ for (const ref of args) {
866
+ if (ref.type === ValueType.error) {
867
+ return ref;
868
+ }
869
+ if (ref.type === ValueType.number) {
870
+ result.real += ref.value;
871
+ count++;
872
+ }
873
+ if (ref.type === ValueType.complex) {
874
+ result.real += ref.value.real;
875
+ result.imaginary += ref.value.imaginary;
876
+ count++;
877
+ }
878
+ }
879
+ result.real /= count;
880
+ result.imaginary /= count;
881
+ if (result.imaginary) {
882
+ return { type: ValueType.complex, value: result, };
883
+ }
884
+ return { type: ValueType.number, value: result.real };
885
+ },
886
+ },
887
+ Percentile: {
888
+ description: 'Returns the kth percentile value from the range of data',
889
+ arguments: [
890
+ { name: 'range' },
891
+ { name: 'percentile' },
892
+ ],
893
+ fn: (range, percentile) => {
894
+ // const flat = Utils.FlattenCellValues(range).filter((test): test is number => typeof test === 'number');
895
+ const flat = Utils.FlattenNumbers(range);
896
+ flat.sort((a, b) => a - b);
897
+ const n = flat.length;
898
+ // try to stabilize this number
899
+ const factor = Math.pow(10, 8);
900
+ const x = Math.round((1 + (n - 1) * percentile) * factor) / factor;
901
+ const lo = Math.floor(x);
902
+ const hi = Math.ceil(x);
903
+ return { type: ValueType.number, value: (flat[lo - 1] + flat[hi - 1]) / 2 };
904
+ },
905
+ },
906
+ 'Quartile.Inc': {
907
+ description: 'Returns the interpolated quartile of the data set (including median)',
908
+ arguments: [
909
+ { name: 'range', },
910
+ { name: 'quartile' },
911
+ ],
912
+ xlfn: true,
913
+ fn: (data, quartile) => {
914
+ if (typeof quartile !== 'number' || quartile < 0 || quartile > 4 || quartile % 1) {
915
+ return ArgumentError();
916
+ }
917
+ const flat = Utils.FlattenNumbers(data);
918
+ const quartiles = InterpolatedQuartiles(flat, true);
919
+ return { type: ValueType.number, value: quartiles[quartile] };
920
+ }
921
+ },
922
+ 'Quartile.Exc': {
923
+ description: 'Returns the interpolated quartile of the data set (excluding median)',
924
+ arguments: [
925
+ { name: 'range', },
926
+ { name: 'quartile' },
927
+ ],
928
+ xlfn: true,
929
+ fn: (data, quartile) => {
930
+ if (typeof quartile !== 'number' || quartile < 1 || quartile > 3 || quartile % 1) {
931
+ return ArgumentError();
932
+ }
933
+ const flat = Utils.FlattenNumbers(data);
934
+ const quartiles = InterpolatedQuartiles(flat, false);
935
+ return { type: ValueType.number, value: quartiles[quartile] };
936
+ }
937
+ },
938
+ Median: {
939
+ description: 'Returns the median value of the range of data',
940
+ arguments: [
941
+ { name: 'range' },
942
+ ],
943
+ fn: (...args) => {
944
+ // const flat = Utils.FlattenCellValues(args).filter((test): test is number => typeof test === 'number');
945
+ const flat = Utils.FlattenNumbers(args);
946
+ flat.sort((a, b) => a - b);
947
+ const n = flat.length;
948
+ const x = 1 + (n - 1) * .5;
949
+ const lo = Math.floor(x);
950
+ const hi = Math.ceil(x);
951
+ return { type: ValueType.number, value: (flat[lo - 1] + flat[hi - 1]) / 2 };
952
+ },
953
+ },
954
+ Rank: {
955
+ arguments: [
956
+ { name: 'Value', },
957
+ { name: 'Source', },
958
+ { name: 'Order', },
959
+ ],
960
+ fn: (value, source, order = 0) => {
961
+ if (typeof value !== 'number') {
962
+ return ArgumentError();
963
+ }
964
+ const numbers = Utils.FlattenNumbers(source);
965
+ numbers.sort(order ? (a, b) => a - b : (a, b) => b - a);
966
+ for (let i = 0; i < numbers.length; i++) {
967
+ if (numbers[i] === value) {
968
+ return {
969
+ type: ValueType.number,
970
+ value: i + 1,
971
+ };
972
+ }
973
+ }
974
+ return ValueError();
975
+ },
976
+ },
977
+ };
978
+ export const StatisticsFunctionAliases = {
979
+ Mean: 'Average',
980
+ 'StDev': 'StDev.S',
981
+ 'StDevA': 'StDev.S',
982
+ 'StDevPA': 'StDev.P',
983
+ 'Var': 'Var.S',
984
+ 'Quartile': 'Quartile.Inc',
985
+ 'NormSInv': 'Norm.S.Inv',
986
+ 'NormSDist': 'Norm.S.Dist',
987
+ 'NormDist': 'Norm.Dist',
988
+ };
989
+ //# sourceMappingURL=statistics-functions.js.map