mathjs 10.6.4 → 11.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (454) hide show
  1. package/HISTORY.md +79 -1
  2. package/README.md +1 -1
  3. package/lib/browser/math.js +2 -41
  4. package/lib/browser/math.js.LICENSE.txt +43 -0
  5. package/lib/browser/math.js.map +1 -1
  6. package/lib/cjs/core/create.js +6 -5
  7. package/lib/cjs/core/function/import.js +4 -14
  8. package/lib/cjs/core/function/typed.js +54 -12
  9. package/lib/cjs/defaultInstance.js +3 -3
  10. package/lib/cjs/entry/allFactoriesAny.js +1 -1
  11. package/lib/cjs/entry/allFactoriesNumber.js +1 -1
  12. package/lib/cjs/entry/configReadonly.js +1 -1
  13. package/lib/cjs/entry/dependenciesAny/dependenciesChainClass.generated.js +3 -0
  14. package/lib/cjs/entry/dependenciesAny/dependenciesKldivergence.generated.js +3 -0
  15. package/lib/cjs/entry/dependenciesAny/dependenciesRationalize.generated.js +3 -0
  16. package/lib/cjs/entry/dependenciesAny/dependenciesResolve.generated.js +3 -0
  17. package/lib/cjs/entry/dependenciesAny/dependenciesSimplify.generated.js +3 -0
  18. package/lib/cjs/entry/dependenciesAny/dependenciesSimplifyConstant.generated.js +56 -0
  19. package/lib/cjs/entry/dependenciesAny/dependenciesSimplifyCore.generated.js +6 -0
  20. package/lib/cjs/entry/dependenciesAny/dependenciesSqrtm.generated.js +3 -0
  21. package/lib/cjs/entry/dependenciesAny/dependenciesStd.generated.js +3 -0
  22. package/lib/cjs/entry/dependenciesAny/dependenciesStdTransform.generated.js +3 -0
  23. package/lib/cjs/entry/dependenciesAny.generated.js +8 -0
  24. package/lib/cjs/entry/dependenciesNumber/dependenciesChainClass.generated.js +3 -0
  25. package/lib/cjs/entry/dependenciesNumber/dependenciesRationalize.generated.js +3 -0
  26. package/lib/cjs/entry/dependenciesNumber/dependenciesResolve.generated.js +3 -0
  27. package/lib/cjs/entry/dependenciesNumber/dependenciesSimplify.generated.js +3 -0
  28. package/lib/cjs/entry/dependenciesNumber/dependenciesSimplifyConstant.generated.js +50 -0
  29. package/lib/cjs/entry/dependenciesNumber/dependenciesSimplifyCore.generated.js +6 -0
  30. package/lib/cjs/entry/dependenciesNumber/dependenciesStd.generated.js +3 -0
  31. package/lib/cjs/entry/dependenciesNumber/dependenciesStdTransform.generated.js +3 -0
  32. package/lib/cjs/entry/dependenciesNumber.generated.js +8 -0
  33. package/lib/cjs/entry/impureFunctionsAny.generated.js +87 -61
  34. package/lib/cjs/entry/impureFunctionsNumber.generated.js +93 -69
  35. package/lib/cjs/entry/pureFunctionsAny.generated.js +50 -45
  36. package/lib/cjs/entry/pureFunctionsNumber.generated.js +22 -19
  37. package/lib/cjs/expression/Parser.js +1 -1
  38. package/lib/cjs/expression/embeddedDocs/construction/index.js +1 -1
  39. package/lib/cjs/expression/embeddedDocs/embeddedDocs.js +8 -5
  40. package/lib/cjs/expression/embeddedDocs/function/algebra/simplifyConstant.js +15 -0
  41. package/lib/cjs/expression/embeddedDocs/function/algebra/simplifyCore.js +1 -1
  42. package/lib/cjs/expression/node/AccessorNode.js +216 -173
  43. package/lib/cjs/expression/node/ArrayNode.js +206 -160
  44. package/lib/cjs/expression/node/AssignmentNode.js +321 -270
  45. package/lib/cjs/expression/node/BlockNode.js +223 -172
  46. package/lib/cjs/expression/node/ConditionalNode.js +253 -193
  47. package/lib/cjs/expression/node/ConstantNode.js +216 -171
  48. package/lib/cjs/expression/node/FunctionAssignmentNode.js +258 -196
  49. package/lib/cjs/expression/node/FunctionNode.js +456 -416
  50. package/lib/cjs/expression/node/IndexNode.js +256 -210
  51. package/lib/cjs/expression/node/Node.js +411 -378
  52. package/lib/cjs/expression/node/ObjectNode.js +223 -178
  53. package/lib/cjs/expression/node/OperatorNode.js +474 -397
  54. package/lib/cjs/expression/node/ParenthesisNode.js +189 -143
  55. package/lib/cjs/expression/node/RangeNode.js +272 -224
  56. package/lib/cjs/expression/node/RelationalNode.js +246 -195
  57. package/lib/cjs/expression/node/SymbolNode.js +219 -172
  58. package/lib/cjs/expression/node/utils/access.js +1 -1
  59. package/lib/cjs/expression/node/utils/assign.js +1 -1
  60. package/lib/cjs/expression/operators.js +117 -23
  61. package/lib/cjs/expression/parse.js +37 -19
  62. package/lib/cjs/expression/transform/std.transform.js +3 -1
  63. package/lib/cjs/factoriesAny.js +8 -0
  64. package/lib/cjs/factoriesNumber.js +10 -1
  65. package/lib/cjs/function/algebra/decomposition/qr.js +1 -1
  66. package/lib/cjs/function/algebra/derivative.js +25 -33
  67. package/lib/cjs/function/algebra/leafCount.js +0 -3
  68. package/lib/cjs/function/algebra/rationalize.js +78 -108
  69. package/lib/cjs/function/algebra/resolve.js +53 -16
  70. package/lib/cjs/function/algebra/simplify/util.js +1 -1
  71. package/lib/cjs/function/algebra/simplify.js +90 -115
  72. package/lib/cjs/function/algebra/{simplify/simplifyConstant.js → simplifyConstant.js} +44 -10
  73. package/lib/cjs/function/algebra/simplifyCore.js +196 -93
  74. package/lib/cjs/function/algebra/solver/lsolveAll.js +2 -2
  75. package/lib/cjs/function/algebra/solver/usolveAll.js +2 -2
  76. package/lib/cjs/function/algebra/symbolicEqual.js +14 -32
  77. package/lib/cjs/function/arithmetic/abs.js +7 -14
  78. package/lib/cjs/function/arithmetic/add.js +26 -70
  79. package/lib/cjs/function/arithmetic/addScalar.js +17 -9
  80. package/lib/cjs/function/arithmetic/cbrt.js +7 -11
  81. package/lib/cjs/function/arithmetic/ceil.js +50 -40
  82. package/lib/cjs/function/arithmetic/cube.js +5 -10
  83. package/lib/cjs/function/arithmetic/divide.js +7 -7
  84. package/lib/cjs/function/arithmetic/divideScalar.js +4 -18
  85. package/lib/cjs/function/arithmetic/dotDivide.js +22 -65
  86. package/lib/cjs/function/arithmetic/dotMultiply.js +16 -61
  87. package/lib/cjs/function/arithmetic/dotPow.js +30 -63
  88. package/lib/cjs/function/arithmetic/exp.js +8 -12
  89. package/lib/cjs/function/arithmetic/expm1.js +10 -10
  90. package/lib/cjs/function/arithmetic/fix.js +34 -28
  91. package/lib/cjs/function/arithmetic/floor.js +51 -41
  92. package/lib/cjs/function/arithmetic/gcd.js +27 -68
  93. package/lib/cjs/function/arithmetic/hypot.js +9 -5
  94. package/lib/cjs/function/arithmetic/invmod.js +2 -2
  95. package/lib/cjs/function/arithmetic/lcm.js +27 -68
  96. package/lib/cjs/function/arithmetic/log.js +10 -12
  97. package/lib/cjs/function/arithmetic/log10.js +5 -3
  98. package/lib/cjs/function/arithmetic/log1p.js +11 -7
  99. package/lib/cjs/function/arithmetic/log2.js +5 -3
  100. package/lib/cjs/function/arithmetic/mod.js +22 -64
  101. package/lib/cjs/function/arithmetic/multiply.js +40 -35
  102. package/lib/cjs/function/arithmetic/multiplyScalar.js +2 -9
  103. package/lib/cjs/function/arithmetic/norm.js +1 -5
  104. package/lib/cjs/function/arithmetic/nthRoot.js +83 -95
  105. package/lib/cjs/function/arithmetic/nthRoots.js +2 -2
  106. package/lib/cjs/function/arithmetic/round.js +56 -42
  107. package/lib/cjs/function/arithmetic/sign.js +14 -10
  108. package/lib/cjs/function/arithmetic/sqrt.js +5 -9
  109. package/lib/cjs/function/arithmetic/square.js +6 -10
  110. package/lib/cjs/function/arithmetic/subtract.js +44 -100
  111. package/lib/cjs/function/arithmetic/unaryMinus.js +14 -16
  112. package/lib/cjs/function/arithmetic/unaryPlus.js +6 -4
  113. package/lib/cjs/function/bitwise/bitAnd.js +17 -61
  114. package/lib/cjs/function/bitwise/bitNot.js +6 -4
  115. package/lib/cjs/function/bitwise/bitOr.js +16 -60
  116. package/lib/cjs/function/bitwise/bitXor.js +17 -61
  117. package/lib/cjs/function/bitwise/leftShift.js +69 -82
  118. package/lib/cjs/function/bitwise/rightArithShift.js +69 -82
  119. package/lib/cjs/function/bitwise/rightLogShift.js +69 -82
  120. package/lib/cjs/function/bitwise/useMatrixForArrayScalar.js +36 -0
  121. package/lib/cjs/function/complex/arg.js +5 -3
  122. package/lib/cjs/function/complex/conj.js +6 -7
  123. package/lib/cjs/function/complex/im.js +7 -8
  124. package/lib/cjs/function/complex/re.js +6 -10
  125. package/lib/cjs/function/geometry/distance.js +2 -2
  126. package/lib/cjs/function/logical/and.js +74 -80
  127. package/lib/cjs/function/logical/not.js +13 -6
  128. package/lib/cjs/function/logical/or.js +21 -63
  129. package/lib/cjs/function/logical/xor.js +21 -63
  130. package/lib/cjs/function/matrix/diff.js +11 -8
  131. package/lib/cjs/function/matrix/eigs/complexEigs.js +5 -5
  132. package/lib/cjs/function/matrix/fft.js +2 -2
  133. package/lib/cjs/function/matrix/matrixFromColumns.js +1 -1
  134. package/lib/cjs/function/matrix/matrixFromRows.js +1 -1
  135. package/lib/cjs/function/matrix/ones.js +2 -1
  136. package/lib/cjs/function/matrix/rotate.js +5 -5
  137. package/lib/cjs/function/matrix/sqrtm.js +3 -2
  138. package/lib/cjs/function/matrix/transpose.js +47 -48
  139. package/lib/cjs/function/matrix/zeros.js +2 -1
  140. package/lib/cjs/function/probability/factorial.js +5 -3
  141. package/lib/cjs/function/probability/gamma.js +38 -40
  142. package/lib/cjs/function/probability/kldivergence.js +5 -2
  143. package/lib/cjs/function/probability/lgamma.js +30 -30
  144. package/lib/cjs/function/probability/util/seededRNG.js +2 -2
  145. package/lib/cjs/function/relational/compare.js +21 -67
  146. package/lib/cjs/function/relational/compareNatural.js +59 -54
  147. package/lib/cjs/function/relational/compareText.js +10 -43
  148. package/lib/cjs/function/relational/compareUnits.js +24 -0
  149. package/lib/cjs/function/relational/equal.js +19 -80
  150. package/lib/cjs/function/relational/equalScalar.js +7 -9
  151. package/lib/cjs/function/relational/larger.js +21 -67
  152. package/lib/cjs/function/relational/largerEq.js +21 -67
  153. package/lib/cjs/function/relational/smaller.js +21 -67
  154. package/lib/cjs/function/relational/smallerEq.js +21 -67
  155. package/lib/cjs/function/relational/unequal.js +19 -80
  156. package/lib/cjs/function/special/erf.js +5 -3
  157. package/lib/cjs/function/statistics/std.js +11 -2
  158. package/lib/cjs/function/string/format.js +2 -2
  159. package/lib/cjs/function/string/hex.js +1 -2
  160. package/lib/cjs/function/trigonometry/acos.js +4 -8
  161. package/lib/cjs/function/trigonometry/acosh.js +2 -7
  162. package/lib/cjs/function/trigonometry/acot.js +6 -11
  163. package/lib/cjs/function/trigonometry/acoth.js +4 -8
  164. package/lib/cjs/function/trigonometry/acsc.js +6 -11
  165. package/lib/cjs/function/trigonometry/acsch.js +4 -8
  166. package/lib/cjs/function/trigonometry/asec.js +6 -10
  167. package/lib/cjs/function/trigonometry/asech.js +4 -8
  168. package/lib/cjs/function/trigonometry/asin.js +5 -10
  169. package/lib/cjs/function/trigonometry/asinh.js +4 -9
  170. package/lib/cjs/function/trigonometry/atan.js +5 -11
  171. package/lib/cjs/function/trigonometry/atan2.js +25 -63
  172. package/lib/cjs/function/trigonometry/atanh.js +4 -9
  173. package/lib/cjs/function/trigonometry/cos.js +11 -20
  174. package/lib/cjs/function/trigonometry/cosh.js +5 -19
  175. package/lib/cjs/function/trigonometry/cot.js +9 -15
  176. package/lib/cjs/function/trigonometry/coth.js +4 -15
  177. package/lib/cjs/function/trigonometry/csc.js +11 -17
  178. package/lib/cjs/function/trigonometry/csch.js +4 -15
  179. package/lib/cjs/function/trigonometry/sec.js +11 -17
  180. package/lib/cjs/function/trigonometry/sech.js +4 -15
  181. package/lib/cjs/function/trigonometry/sin.js +11 -21
  182. package/lib/cjs/function/trigonometry/sinh.js +5 -20
  183. package/lib/cjs/function/trigonometry/tan.js +11 -21
  184. package/lib/cjs/function/trigonometry/tanh.js +5 -20
  185. package/lib/cjs/function/trigonometry/trigUnit.js +24 -0
  186. package/lib/cjs/function/unit/to.js +7 -41
  187. package/lib/cjs/function/utils/clone.js +1 -1
  188. package/lib/cjs/function/utils/hasNumericValue.js +5 -1
  189. package/lib/cjs/function/utils/isInteger.js +6 -4
  190. package/lib/cjs/function/utils/isNaN.js +1 -1
  191. package/lib/cjs/function/utils/isNegative.js +11 -7
  192. package/lib/cjs/function/utils/isNumeric.js +6 -4
  193. package/lib/cjs/function/utils/isPositive.js +11 -7
  194. package/lib/cjs/function/utils/isPrime.js +5 -3
  195. package/lib/cjs/function/utils/isZero.js +21 -17
  196. package/lib/cjs/function/utils/numeric.js +11 -4
  197. package/lib/cjs/function/utils/typeOf.js +38 -44
  198. package/lib/cjs/header.js +2 -2
  199. package/lib/cjs/plain/bignumber/index.js +1 -1
  200. package/lib/cjs/type/bignumber/BigNumber.js +2 -2
  201. package/lib/cjs/type/bignumber/function/bignumber.js +6 -4
  202. package/lib/cjs/type/boolean.js +7 -5
  203. package/lib/cjs/type/chain/Chain.js +23 -3
  204. package/lib/cjs/type/complex/Complex.js +18 -14
  205. package/lib/cjs/type/complex/function/complex.js +6 -4
  206. package/lib/cjs/type/fraction/Fraction.js +10 -6
  207. package/lib/cjs/type/fraction/function/fraction.js +6 -4
  208. package/lib/cjs/type/matrix/DenseMatrix.js +21 -6
  209. package/lib/cjs/type/matrix/SparseMatrix.js +12 -2
  210. package/lib/cjs/type/matrix/utils/{algorithm01.js → matAlgo01xDSid.js} +4 -4
  211. package/lib/cjs/type/matrix/utils/{algorithm02.js → matAlgo02xDS0.js} +5 -5
  212. package/lib/cjs/type/matrix/utils/{algorithm03.js → matAlgo03xDSf.js} +5 -5
  213. package/lib/cjs/type/matrix/utils/{algorithm04.js → matAlgo04xSidSid.js} +7 -7
  214. package/lib/cjs/type/matrix/utils/{algorithm05.js → matAlgo05xSfSf.js} +5 -5
  215. package/lib/cjs/type/matrix/utils/{algorithm06.js → matAlgo06xS0S0.js} +5 -5
  216. package/lib/cjs/type/matrix/utils/{algorithm07.js → matAlgo07xSSf.js} +5 -5
  217. package/lib/cjs/type/matrix/utils/{algorithm08.js → matAlgo08xS0Sid.js} +6 -6
  218. package/lib/cjs/type/matrix/utils/{algorithm09.js → matAlgo09xS0Sf.js} +5 -5
  219. package/lib/cjs/type/matrix/utils/{algorithm10.js → matAlgo10xSids.js} +5 -5
  220. package/lib/cjs/type/matrix/utils/{algorithm11.js → matAlgo11xS0s.js} +5 -5
  221. package/lib/cjs/type/matrix/utils/{algorithm12.js → matAlgo12xSfs.js} +5 -5
  222. package/lib/cjs/type/matrix/utils/{algorithm13.js → matAlgo13xDD.js} +5 -5
  223. package/lib/cjs/type/matrix/utils/{algorithm14.js → matAlgo14xDs.js} +5 -5
  224. package/lib/cjs/type/matrix/utils/matrixAlgorithmSuite.js +238 -0
  225. package/lib/cjs/type/number.js +6 -4
  226. package/lib/cjs/type/string.js +7 -5
  227. package/lib/cjs/type/unit/Unit.js +98 -45
  228. package/lib/cjs/type/unit/function/createUnit.js +2 -1
  229. package/lib/cjs/type/unit/function/unit.js +14 -5
  230. package/lib/cjs/utils/customs.js +2 -2
  231. package/lib/cjs/utils/emitter.js +1 -1
  232. package/lib/cjs/utils/function.js +2 -2
  233. package/lib/cjs/utils/is.js +27 -25
  234. package/lib/cjs/utils/latex.js +3 -3
  235. package/lib/cjs/utils/lruQueue.js +1 -1
  236. package/lib/cjs/utils/map.js +3 -3
  237. package/lib/cjs/utils/object.js +2 -2
  238. package/lib/cjs/utils/snapshot.js +30 -57
  239. package/lib/cjs/utils/string.js +3 -3
  240. package/lib/cjs/version.js +1 -1
  241. package/lib/esm/core/create.js +2 -1
  242. package/lib/esm/core/function/import.js +2 -12
  243. package/lib/esm/core/function/typed.js +47 -11
  244. package/lib/esm/entry/dependenciesAny/dependenciesChainClass.generated.js +2 -0
  245. package/lib/esm/entry/dependenciesAny/dependenciesKldivergence.generated.js +2 -0
  246. package/lib/esm/entry/dependenciesAny/dependenciesRationalize.generated.js +2 -0
  247. package/lib/esm/entry/dependenciesAny/dependenciesResolve.generated.js +2 -0
  248. package/lib/esm/entry/dependenciesAny/dependenciesSimplify.generated.js +2 -0
  249. package/lib/esm/entry/dependenciesAny/dependenciesSimplifyConstant.generated.js +34 -0
  250. package/lib/esm/entry/dependenciesAny/dependenciesSimplifyCore.generated.js +4 -0
  251. package/lib/esm/entry/dependenciesAny/dependenciesSqrtm.generated.js +2 -0
  252. package/lib/esm/entry/dependenciesAny/dependenciesStd.generated.js +2 -0
  253. package/lib/esm/entry/dependenciesAny/dependenciesStdTransform.generated.js +2 -0
  254. package/lib/esm/entry/dependenciesAny.generated.js +1 -0
  255. package/lib/esm/entry/dependenciesNumber/dependenciesChainClass.generated.js +2 -0
  256. package/lib/esm/entry/dependenciesNumber/dependenciesRationalize.generated.js +2 -0
  257. package/lib/esm/entry/dependenciesNumber/dependenciesResolve.generated.js +2 -0
  258. package/lib/esm/entry/dependenciesNumber/dependenciesSimplify.generated.js +2 -0
  259. package/lib/esm/entry/dependenciesNumber/dependenciesSimplifyConstant.generated.js +30 -0
  260. package/lib/esm/entry/dependenciesNumber/dependenciesSimplifyCore.generated.js +4 -0
  261. package/lib/esm/entry/dependenciesNumber/dependenciesStd.generated.js +2 -0
  262. package/lib/esm/entry/dependenciesNumber/dependenciesStdTransform.generated.js +2 -0
  263. package/lib/esm/entry/dependenciesNumber.generated.js +1 -0
  264. package/lib/esm/entry/impureFunctionsAny.generated.js +73 -48
  265. package/lib/esm/entry/impureFunctionsNumber.generated.js +81 -58
  266. package/lib/esm/entry/pureFunctionsAny.generated.js +39 -36
  267. package/lib/esm/entry/pureFunctionsNumber.generated.js +14 -13
  268. package/lib/esm/expression/embeddedDocs/construction/index.js +1 -1
  269. package/lib/esm/expression/embeddedDocs/embeddedDocs.js +2 -0
  270. package/lib/esm/expression/embeddedDocs/function/algebra/simplifyConstant.js +8 -0
  271. package/lib/esm/expression/embeddedDocs/function/algebra/simplifyCore.js +1 -1
  272. package/lib/esm/expression/node/AccessorNode.js +158 -153
  273. package/lib/esm/expression/node/ArrayNode.js +162 -154
  274. package/lib/esm/expression/node/AssignmentNode.js +257 -245
  275. package/lib/esm/expression/node/BlockNode.js +177 -163
  276. package/lib/esm/expression/node/ConditionalNode.js +197 -174
  277. package/lib/esm/expression/node/ConstantNode.js +171 -163
  278. package/lib/esm/expression/node/FunctionAssignmentNode.js +205 -180
  279. package/lib/esm/expression/node/FunctionNode.js +407 -407
  280. package/lib/esm/expression/node/IndexNode.js +206 -198
  281. package/lib/esm/expression/node/Node.js +325 -325
  282. package/lib/esm/expression/node/ObjectNode.js +166 -157
  283. package/lib/esm/expression/node/OperatorNode.js +414 -377
  284. package/lib/esm/expression/node/ParenthesisNode.js +146 -138
  285. package/lib/esm/expression/node/RangeNode.js +221 -212
  286. package/lib/esm/expression/node/RelationalNode.js +190 -176
  287. package/lib/esm/expression/node/SymbolNode.js +161 -152
  288. package/lib/esm/expression/operators.js +96 -4
  289. package/lib/esm/expression/parse.js +25 -7
  290. package/lib/esm/expression/transform/std.transform.js +3 -1
  291. package/lib/esm/factoriesAny.js +1 -0
  292. package/lib/esm/factoriesNumber.js +1 -0
  293. package/lib/esm/function/algebra/derivative.js +25 -33
  294. package/lib/esm/function/algebra/leafCount.js +0 -3
  295. package/lib/esm/function/algebra/rationalize.js +83 -114
  296. package/lib/esm/function/algebra/resolve.js +25 -16
  297. package/lib/esm/function/algebra/simplify.js +85 -113
  298. package/lib/esm/function/algebra/{simplify/simplifyConstant.js → simplifyConstant.js} +39 -9
  299. package/lib/esm/function/algebra/simplifyCore.js +192 -91
  300. package/lib/esm/function/algebra/symbolicEqual.js +14 -32
  301. package/lib/esm/function/arithmetic/abs.js +3 -16
  302. package/lib/esm/function/arithmetic/add.js +21 -65
  303. package/lib/esm/function/arithmetic/addScalar.js +11 -5
  304. package/lib/esm/function/arithmetic/cbrt.js +7 -10
  305. package/lib/esm/function/arithmetic/ceil.js +25 -25
  306. package/lib/esm/function/arithmetic/cube.js +5 -9
  307. package/lib/esm/function/arithmetic/divide.js +7 -7
  308. package/lib/esm/function/arithmetic/divideScalar.js +2 -19
  309. package/lib/esm/function/arithmetic/dotDivide.js +22 -64
  310. package/lib/esm/function/arithmetic/dotMultiply.js +16 -60
  311. package/lib/esm/function/arithmetic/dotPow.js +30 -62
  312. package/lib/esm/function/arithmetic/exp.js +8 -11
  313. package/lib/esm/function/arithmetic/expm1.js +10 -9
  314. package/lib/esm/function/arithmetic/fix.js +18 -18
  315. package/lib/esm/function/arithmetic/floor.js +26 -26
  316. package/lib/esm/function/arithmetic/gcd.js +26 -70
  317. package/lib/esm/function/arithmetic/hypot.js +7 -6
  318. package/lib/esm/function/arithmetic/invmod.js +1 -1
  319. package/lib/esm/function/arithmetic/lcm.js +26 -70
  320. package/lib/esm/function/arithmetic/log.js +7 -10
  321. package/lib/esm/function/arithmetic/log10.js +1 -3
  322. package/lib/esm/function/arithmetic/log1p.js +4 -6
  323. package/lib/esm/function/arithmetic/log2.js +1 -3
  324. package/lib/esm/function/arithmetic/mod.js +21 -62
  325. package/lib/esm/function/arithmetic/multiply.js +23 -27
  326. package/lib/esm/function/arithmetic/multiplyScalar.js +2 -13
  327. package/lib/esm/function/arithmetic/norm.js +0 -4
  328. package/lib/esm/function/arithmetic/nthRoot.js +41 -76
  329. package/lib/esm/function/arithmetic/nthRoots.js +2 -2
  330. package/lib/esm/function/arithmetic/round.js +26 -28
  331. package/lib/esm/function/arithmetic/sign.js +5 -7
  332. package/lib/esm/function/arithmetic/sqrt.js +5 -8
  333. package/lib/esm/function/arithmetic/square.js +6 -9
  334. package/lib/esm/function/arithmetic/subtract.js +31 -95
  335. package/lib/esm/function/arithmetic/unaryMinus.js +6 -16
  336. package/lib/esm/function/arithmetic/unaryPlus.js +2 -4
  337. package/lib/esm/function/bitwise/bitAnd.js +16 -59
  338. package/lib/esm/function/bitwise/bitNot.js +2 -4
  339. package/lib/esm/function/bitwise/bitOr.js +16 -59
  340. package/lib/esm/function/bitwise/bitXor.js +16 -59
  341. package/lib/esm/function/bitwise/leftShift.js +39 -61
  342. package/lib/esm/function/bitwise/rightArithShift.js +39 -61
  343. package/lib/esm/function/bitwise/rightLogShift.js +39 -61
  344. package/lib/esm/function/bitwise/useMatrixForArrayScalar.js +13 -0
  345. package/lib/esm/function/complex/arg.js +1 -3
  346. package/lib/esm/function/complex/conj.js +3 -12
  347. package/lib/esm/function/complex/im.js +4 -15
  348. package/lib/esm/function/complex/re.js +3 -15
  349. package/lib/esm/function/geometry/distance.js +2 -2
  350. package/lib/esm/function/logical/and.js +35 -57
  351. package/lib/esm/function/logical/not.js +3 -6
  352. package/lib/esm/function/logical/or.js +16 -61
  353. package/lib/esm/function/logical/xor.js +16 -61
  354. package/lib/esm/function/matrix/diff.js +3 -8
  355. package/lib/esm/function/matrix/ones.js +2 -1
  356. package/lib/esm/function/matrix/rotate.js +5 -5
  357. package/lib/esm/function/matrix/sqrtm.js +3 -2
  358. package/lib/esm/function/matrix/transpose.js +47 -50
  359. package/lib/esm/function/matrix/zeros.js +2 -1
  360. package/lib/esm/function/probability/factorial.js +1 -3
  361. package/lib/esm/function/probability/gamma.js +38 -39
  362. package/lib/esm/function/probability/kldivergence.js +3 -2
  363. package/lib/esm/function/probability/lgamma.js +29 -29
  364. package/lib/esm/function/relational/compare.js +21 -67
  365. package/lib/esm/function/relational/compareNatural.js +54 -49
  366. package/lib/esm/function/relational/compareText.js +10 -42
  367. package/lib/esm/function/relational/compareUnits.js +15 -0
  368. package/lib/esm/function/relational/equal.js +19 -79
  369. package/lib/esm/function/relational/equalScalar.js +6 -9
  370. package/lib/esm/function/relational/larger.js +23 -73
  371. package/lib/esm/function/relational/largerEq.js +23 -73
  372. package/lib/esm/function/relational/smaller.js +23 -73
  373. package/lib/esm/function/relational/smallerEq.js +23 -73
  374. package/lib/esm/function/relational/unequal.js +19 -79
  375. package/lib/esm/function/special/erf.js +1 -3
  376. package/lib/esm/function/statistics/std.js +10 -2
  377. package/lib/esm/function/string/format.js +2 -2
  378. package/lib/esm/function/string/hex.js +1 -2
  379. package/lib/esm/function/trigonometry/acos.js +4 -7
  380. package/lib/esm/function/trigonometry/acosh.js +2 -6
  381. package/lib/esm/function/trigonometry/acot.js +6 -10
  382. package/lib/esm/function/trigonometry/acoth.js +4 -7
  383. package/lib/esm/function/trigonometry/acsc.js +6 -10
  384. package/lib/esm/function/trigonometry/acsch.js +4 -7
  385. package/lib/esm/function/trigonometry/asec.js +6 -9
  386. package/lib/esm/function/trigonometry/asech.js +4 -7
  387. package/lib/esm/function/trigonometry/asin.js +5 -9
  388. package/lib/esm/function/trigonometry/asinh.js +4 -8
  389. package/lib/esm/function/trigonometry/atan.js +5 -10
  390. package/lib/esm/function/trigonometry/atan2.js +26 -65
  391. package/lib/esm/function/trigonometry/atanh.js +4 -8
  392. package/lib/esm/function/trigonometry/cos.js +11 -22
  393. package/lib/esm/function/trigonometry/cosh.js +5 -20
  394. package/lib/esm/function/trigonometry/cot.js +10 -20
  395. package/lib/esm/function/trigonometry/coth.js +6 -20
  396. package/lib/esm/function/trigonometry/csc.js +12 -22
  397. package/lib/esm/function/trigonometry/csch.js +6 -20
  398. package/lib/esm/function/trigonometry/sec.js +12 -22
  399. package/lib/esm/function/trigonometry/sech.js +6 -20
  400. package/lib/esm/function/trigonometry/sin.js +11 -23
  401. package/lib/esm/function/trigonometry/sinh.js +5 -21
  402. package/lib/esm/function/trigonometry/tan.js +11 -23
  403. package/lib/esm/function/trigonometry/tanh.js +5 -21
  404. package/lib/esm/function/trigonometry/trigUnit.js +15 -0
  405. package/lib/esm/function/unit/to.js +8 -43
  406. package/lib/esm/function/utils/clone.js +1 -1
  407. package/lib/esm/function/utils/hasNumericValue.js +3 -1
  408. package/lib/esm/function/utils/isInteger.js +2 -4
  409. package/lib/esm/function/utils/isNaN.js +1 -1
  410. package/lib/esm/function/utils/isNegative.js +3 -7
  411. package/lib/esm/function/utils/isNumeric.js +4 -10
  412. package/lib/esm/function/utils/isPositive.js +3 -7
  413. package/lib/esm/function/utils/isPrime.js +1 -3
  414. package/lib/esm/function/utils/isZero.js +13 -17
  415. package/lib/esm/function/utils/numeric.js +11 -4
  416. package/lib/esm/function/utils/typeOf.js +38 -44
  417. package/lib/esm/type/bignumber/function/bignumber.js +1 -3
  418. package/lib/esm/type/boolean.js +1 -3
  419. package/lib/esm/type/chain/Chain.js +23 -3
  420. package/lib/esm/type/complex/Complex.js +4 -0
  421. package/lib/esm/type/complex/function/complex.js +1 -3
  422. package/lib/esm/type/fraction/Fraction.js +4 -0
  423. package/lib/esm/type/fraction/function/fraction.js +1 -3
  424. package/lib/esm/type/matrix/DenseMatrix.js +15 -1
  425. package/lib/esm/type/matrix/SparseMatrix.js +9 -0
  426. package/lib/esm/type/matrix/utils/{algorithm01.js → matAlgo01xDSid.js} +2 -2
  427. package/lib/esm/type/matrix/utils/{algorithm02.js → matAlgo02xDS0.js} +3 -3
  428. package/lib/esm/type/matrix/utils/{algorithm03.js → matAlgo03xDSf.js} +3 -3
  429. package/lib/esm/type/matrix/utils/{algorithm04.js → matAlgo04xSidSid.js} +5 -5
  430. package/lib/esm/type/matrix/utils/{algorithm05.js → matAlgo05xSfSf.js} +3 -3
  431. package/lib/esm/type/matrix/utils/{algorithm06.js → matAlgo06xS0S0.js} +3 -3
  432. package/lib/esm/type/matrix/utils/{algorithm07.js → matAlgo07xSSf.js} +3 -3
  433. package/lib/esm/type/matrix/utils/{algorithm08.js → matAlgo08xS0Sid.js} +4 -4
  434. package/lib/esm/type/matrix/utils/{algorithm09.js → matAlgo09xS0Sf.js} +3 -3
  435. package/lib/esm/type/matrix/utils/{algorithm10.js → matAlgo10xSids.js} +3 -3
  436. package/lib/esm/type/matrix/utils/{algorithm11.js → matAlgo11xS0s.js} +3 -3
  437. package/lib/esm/type/matrix/utils/{algorithm12.js → matAlgo12xSfs.js} +3 -3
  438. package/lib/esm/type/matrix/utils/{algorithm13.js → matAlgo13xDD.js} +3 -3
  439. package/lib/esm/type/matrix/utils/{algorithm14.js → matAlgo14xDs.js} +3 -3
  440. package/lib/esm/type/matrix/utils/matrixAlgorithmSuite.js +168 -0
  441. package/lib/esm/type/number.js +1 -3
  442. package/lib/esm/type/string.js +1 -3
  443. package/lib/esm/type/unit/Unit.js +85 -36
  444. package/lib/esm/type/unit/function/createUnit.js +2 -1
  445. package/lib/esm/type/unit/function/unit.js +10 -5
  446. package/lib/esm/utils/is.js +18 -18
  447. package/lib/esm/utils/snapshot.js +22 -48
  448. package/lib/esm/version.js +1 -1
  449. package/package.json +22 -25
  450. package/types/index.d.ts +211 -180
  451. package/types/index.ts +358 -144
  452. package/types/tsconfig.json +4 -1
  453. package/lib/cjs/utils/polyfills.js +0 -14
  454. package/lib/esm/utils/polyfills.js +0 -12
@@ -7,10 +7,14 @@ Object.defineProperty(exports, "__esModule", {
7
7
  });
8
8
  exports.createNode = void 0;
9
9
 
10
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
11
-
12
10
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
11
 
12
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
13
+
14
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
15
+
16
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
17
+
14
18
  var _is = require("../../utils/is.js");
15
19
 
16
20
  var _keywords = require("../keywords.js");
@@ -26,388 +30,13 @@ var dependencies = ['mathWithTransform'];
26
30
  var createNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {
27
31
  var mathWithTransform = _ref.mathWithTransform;
28
32
 
29
- /**
30
- * Node
31
- */
32
- function Node() {
33
- if (!(this instanceof Node)) {
34
- throw new SyntaxError('Constructor must be called with the new operator');
35
- }
36
- }
37
- /**
38
- * Evaluate the node
39
- * @param {Object} [scope] Scope to read/write variables
40
- * @return {*} Returns the result
41
- */
42
-
43
-
44
- Node.prototype.evaluate = function (scope) {
45
- return this.compile().evaluate(scope);
46
- };
47
-
48
- Node.prototype.type = 'Node';
49
- Node.prototype.isNode = true;
50
- Node.prototype.comment = '';
51
- /**
52
- * Compile the node into an optimized, evauatable JavaScript function
53
- * @return {{evaluate: function([Object])}} object
54
- * Returns an object with a function 'evaluate',
55
- * which can be invoked as expr.evaluate([scope: Object]),
56
- * where scope is an optional object with
57
- * variables.
58
- */
59
-
60
- Node.prototype.compile = function () {
61
- var expr = this._compile(mathWithTransform, {});
62
-
63
- var args = {};
64
- var context = null;
65
-
66
- function evaluate(scope) {
67
- var s = (0, _map.createMap)(scope);
68
-
69
- _validateScope(s);
70
-
71
- return expr(s, args, context);
72
- }
73
-
74
- return {
75
- evaluate: evaluate
76
- };
77
- };
78
- /**
79
- * Compile a node into a JavaScript function.
80
- * This basically pre-calculates as much as possible and only leaves open
81
- * calculations which depend on a dynamic scope with variables.
82
- * @param {Object} math Math.js namespace with functions and constants.
83
- * @param {Object} argNames An object with argument names as key and `true`
84
- * as value. Used in the SymbolNode to optimize
85
- * for arguments from user assigned functions
86
- * (see FunctionAssignmentNode) or special symbols
87
- * like `end` (see IndexNode).
88
- * @return {function} Returns a function which can be called like:
89
- * evalNode(scope: Object, args: Object, context: *)
90
- */
91
-
92
-
93
- Node.prototype._compile = function (math, argNames) {
94
- throw new Error('Method _compile should be implemented by type ' + this.type);
95
- };
96
- /**
97
- * Execute a callback for each of the child nodes of this node
98
- * @param {function(child: Node, path: string, parent: Node)} callback
99
- */
100
-
101
-
102
- Node.prototype.forEach = function (callback) {
103
- // must be implemented by each of the Node implementations
104
- throw new Error('Cannot run forEach on a Node interface');
105
- };
106
- /**
107
- * Create a new Node having it's childs be the results of calling
108
- * the provided callback function for each of the childs of the original node.
109
- * @param {function(child: Node, path: string, parent: Node): Node} callback
110
- * @returns {OperatorNode} Returns a transformed copy of the node
111
- */
112
-
113
-
114
- Node.prototype.map = function (callback) {
115
- // must be implemented by each of the Node implementations
116
- throw new Error('Cannot run map on a Node interface');
117
- };
118
- /**
119
- * Validate whether an object is a Node, for use with map
120
- * @param {Node} node
121
- * @returns {Node} Returns the input if it's a node, else throws an Error
122
- * @protected
123
- */
124
-
125
-
126
- Node.prototype._ifNode = function (node) {
127
- if (!(0, _is.isNode)(node)) {
128
- throw new TypeError('Callback function must return a Node');
129
- }
130
-
131
- return node;
132
- };
133
- /**
134
- * Recursively traverse all nodes in a node tree. Executes given callback for
135
- * this node and each of its child nodes.
136
- * @param {function(node: Node, path: string, parent: Node)} callback
137
- * A callback called for every node in the node tree.
138
- */
139
-
140
-
141
- Node.prototype.traverse = function (callback) {
142
- // execute callback for itself
143
- // eslint-disable-next-line
144
- callback(this, null, null); // recursively traverse over all childs of a node
145
-
146
- function _traverse(node, callback) {
147
- node.forEach(function (child, path, parent) {
148
- callback(child, path, parent);
149
-
150
- _traverse(child, callback);
151
- });
152
- }
153
-
154
- _traverse(this, callback);
155
- };
156
- /**
157
- * Recursively transform a node tree via a transform function.
158
- *
159
- * For example, to replace all nodes of type SymbolNode having name 'x' with a
160
- * ConstantNode with value 2:
161
- *
162
- * const res = Node.transform(function (node, path, parent) {
163
- * if (node && node.isSymbolNode) && (node.name === 'x')) {
164
- * return new ConstantNode(2)
165
- * }
166
- * else {
167
- * return node
168
- * }
169
- * })
170
- *
171
- * @param {function(node: Node, path: string, parent: Node) : Node} callback
172
- * A mapping function accepting a node, and returning
173
- * a replacement for the node or the original node.
174
- * Signature: callback(node: Node, index: string, parent: Node) : Node
175
- * @return {Node} Returns the original node or its replacement
176
- */
177
-
178
-
179
- Node.prototype.transform = function (callback) {
180
- function _transform(child, path, parent) {
181
- var replacement = callback(child, path, parent);
182
-
183
- if (replacement !== child) {
184
- // stop iterating when the node is replaced
185
- return replacement;
186
- }
187
-
188
- return child.map(_transform);
189
- }
190
-
191
- return _transform(this, null, null);
192
- };
193
- /**
194
- * Find any node in the node tree matching given filter function. For example, to
195
- * find all nodes of type SymbolNode having name 'x':
196
- *
197
- * const results = Node.filter(function (node) {
198
- * return (node && node.isSymbolNode) && (node.name === 'x')
199
- * })
200
- *
201
- * @param {function(node: Node, path: string, parent: Node) : Node} callback
202
- * A test function returning true when a node matches, and false
203
- * otherwise. Function signature:
204
- * callback(node: Node, index: string, parent: Node) : boolean
205
- * @return {Node[]} nodes An array with nodes matching given filter criteria
206
- */
207
-
208
-
209
- Node.prototype.filter = function (callback) {
210
- var nodes = [];
211
- this.traverse(function (node, path, parent) {
212
- if (callback(node, path, parent)) {
213
- nodes.push(node);
214
- }
215
- });
216
- return nodes;
217
- };
218
- /**
219
- * Create a shallow clone of this node
220
- * @return {Node}
221
- */
222
-
223
-
224
- Node.prototype.clone = function () {
225
- // must be implemented by each of the Node implementations
226
- throw new Error('Cannot clone a Node interface');
227
- };
228
- /**
229
- * Create a deep clone of this node
230
- * @return {Node}
231
- */
232
-
233
-
234
- Node.prototype.cloneDeep = function () {
235
- return this.map(function (node) {
236
- return node.cloneDeep();
237
- });
238
- };
239
- /**
240
- * Deep compare this node with another node.
241
- * @param {Node} other
242
- * @return {boolean} Returns true when both nodes are of the same type and
243
- * contain the same values (as do their childs)
244
- */
245
-
246
-
247
- Node.prototype.equals = function (other) {
248
- return other ? (0, _object.deepStrictEqual)(this, other) : false;
249
- };
250
- /**
251
- * Get string representation. (wrapper function)
252
- *
253
- * This function can get an object of the following form:
254
- * {
255
- * handler: //This can be a callback function of the form
256
- * // "function callback(node, options)"or
257
- * // a map that maps function names (used in FunctionNodes)
258
- * // to callbacks
259
- * parenthesis: "keep" //the parenthesis option (This is optional)
260
- * }
261
- *
262
- * @param {Object} [options]
263
- * @return {string}
264
- */
265
-
266
-
267
- Node.prototype.toString = function (options) {
268
- var customString = this._getCustomString(options);
269
-
270
- if (typeof customString !== 'undefined') {
271
- return customString;
272
- }
273
-
274
- return this._toString(options);
275
- };
276
- /**
277
- * Get a JSON representation of the node
278
- * Both .toJSON() and the static .fromJSON(json) should be implemented by all
279
- * implementations of Node
280
- * @returns {Object}
281
- */
282
-
283
-
284
- Node.prototype.toJSON = function () {
285
- throw new Error('Cannot serialize object: toJSON not implemented by ' + this.type);
286
- };
287
- /**
288
- * Get HTML representation. (wrapper function)
289
- *
290
- * This function can get an object of the following form:
291
- * {
292
- * handler: //This can be a callback function of the form
293
- * // "function callback(node, options)" or
294
- * // a map that maps function names (used in FunctionNodes)
295
- * // to callbacks
296
- * parenthesis: "keep" //the parenthesis option (This is optional)
297
- * }
298
- *
299
- * @param {Object} [options]
300
- * @return {string}
301
- */
302
-
303
-
304
- Node.prototype.toHTML = function (options) {
305
- var customString = this._getCustomString(options);
306
-
307
- if (typeof customString !== 'undefined') {
308
- return customString;
309
- }
310
-
311
- return this.toHTML(options);
312
- };
313
- /**
314
- * Internal function to generate the string output.
315
- * This has to be implemented by every Node
316
- *
317
- * @throws {Error}
318
- */
319
-
320
-
321
- Node.prototype._toString = function () {
322
- // must be implemented by each of the Node implementations
323
- throw new Error('_toString not implemented for ' + this.type);
324
- };
325
- /**
326
- * Get LaTeX representation. (wrapper function)
327
- *
328
- * This function can get an object of the following form:
329
- * {
330
- * handler: //This can be a callback function of the form
331
- * // "function callback(node, options)"or
332
- * // a map that maps function names (used in FunctionNodes)
333
- * // to callbacks
334
- * parenthesis: "keep" //the parenthesis option (This is optional)
335
- * }
336
- *
337
- * @param {Object} [options]
338
- * @return {string}
339
- */
340
-
341
-
342
- Node.prototype.toTex = function (options) {
343
- var customString = this._getCustomString(options);
344
-
345
- if (typeof customString !== 'undefined') {
346
- return customString;
347
- }
348
-
349
- return this._toTex(options);
350
- };
351
- /**
352
- * Internal function to generate the LaTeX output.
353
- * This has to be implemented by every Node
354
- *
355
- * @param {Object} [options]
356
- * @throws {Error}
357
- */
358
-
359
-
360
- Node.prototype._toTex = function (options) {
361
- // must be implemented by each of the Node implementations
362
- throw new Error('_toTex not implemented for ' + this.type);
363
- };
364
- /**
365
- * Helper used by `to...` functions.
366
- */
367
-
368
-
369
- Node.prototype._getCustomString = function (options) {
370
- if (options && (0, _typeof2.default)(options) === 'object') {
371
- switch ((0, _typeof2.default)(options.handler)) {
372
- case 'object':
373
- case 'undefined':
374
- return;
375
-
376
- case 'function':
377
- return options.handler(this, options);
378
-
379
- default:
380
- throw new TypeError('Object or function expected as callback');
381
- }
382
- }
383
- };
384
- /**
385
- * Get identifier.
386
- * @return {string}
387
- */
388
-
389
-
390
- Node.prototype.getIdentifier = function () {
391
- return this.type;
392
- };
393
- /**
394
- * Get the content of the current Node.
395
- * @return {Node} node
396
- **/
397
-
398
-
399
- Node.prototype.getContent = function () {
400
- return this;
401
- };
402
33
  /**
403
34
  * Validate the symbol names of a scope.
404
35
  * Throws an error when the scope contains an illegal symbol.
405
36
  * @param {Object} scope
406
37
  */
407
-
408
-
409
38
  function _validateScope(scope) {
410
- for (var _i = 0, _arr = (0, _toConsumableArray2.default)(_keywords.keywords); _i < _arr.length; _i++) {
39
+ for (var _i = 0, _arr = (0, _toConsumableArray2["default"])(_keywords.keywords); _i < _arr.length; _i++) {
411
40
  var symbol = _arr[_i];
412
41
 
413
42
  if (scope.has(symbol)) {
@@ -416,6 +45,410 @@ var createNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, functi
416
45
  }
417
46
  }
418
47
 
48
+ var Node = /*#__PURE__*/function () {
49
+ function Node() {
50
+ (0, _classCallCheck2["default"])(this, Node);
51
+ }
52
+
53
+ (0, _createClass2["default"])(Node, [{
54
+ key: "type",
55
+ get: function get() {
56
+ return 'Node';
57
+ }
58
+ }, {
59
+ key: "isNode",
60
+ get: function get() {
61
+ return true;
62
+ }
63
+ /**
64
+ * Evaluate the node
65
+ * @param {Object} [scope] Scope to read/write variables
66
+ * @return {*} Returns the result
67
+ */
68
+
69
+ }, {
70
+ key: "evaluate",
71
+ value: function evaluate(scope) {
72
+ return this.compile().evaluate(scope);
73
+ }
74
+ /**
75
+ * Compile the node into an optimized, evauatable JavaScript function
76
+ * @return {{evaluate: function([Object])}} object
77
+ * Returns an object with a function 'evaluate',
78
+ * which can be invoked as expr.evaluate([scope: Object]),
79
+ * where scope is an optional object with
80
+ * variables.
81
+ */
82
+
83
+ }, {
84
+ key: "compile",
85
+ value: function compile() {
86
+ var expr = this._compile(mathWithTransform, {});
87
+
88
+ var args = {};
89
+ var context = null;
90
+
91
+ function evaluate(scope) {
92
+ var s = (0, _map.createMap)(scope);
93
+
94
+ _validateScope(s);
95
+
96
+ return expr(s, args, context);
97
+ }
98
+
99
+ return {
100
+ evaluate: evaluate
101
+ };
102
+ }
103
+ /**
104
+ * Compile a node into a JavaScript function.
105
+ * This basically pre-calculates as much as possible and only leaves open
106
+ * calculations which depend on a dynamic scope with variables.
107
+ * @param {Object} math Math.js namespace with functions and constants.
108
+ * @param {Object} argNames An object with argument names as key and `true`
109
+ * as value. Used in the SymbolNode to optimize
110
+ * for arguments from user assigned functions
111
+ * (see FunctionAssignmentNode) or special symbols
112
+ * like `end` (see IndexNode).
113
+ * @return {function} Returns a function which can be called like:
114
+ * evalNode(scope: Object, args: Object, context: *)
115
+ */
116
+
117
+ }, {
118
+ key: "_compile",
119
+ value: function _compile(math, argNames) {
120
+ throw new Error('Method _compile must be implemented by type ' + this.type);
121
+ }
122
+ /**
123
+ * Execute a callback for each of the child nodes of this node
124
+ * @param {function(child: Node, path: string, parent: Node)} callback
125
+ */
126
+
127
+ }, {
128
+ key: "forEach",
129
+ value: function forEach(callback) {
130
+ // must be implemented by each of the Node implementations
131
+ throw new Error('Cannot run forEach on a Node interface');
132
+ }
133
+ /**
134
+ * Create a new Node whose children are the results of calling the
135
+ * provided callback function for each child of the original node.
136
+ * @param {function(child: Node, path: string, parent: Node): Node} callback
137
+ * @returns {OperatorNode} Returns a transformed copy of the node
138
+ */
139
+
140
+ }, {
141
+ key: "map",
142
+ value: function map(callback) {
143
+ // must be implemented by each of the Node implementations
144
+ throw new Error('Cannot run map on a Node interface');
145
+ }
146
+ /**
147
+ * Validate whether an object is a Node, for use with map
148
+ * @param {Node} node
149
+ * @returns {Node} Returns the input if it's a node, else throws an Error
150
+ * @protected
151
+ */
152
+
153
+ }, {
154
+ key: "_ifNode",
155
+ value: function _ifNode(node) {
156
+ if (!(0, _is.isNode)(node)) {
157
+ throw new TypeError('Callback function must return a Node');
158
+ }
159
+
160
+ return node;
161
+ }
162
+ /**
163
+ * Recursively traverse all nodes in a node tree. Executes given callback for
164
+ * this node and each of its child nodes.
165
+ * @param {function(node: Node, path: string, parent: Node)} callback
166
+ * A callback called for every node in the node tree.
167
+ */
168
+
169
+ }, {
170
+ key: "traverse",
171
+ value: function traverse(callback) {
172
+ // execute callback for itself
173
+ // eslint-disable-next-line
174
+ callback(this, null, null); // recursively traverse over all children of a node
175
+
176
+ function _traverse(node, callback) {
177
+ node.forEach(function (child, path, parent) {
178
+ callback(child, path, parent);
179
+
180
+ _traverse(child, callback);
181
+ });
182
+ }
183
+
184
+ _traverse(this, callback);
185
+ }
186
+ /**
187
+ * Recursively transform a node tree via a transform function.
188
+ *
189
+ * For example, to replace all nodes of type SymbolNode having name 'x' with
190
+ * a ConstantNode with value 2:
191
+ *
192
+ * const res = Node.transform(function (node, path, parent) {
193
+ * if (node && node.isSymbolNode) && (node.name === 'x')) {
194
+ * return new ConstantNode(2)
195
+ * }
196
+ * else {
197
+ * return node
198
+ * }
199
+ * })
200
+ *
201
+ * @param {function(node: Node, path: string, parent: Node) : Node} callback
202
+ * A mapping function accepting a node, and returning
203
+ * a replacement for the node or the original node. The "signature"
204
+ * of the callback must be:
205
+ * callback(node: Node, index: string, parent: Node) : Node
206
+ * @return {Node} Returns the original node or its replacement
207
+ */
208
+
209
+ }, {
210
+ key: "transform",
211
+ value: function transform(callback) {
212
+ function _transform(child, path, parent) {
213
+ var replacement = callback(child, path, parent);
214
+
215
+ if (replacement !== child) {
216
+ // stop iterating when the node is replaced
217
+ return replacement;
218
+ }
219
+
220
+ return child.map(_transform);
221
+ }
222
+
223
+ return _transform(this, null, null);
224
+ }
225
+ /**
226
+ * Find any node in the node tree matching given filter function. For
227
+ * example, to find all nodes of type SymbolNode having name 'x':
228
+ *
229
+ * const results = Node.filter(function (node) {
230
+ * return (node && node.isSymbolNode) && (node.name === 'x')
231
+ * })
232
+ *
233
+ * @param {function(node: Node, path: string, parent: Node) : Node} callback
234
+ * A test function returning true when a node matches, and false
235
+ * otherwise. Function signature:
236
+ * callback(node: Node, index: string, parent: Node) : boolean
237
+ * @return {Node[]} nodes
238
+ * An array with nodes matching given filter criteria
239
+ */
240
+
241
+ }, {
242
+ key: "filter",
243
+ value: function filter(callback) {
244
+ var nodes = [];
245
+ this.traverse(function (node, path, parent) {
246
+ if (callback(node, path, parent)) {
247
+ nodes.push(node);
248
+ }
249
+ });
250
+ return nodes;
251
+ }
252
+ /**
253
+ * Create a shallow clone of this node
254
+ * @return {Node}
255
+ */
256
+
257
+ }, {
258
+ key: "clone",
259
+ value: function clone() {
260
+ // must be implemented by each of the Node implementations
261
+ throw new Error('Cannot clone a Node interface');
262
+ }
263
+ /**
264
+ * Create a deep clone of this node
265
+ * @return {Node}
266
+ */
267
+
268
+ }, {
269
+ key: "cloneDeep",
270
+ value: function cloneDeep() {
271
+ return this.map(function (node) {
272
+ return node.cloneDeep();
273
+ });
274
+ }
275
+ /**
276
+ * Deep compare this node with another node.
277
+ * @param {Node} other
278
+ * @return {boolean} Returns true when both nodes are of the same type and
279
+ * contain the same values (as do their childs)
280
+ */
281
+
282
+ }, {
283
+ key: "equals",
284
+ value: function equals(other) {
285
+ return other ? this.type === other.type && (0, _object.deepStrictEqual)(this, other) : false;
286
+ }
287
+ /**
288
+ * Get string representation. (wrapper function)
289
+ *
290
+ * This function can get an object of the following form:
291
+ * {
292
+ * handler: //This can be a callback function of the form
293
+ * // "function callback(node, options)"or
294
+ * // a map that maps function names (used in FunctionNodes)
295
+ * // to callbacks
296
+ * parenthesis: "keep" //the parenthesis option (This is optional)
297
+ * }
298
+ *
299
+ * @param {Object} [options]
300
+ * @return {string}
301
+ */
302
+
303
+ }, {
304
+ key: "toString",
305
+ value: function toString(options) {
306
+ var customString = this._getCustomString(options);
307
+
308
+ if (typeof customString !== 'undefined') {
309
+ return customString;
310
+ }
311
+
312
+ return this._toString(options);
313
+ }
314
+ /**
315
+ * Get a JSON representation of the node
316
+ * Both .toJSON() and the static .fromJSON(json) should be implemented by all
317
+ * implementations of Node
318
+ * @returns {Object}
319
+ */
320
+
321
+ }, {
322
+ key: "toJSON",
323
+ value: function toJSON() {
324
+ throw new Error('Cannot serialize object: toJSON not implemented by ' + this.type);
325
+ }
326
+ /**
327
+ * Get HTML representation. (wrapper function)
328
+ *
329
+ * This function can get an object of the following form:
330
+ * {
331
+ * handler: //This can be a callback function of the form
332
+ * // "function callback(node, options)" or
333
+ * // a map that maps function names (used in FunctionNodes)
334
+ * // to callbacks
335
+ * parenthesis: "keep" //the parenthesis option (This is optional)
336
+ * }
337
+ *
338
+ * @param {Object} [options]
339
+ * @return {string}
340
+ */
341
+
342
+ }, {
343
+ key: "toHTML",
344
+ value: function toHTML(options) {
345
+ var customString = this._getCustomString(options);
346
+
347
+ if (typeof customString !== 'undefined') {
348
+ return customString;
349
+ }
350
+
351
+ return this.toHTML(options);
352
+ }
353
+ /**
354
+ * Internal function to generate the string output.
355
+ * This has to be implemented by every Node
356
+ *
357
+ * @throws {Error}
358
+ */
359
+
360
+ }, {
361
+ key: "_toString",
362
+ value: function _toString() {
363
+ // must be implemented by each of the Node implementations
364
+ throw new Error('_toString not implemented for ' + this.type);
365
+ }
366
+ /**
367
+ * Get LaTeX representation. (wrapper function)
368
+ *
369
+ * This function can get an object of the following form:
370
+ * {
371
+ * handler: //This can be a callback function of the form
372
+ * // "function callback(node, options)"or
373
+ * // a map that maps function names (used in FunctionNodes)
374
+ * // to callbacks
375
+ * parenthesis: "keep" //the parenthesis option (This is optional)
376
+ * }
377
+ *
378
+ * @param {Object} [options]
379
+ * @return {string}
380
+ */
381
+
382
+ }, {
383
+ key: "toTex",
384
+ value: function toTex(options) {
385
+ var customString = this._getCustomString(options);
386
+
387
+ if (typeof customString !== 'undefined') {
388
+ return customString;
389
+ }
390
+
391
+ return this._toTex(options);
392
+ }
393
+ /**
394
+ * Internal function to generate the LaTeX output.
395
+ * This has to be implemented by every Node
396
+ *
397
+ * @param {Object} [options]
398
+ * @throws {Error}
399
+ */
400
+
401
+ }, {
402
+ key: "_toTex",
403
+ value: function _toTex(options) {
404
+ // must be implemented by each of the Node implementations
405
+ throw new Error('_toTex not implemented for ' + this.type);
406
+ }
407
+ /**
408
+ * Helper used by `to...` functions.
409
+ */
410
+
411
+ }, {
412
+ key: "_getCustomString",
413
+ value: function _getCustomString(options) {
414
+ if (options && (0, _typeof2["default"])(options) === 'object') {
415
+ switch ((0, _typeof2["default"])(options.handler)) {
416
+ case 'object':
417
+ case 'undefined':
418
+ return;
419
+
420
+ case 'function':
421
+ return options.handler(this, options);
422
+
423
+ default:
424
+ throw new TypeError('Object or function expected as callback');
425
+ }
426
+ }
427
+ }
428
+ /**
429
+ * Get identifier.
430
+ * @return {string}
431
+ */
432
+
433
+ }, {
434
+ key: "getIdentifier",
435
+ value: function getIdentifier() {
436
+ return this.type;
437
+ }
438
+ /**
439
+ * Get the content of the current Node.
440
+ * @return {Node} node
441
+ **/
442
+
443
+ }, {
444
+ key: "getContent",
445
+ value: function getContent() {
446
+ return this;
447
+ }
448
+ }]);
449
+ return Node;
450
+ }();
451
+
419
452
  return Node;
420
453
  }, {
421
454
  isClass: true,