pimath 0.0.120 → 0.0.122

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 (175) hide show
  1. package/.idea/PI.iml +7 -1
  2. package/.idea/shelf/Uncommitted_changes_before_Update_at_24_07_2023_15_31_[Default_Changelist]/shelved.patch +90 -0
  3. package/.idea/shelf/Uncommitted_changes_before_Update_at_24_07_2023_15_31_[Default_Changelist]1/shelved.patch +107 -0
  4. package/.idea/shelf/Uncommitted_changes_before_Update_at_24_07_2023_15_31__Default_Changelist_.xml +4 -0
  5. package/.idea/shelf/Uncommitted_changes_before_Update_at_24_07_2023_15_31__Default_Changelist_1.xml +4 -0
  6. package/LICENSE.md +1 -1
  7. package/dev/pimath.js +7929 -0
  8. package/dev/pimath.js.map +1 -0
  9. package/dist/{pi.js → pimath.js} +7613 -7840
  10. package/dist/pimath.js.map +1 -0
  11. package/dist/pimath.min.js +2 -0
  12. package/dist/pimath.min.js.map +1 -0
  13. package/docs/assets/main.js +58 -58
  14. package/docs/assets/search.js +1 -1
  15. package/docs/assets/style.css +1367 -1280
  16. package/docs/classes/Logicalset.Logicalset.html +221 -212
  17. package/docs/classes/Polynom.Rational.html +391 -388
  18. package/docs/classes/Vector-1.Vector.html +494 -448
  19. package/docs/classes/Vector.Point.html +341 -342
  20. package/docs/classes/algebra_equation.Equation.html +796 -753
  21. package/docs/classes/algebra_linearSystem.LinearSystem.html +408 -397
  22. package/docs/classes/algebra_monom.Monom.html +967 -910
  23. package/docs/classes/algebra_polynom.Polynom.html +1281 -1260
  24. package/docs/classes/coefficients_fraction.Fraction.html +939 -931
  25. package/docs/classes/geometry_circle.Circle.html +476 -476
  26. package/docs/classes/geometry_line.Line.html +779 -719
  27. package/docs/classes/geometry_triangle.Triangle.html +429 -420
  28. package/docs/classes/numeric.Numeric.html +269 -263
  29. package/docs/classes/shutingyard.Shutingyard.html +259 -248
  30. package/docs/enums/algebra_equation.PARTICULAR_SOLUTION.html +89 -88
  31. package/docs/enums/geometry_line.LinePropriety.html +102 -102
  32. package/docs/enums/shutingyard.ShutingyardMode.html +106 -102
  33. package/docs/enums/shutingyard.ShutingyardType.html +120 -116
  34. package/docs/index.html +63 -65
  35. package/docs/interfaces/algebra_equation.ISolution.html +111 -109
  36. package/docs/interfaces/algebra_polynom.IEuclidian.html +93 -92
  37. package/docs/interfaces/geometry_triangle.remarquableLines.html +150 -150
  38. package/docs/modules/Logicalset.html +69 -74
  39. package/docs/modules/Polynom.html +69 -74
  40. package/docs/modules/Vector-1.html +69 -74
  41. package/docs/modules/Vector.html +69 -74
  42. package/docs/modules/algebra_equation.html +75 -81
  43. package/docs/modules/algebra_linearSystem.html +65 -71
  44. package/docs/modules/algebra_monom.html +70 -76
  45. package/docs/modules/algebra_polynom.html +75 -81
  46. package/docs/modules/coefficients_fraction.html +70 -76
  47. package/docs/modules/geometry_circle.html +65 -71
  48. package/docs/modules/geometry_line.html +70 -76
  49. package/docs/modules/geometry_triangle.html +70 -76
  50. package/docs/modules/numeric.html +65 -71
  51. package/docs/modules/shutingyard.html +84 -90
  52. package/docs/types/algebra_monom.literalType.html +66 -70
  53. package/docs/types/algebra_polynom.PolynomParsingType.html +62 -66
  54. package/docs/types/coefficients_fraction.FractionParsingType.html +61 -65
  55. package/docs/types/shutingyard.Token.html +72 -76
  56. package/docs/types/shutingyard.tokenType.html +77 -81
  57. package/docs/variables/shutingyard.tokenConstant.html +70 -74
  58. package/esm/index.d.ts +38 -41
  59. package/esm/index.js +43 -46
  60. package/esm/index.js.map +1 -1
  61. package/esm/maths/algebra/equation.d.ts +119 -117
  62. package/esm/maths/algebra/equation.js +796 -785
  63. package/esm/maths/algebra/equation.js.map +1 -1
  64. package/esm/maths/algebra/linearSystem.d.ts +39 -38
  65. package/esm/maths/algebra/linearSystem.js +278 -262
  66. package/esm/maths/algebra/linearSystem.js.map +1 -1
  67. package/esm/maths/algebra/logicalset.d.ts +28 -28
  68. package/esm/maths/algebra/logicalset.js +157 -157
  69. package/esm/maths/algebra/monom.d.ts +206 -206
  70. package/esm/maths/algebra/monom.js +908 -908
  71. package/esm/maths/algebra/monom.js.map +1 -1
  72. package/esm/maths/algebra/polynom.d.ts +157 -157
  73. package/esm/maths/algebra/polynom.js +1277 -1277
  74. package/esm/maths/algebra/rational.d.ts +45 -45
  75. package/esm/maths/algebra/rational.js +183 -183
  76. package/esm/maths/algebra/study/rationalStudy.d.ts +28 -28
  77. package/esm/maths/algebra/study/rationalStudy.js +243 -243
  78. package/esm/maths/algebra/study.d.ts +143 -142
  79. package/esm/maths/algebra/study.js +378 -377
  80. package/esm/maths/algebra/study.js.map +1 -1
  81. package/esm/maths/coefficients/fraction.d.ts +90 -90
  82. package/esm/maths/coefficients/fraction.js +516 -516
  83. package/esm/maths/coefficients/fraction.js.map +1 -1
  84. package/esm/maths/coefficients/nthRoot.d.ts +23 -23
  85. package/esm/maths/coefficients/nthRoot.js +136 -136
  86. package/esm/maths/geometry/circle.d.ts +45 -45
  87. package/esm/maths/geometry/circle.js +323 -323
  88. package/esm/maths/geometry/line.d.ts +99 -99
  89. package/esm/maths/geometry/line.js +481 -481
  90. package/esm/maths/geometry/line.js.map +1 -1
  91. package/esm/maths/geometry/point.d.ts +34 -34
  92. package/esm/maths/geometry/point.js +166 -166
  93. package/esm/maths/geometry/point.js.map +1 -1
  94. package/esm/maths/geometry/triangle.d.ts +85 -85
  95. package/esm/maths/geometry/triangle.js +268 -268
  96. package/esm/maths/geometry/vector.d.ts +41 -41
  97. package/esm/maths/geometry/vector.js +197 -197
  98. package/esm/maths/geometry/vector.js.map +1 -1
  99. package/esm/maths/numeric.d.ts +28 -28
  100. package/esm/maths/numeric.js +180 -180
  101. package/esm/maths/numexp.d.ts +19 -0
  102. package/esm/maths/numexp.js +186 -0
  103. package/esm/maths/numexp.js.map +1 -0
  104. package/esm/maths/randomization/random.d.ts +23 -23
  105. package/esm/maths/randomization/random.js +78 -78
  106. package/esm/maths/randomization/random.js.map +1 -1
  107. package/esm/maths/randomization/randomCore.d.ts +7 -7
  108. package/esm/maths/randomization/randomCore.js +21 -21
  109. package/esm/maths/randomization/rndFraction.d.ts +12 -12
  110. package/esm/maths/randomization/rndFraction.js +43 -43
  111. package/esm/maths/randomization/rndGeometryLine.d.ts +12 -12
  112. package/esm/maths/randomization/rndGeometryLine.js +45 -45
  113. package/esm/maths/randomization/rndGeometryPoint.d.ts +12 -12
  114. package/esm/maths/randomization/rndGeometryPoint.js +60 -60
  115. package/esm/maths/randomization/rndHelpers.d.ts +23 -23
  116. package/esm/maths/randomization/rndHelpers.js +76 -76
  117. package/esm/maths/randomization/rndMonom.d.ts +12 -12
  118. package/esm/maths/randomization/rndMonom.js +52 -52
  119. package/esm/maths/randomization/rndPolynom.d.ts +13 -13
  120. package/esm/maths/randomization/rndPolynom.js +74 -74
  121. package/esm/maths/randomization/rndTypes.d.ts +34 -34
  122. package/esm/maths/randomization/rndTypes.js +2 -2
  123. package/esm/maths/shutingyard.d.ts +59 -59
  124. package/esm/maths/shutingyard.js +442 -442
  125. package/esm/maths/shutingyard.js.map +1 -1
  126. package/package.json +11 -11
  127. package/public/index.html +50 -81
  128. package/public/playground.html +7 -8
  129. package/src/index.ts +1 -4
  130. package/src/maths/algebra/equation.ts +16 -0
  131. package/src/maths/algebra/linearSystem.ts +20 -0
  132. package/src/maths/algebra/study.ts +12 -10
  133. package/src/maths/{expressions/numexp.ts → numexp.ts} +2 -2
  134. package/tests/algebra/equation.test.ts +19 -5
  135. package/tests/algebra/linear.test.ts +3 -11
  136. package/tests/algebra/polynom.test.ts +7 -8
  137. package/tests/algebra/rationnal.test.ts +1 -1
  138. package/tests/algebra/study.test.ts +2 -9
  139. package/tests/coefficients/fraction.test.ts +8 -8
  140. package/tests/custom.test.ts +33 -37
  141. package/tests/numeric.test.ts +1 -2
  142. package/tests/numexp.test.ts +13 -5
  143. package/tests/shutingyard.test.ts +3 -3
  144. package/webpack-production-min.config.js +1 -1
  145. package/webpack-production.config.js +1 -1
  146. package/webpack.config.js +1 -1
  147. package/dist/pi.js.map +0 -1
  148. package/dist/pi.min.js +0 -2
  149. package/dist/pi.min.js.map +0 -1
  150. package/docs/classes/expressions_numexp.NumExp.html +0 -236
  151. package/docs/classes/expressions_polynomexp.PolynomExpFactor.html +0 -317
  152. package/docs/classes/expressions_polynomexp.PolynomExpProduct.html +0 -285
  153. package/docs/modules/expressions_numexp.html +0 -71
  154. package/docs/modules/expressions_polynomexp.html +0 -73
  155. package/docs/modules.html +0 -76
  156. package/graph.svg +0 -1033
  157. package/src/maths/expressions/ExpressionTree.ts +0 -172
  158. package/src/maths/expressions/expression.ts +0 -286
  159. package/src/maths/expressions/expressionFactor.ts +0 -190
  160. package/src/maths/expressions/expressionMember.ts +0 -233
  161. package/src/maths/expressions/expressionOperators.ts +0 -49
  162. package/src/maths/expressions/expressionParser.ts +0 -295
  163. package/src/maths/expressions/factors/ExpFactor.ts +0 -39
  164. package/src/maths/expressions/factors/ExpFactorConstant.ts +0 -60
  165. package/src/maths/expressions/factors/ExpFactorExponential.ts +0 -26
  166. package/src/maths/expressions/factors/ExpFactorNumber.ts +0 -72
  167. package/src/maths/expressions/factors/ExpFactorPower.ts +0 -42
  168. package/src/maths/expressions/factors/ExpFactorTrigo.ts +0 -53
  169. package/src/maths/expressions/factors/ExpFactorVariable.ts +0 -45
  170. package/src/maths/expressions/internals.ts +0 -14
  171. package/src/maths/expressions/polynomexp.bkp.ts +0 -221
  172. package/src/maths/expressions/polynomexp.ts +0 -310
  173. package/tests/expressions/expressions.test.ts +0 -145
  174. package/tests/expressions/expressiontree.test.ts +0 -11
  175. package/tests/polynomexp.test.ts +0 -12
@@ -1,181 +1,181 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Numeric = void 0;
4
- class Numeric {
5
- static round(value, decimals = 2) {
6
- return Number(Math.round(Number(value + 'e' + decimals)) + 'e-' + decimals);
7
- }
8
- /**
9
- * Get the list of the nth first prime numbers.
10
- * @param nb : number of primes to choose from
11
- */
12
- static primes(nb) {
13
- let primesValues = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97, 101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199, 211, 223, 227, 229, 233, 239, 241, 251, 257, 263, 269, 271, 277, 281, 283, 293, 307, 311, 313, 317, 331, 337, 347, 349, 353, 359, 367, 373, 379, 383, 389, 397, 401, 409, 419, 421, 431, 433, 439, 443, 449, 457, 461, 463, 467, 479, 487, 491, 499, 503, 509, 521, 523, 541, 547, 557, 563, 569, 571, 577, 587, 593, 599, 601, 607, 613, 617, 619, 631, 641, 643, 647, 653, 659, 661, 673, 677, 683, 691, 701, 709, 719, 727, 733, 739, 743, 751, 757, 761, 769, 773, 787, 797, 809, 811, 821, 823, 827, 829, 839, 853, 857, 859, 863, 877, 881, 883, 887, 907, 911, 919, 929, 937, 941, 947, 953, 967, 971, 977, 983, 991, 997, 1009, 1013, 1019, 1021, 1031, 1033, 1039, 1049, 1051, 1061, 1063, 1069, 1087, 1091, 1093, 1097, 1103, 1109, 1117, 1123, 1129, 1151, 1153, 1163, 1171, 1181, 1187, 1193, 1201, 1213, 1217, 1223, 1229, 1231, 1237, 1249, 1259, 1277, 1279, 1283, 1289, 1291, 1297, 1301, 1303, 1307, 1319, 1321, 1327, 1361, 1367, 1373, 1381, 1399, 1409, 1423, 1427, 1429, 1433, 1439, 1447, 1451, 1453, 1459, 1471, 1481, 1483, 1487, 1489, 1493, 1499, 1511, 1523, 1531, 1543, 1549, 1553, 1559, 1567, 1571, 1579, 1583, 1597, 1601, 1607, 1609, 1613, 1619, 1621, 1627, 1637, 1657, 1663, 1667, 1669, 1693, 1697, 1699, 1709, 1721, 1723, 1733, 1741, 1747, 1753, 1759, 1777, 1783, 1787, 1789, 1801, 1811, 1823, 1831, 1847, 1861, 1867, 1871, 1873, 1877, 1879, 1889, 1901, 1907, 1913, 1931, 1933, 1949, 1951, 1973, 1979, 1987, 1993, 1997, 1999, 2003, 2011, 2017, 2027, 2029, 2039, 2053, 2063, 2069, 2081, 2083, 2087, 2089, 2099, 2111, 2113, 2129, 2131, 2137, 2141, 2143, 2153, 2161, 2179, 2203, 2207, 2213, 2221, 2237, 2239, 2243, 2251, 2267, 2269, 2273, 2281, 2287, 2293, 2297, 2309, 2311, 2333, 2339, 2341, 2347, 2351, 2357, 2371, 2377, 2381, 2383, 2389, 2393, 2399, 2411, 2417, 2423, 2437, 2441, 2447, 2459, 2467, 2473, 2477, 2503, 2521, 2531, 2539, 2543, 2549, 2551, 2557, 2579, 2591, 2593, 2609, 2617, 2621, 2633, 2647, 2657, 2659, 2663, 2671, 2677, 2683, 2687, 2689, 2693, 2699, 2707, 2711, 2713, 2719, 2729, 2731, 2741, 2749, 2753, 2767, 2777, 2789, 2791, 2797, 2801, 2803, 2819, 2833, 2837, 2843, 2851, 2857, 2861, 2879, 2887, 2897, 2903, 2909, 2917, 2927, 2939, 2953, 2957, 2963, 2969, 2971, 2999, 3001, 3011, 3019, 3023, 3037, 3041, 3049, 3061, 3067, 3079, 3083, 3089, 3109, 3119, 3121, 3137, 3163, 3167, 3169, 3181, 3187, 3191, 3203, 3209, 3217, 3221, 3229, 3251, 3253, 3257, 3259, 3271, 3299, 3301, 3307, 3313, 3319, 3323, 3329, 3331, 3343, 3347, 3359, 3361, 3371, 3373, 3389, 3391, 3407, 3413, 3433, 3449, 3457, 3461, 3463, 3467, 3469, 3491, 3499, 3511, 3517, 3527, 3529, 3533, 3539, 3541, 3547, 3557, 3559, 3571, 3581, 3583, 3593, 3607, 3613, 3617, 3623, 3631, 3637, 3643, 3659, 3671, 3673, 3677, 3691, 3697, 3701, 3709, 3719, 3727, 3733, 3739, 3761, 3767, 3769, 3779, 3793, 3797, 3803, 3821, 3823, 3833, 3847, 3851, 3853, 3863, 3877, 3881, 3889, 3907, 3911, 3917, 3919, 3923, 3929, 3931, 3943, 3947, 3967, 3989, 4001, 4003, 4007, 4013, 4019, 4021, 4027, 4049, 4051, 4057, 4073, 4079, 4091, 4093, 4099, 4111, 4127, 4129, 4133, 4139, 4153, 4157, 4159, 4177, 4201, 4211, 4217, 4219, 4229, 4231, 4241, 4243, 4253, 4259, 4261, 4271, 4273, 4283, 4289, 4297, 4327, 4337, 4339, 4349, 4357, 4363, 4373, 4391, 4397, 4409, 4421, 4423, 4441, 4447, 4451, 4457, 4463, 4481, 4483, 4493, 4507, 4513, 4517, 4519, 4523, 4547, 4549, 4561, 4567, 4583, 4591, 4597, 4603, 4621, 4637, 4639, 4643, 4649, 4651, 4657, 4663, 4673, 4679, 4691, 4703, 4721, 4723, 4729, 4733, 4751, 4759, 4783, 4787, 4789, 4793, 4799, 4801, 4813, 4817, 4831, 4861, 4871, 4877, 4889, 4903, 4909, 4919, 4931, 4933, 4937, 4943, 4951, 4957, 4967, 4969, 4973, 4987, 4993, 4999, 5003, 5009, 5011, 5021, 5023, 5039, 5051, 5059, 5077, 5081, 5087, 5099, 5101, 5107, 5113, 5119, 5147, 5153, 5167, 5171, 5179, 5189, 5197, 5209, 5227, 5231, 5233, 5237, 5261, 5273, 5279, 5281, 5297, 5303, 5309, 5323, 5333, 5347, 5351, 5381, 5387, 5393, 5399, 5407, 5413, 5417, 5419, 5431, 5437, 5441, 5443, 5449, 5471, 5477, 5479, 5483, 5501, 5503, 5507, 5519, 5521, 5527, 5531, 5557, 5563, 5569, 5573, 5581, 5591, 5623, 5639, 5641, 5647, 5651, 5653, 5657, 5659, 5669, 5683, 5689, 5693, 5701, 5711, 5717, 5737, 5741, 5743, 5749, 5779, 5783, 5791, 5801, 5807, 5813, 5821, 5827, 5839, 5843, 5849, 5851, 5857, 5861, 5867, 5869, 5879, 5881, 5897, 5903, 5923, 5927, 5939, 5953, 5981, 5987, 6007, 6011, 6029, 6037, 6043, 6047, 6053, 6067, 6073, 6079, 6089, 6091, 6101, 6113, 6121, 6131, 6133, 6143, 6151, 6163, 6173, 6197, 6199, 6203, 6211, 6217, 6221, 6229, 6247, 6257, 6263, 6269, 6271, 6277, 6287, 6299, 6301, 6311, 6317, 6323, 6329, 6337, 6343, 6353, 6359, 6361, 6367, 6373, 6379, 6389, 6397, 6421, 6427, 6449, 6451, 6469, 6473, 6481, 6491, 6521, 6529, 6547, 6551, 6553, 6563, 6569, 6571, 6577, 6581, 6599, 6607, 6619, 6637, 6653, 6659, 6661, 6673, 6679, 6689, 6691, 6701, 6703, 6709, 6719, 6733, 6737, 6761, 6763, 6779, 6781, 6791, 6793, 6803, 6823, 6827, 6829, 6833, 6841, 6857, 6863, 6869, 6871, 6883, 6899, 6907, 6911, 6917, 6947, 6949, 6959, 6961, 6967, 6971, 6977, 6983, 6991, 6997, 7001, 7013, 7019, 7027, 7039, 7043, 7057, 7069, 7079, 7103, 7109, 7121, 7127, 7129, 7151, 7159, 7177, 7187, 7193, 7207, 7211, 7213, 7219, 7229, 7237, 7243, 7247, 7253, 7283, 7297, 7307, 7309, 7321, 7331, 7333, 7349, 7351, 7369, 7393, 7411, 7417, 7433, 7451, 7457, 7459, 7477, 7481, 7487, 7489, 7499, 7507, 7517, 7523, 7529, 7537, 7541, 7547, 7549, 7559, 7561, 7573, 7577, 7583, 7589, 7591, 7603, 7607, 7621, 7639, 7643, 7649, 7669, 7673, 7681, 7687, 7691, 7699, 7703, 7717, 7723, 7727, 7741, 7753, 7757, 7759, 7789, 7793, 7817, 7823, 7829, 7841, 7853, 7867, 7873, 7877, 7879, 7883, 7901, 7907, 7919, 7927, 7933, 7937, 7949, 7951, 7963, 7993, 8009, 8011, 8017, 8039, 8053, 8059, 8069, 8081, 8087, 8089, 8093, 8101, 8111, 8117, 8123, 8147, 8161, 8167, 8171, 8179, 8191, 8209, 8219, 8221, 8231, 8233, 8237, 8243, 8263, 8269, 8273, 8287, 8291, 8293, 8297, 8311, 8317, 8329, 8353, 8363, 8369, 8377, 8387, 8389, 8419, 8423, 8429, 8431, 8443, 8447, 8461, 8467, 8501, 8513, 8521, 8527, 8537, 8539, 8543, 8563, 8573, 8581, 8597, 8599, 8609, 8623, 8627, 8629, 8641, 8647, 8663, 8669, 8677, 8681, 8689, 8693, 8699, 8707, 8713, 8719, 8731, 8737, 8741, 8747, 8753, 8761, 8779, 8783, 8803, 8807, 8819, 8821, 8831, 8837, 8839, 8849, 8861, 8863, 8867, 8887, 8893, 8923, 8929, 8933, 8941, 8951, 8963, 8969, 8971, 8999, 9001, 9007, 9011, 9013, 9029, 9041, 9043, 9049, 9059, 9067, 9091, 9103, 9109, 9127, 9133, 9137, 9151, 9157, 9161, 9173, 9181, 9187, 9199, 9203, 9209, 9221, 9227, 9239, 9241, 9257, 9277, 9281, 9283, 9293, 9311, 9319, 9323, 9337, 9341, 9343, 9349, 9371, 9377, 9391, 9397, 9403, 9413, 9419, 9421, 9431, 9433, 9437, 9439, 9461, 9463, 9467, 9473, 9479, 9491, 9497, 9511, 9521, 9533, 9539, 9547, 9551, 9587, 9601, 9613, 9619, 9623, 9629, 9631, 9643, 9649, 9661, 9677, 9679, 9689, 9697, 9719, 9721, 9733, 9739, 9743, 9749, 9767, 9769, 9781, 9787, 9791, 9803, 9811, 9817, 9829, 9833, 9839, 9851, 9857, 9859, 9871, 9883, 9887, 9901, 9907, 9923, 9929, 9931, 9941, 9949, 9967, 9973];
14
- if (nb === undefined) {
15
- return primesValues;
16
- }
17
- else {
18
- return primesValues.slice(0, Math.min(primesValues.length, nb));
19
- }
20
- }
21
- /**
22
- * Get the list of all dividers of a number.
23
- * @param value
24
- */
25
- static dividers(value) {
26
- let D;
27
- const maxV = Math.sqrt(Math.abs(value));
28
- // Initialize the list of dividers.
29
- D = [];
30
- for (let i = 1; i <= maxV; i++) {
31
- if (value % i === 0) {
32
- D.push(i);
33
- D.push(value / i);
34
- }
35
- }
36
- // Order numbers.
37
- D.sort(function (a, b) { return a - b; });
38
- // Make sure the array of value is unique.
39
- return [...new Set(D)];
40
- }
41
- /**
42
- * Great Common Divisor
43
- * @param values : number values
44
- */
45
- static gcd(...values) {
46
- // Define the gcd for two number
47
- let gcd2 = function (a, b) {
48
- if (b === 0) {
49
- return a;
50
- }
51
- return gcd2(b, a % b);
52
- };
53
- let g = 1, i = 2;
54
- // Nothing is given
55
- if (values.length === 0) {
56
- return 1;
57
- }
58
- // Only one number is given
59
- if (values.length === 1) {
60
- // The first number is zero
61
- if (values[0] === 0) {
62
- return 1;
63
- }
64
- // Return the number
65
- return values[0];
66
- }
67
- // We have at least 2 numbers.
68
- g = gcd2(values[0], values[1]);
69
- // The gcd of the two first value is one ? It's already finished.
70
- if (g === 1) {
71
- return 1;
72
- }
73
- // The current gcd isn't one. Continue with all next values.
74
- for (i = 2; i < values.length; i++) {
75
- g = gcd2(g, values[i]);
76
- // Escape if gcd is already one.
77
- if (g === 1) {
78
- break;
79
- }
80
- }
81
- return Math.abs(g);
82
- }
83
- static divideNumbersByGCD(...values) {
84
- let gcd = Numeric.gcd(...values);
85
- return values.map(x => x / gcd);
86
- }
87
- /**
88
- * Least Common Multiple
89
- * @param values: list of numbers
90
- */
91
- static lcm(...values) {
92
- return values.reduce(function (a, b) {
93
- return Math.abs(a * b / Numeric.gcd(a, b));
94
- });
95
- }
96
- static pythagoricianTripletsWithTarget(target, targetIsSquare) {
97
- // méthode inverse, à partir du triplet.
98
- const triplets = [], targetValue = targetIsSquare === true ? +target : target ** 2;
99
- for (let u = 0; u <= target; u++) {
100
- for (let v = 0; v <= target; v++) {
101
- if (u ** 2 + v ** 2 === targetValue) {
102
- triplets.push([u, v, target]);
103
- }
104
- }
105
- }
106
- return triplets;
107
- }
108
- static numberCorrection(value, epsilonDigit = 1, epsilonNumberOfDigits = 10, number_of_digits = 8) {
109
- return +value.toFixed(number_of_digits);
110
- //
111
- // // Must modify the number if it's like:
112
- // // a: 3.0000000000000003
113
- // // b: 3.9999999999999994
114
- // // remove the last character
115
- // // check if around n last characters are either 0 or 9
116
- // // if it is, 'round' the number.
117
- // function extractDecimalPart(valueToExtract: number, decimalLength: number){
118
- // let decimal = valueToExtract.toString()
119
- //
120
- // if (!decimal.includes('.')) {
121
- // return ''
122
- // }
123
- //
124
- // decimal = decimal.split('.')[1]
125
- // return decimal.substring(0, decimalLength)
126
- // }
127
- //
128
- // const epsilon = Number(`0.${"0".repeat(epsilonNumberOfDigits-1)}${epsilonDigit}`)
129
- // const decimal = extractDecimalPart(value, epsilonNumberOfDigits)
130
- // if(decimal===''){return value}
131
- //
132
- // const n9 = decimal.match(/9+$/g)
133
- // const n0 = decimal.match(/0+$/g)
134
- //
135
- // if (n9 && n9[0].length >= number_of_digits) {
136
- // // New tested values.
137
- // const mod = extractDecimalPart(value + epsilon, epsilonNumberOfDigits),
138
- // mod0 = mod.match(/0+$/g)
139
- //
140
- // if(mod0 && mod0[0].length>= number_of_digits){
141
- // return +((value+epsilon).toString().split(mod0[0])[0])
142
- // }
143
- // }
144
- //
145
- // if (n0 && n0[0].length >= number_of_digits) {
146
- // // New tested values.
147
- // const mod = extractDecimalPart(value - epsilon, epsilonNumberOfDigits),
148
- // mod9 = mod.match(/9+$/g)
149
- //
150
- // if(mod9 && mod9[0].length>= number_of_digits){
151
- // // The value can be changed. Remove all nines!
152
- // return +(value.toString().split(n0[0])[0])
153
- // }
154
- // }
155
- //
156
- // return value
157
- }
158
- static periodic(value) {
159
- if (Number.isSafeInteger(value)) {
160
- return 0;
161
- }
162
- // Assume it's with decimal.
163
- let decimal = (value.toString()).split('.')[0];
164
- // The decimal part is limited
165
- if (decimal.length < 10) {
166
- return 0;
167
- }
168
- // Find the periodic if it exists.
169
- }
170
- static decompose(value) {
171
- let dividers = Numeric.dividers(value), limit = Math.sqrt(value), arr = [], u, v;
172
- while (dividers.length > 0) {
173
- u = dividers.shift();
174
- v = dividers.length > 0 ? dividers.pop() : +u;
175
- arr.push([u, v]);
176
- }
177
- return arr;
178
- }
179
- }
180
- exports.Numeric = Numeric;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Numeric = void 0;
4
+ class Numeric {
5
+ static round(value, decimals = 2) {
6
+ return Number(Math.round(Number(value + 'e' + decimals)) + 'e-' + decimals);
7
+ }
8
+ /**
9
+ * Get the list of the nth first prime numbers.
10
+ * @param nb : number of primes to choose from
11
+ */
12
+ static primes(nb) {
13
+ let primesValues = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97, 101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199, 211, 223, 227, 229, 233, 239, 241, 251, 257, 263, 269, 271, 277, 281, 283, 293, 307, 311, 313, 317, 331, 337, 347, 349, 353, 359, 367, 373, 379, 383, 389, 397, 401, 409, 419, 421, 431, 433, 439, 443, 449, 457, 461, 463, 467, 479, 487, 491, 499, 503, 509, 521, 523, 541, 547, 557, 563, 569, 571, 577, 587, 593, 599, 601, 607, 613, 617, 619, 631, 641, 643, 647, 653, 659, 661, 673, 677, 683, 691, 701, 709, 719, 727, 733, 739, 743, 751, 757, 761, 769, 773, 787, 797, 809, 811, 821, 823, 827, 829, 839, 853, 857, 859, 863, 877, 881, 883, 887, 907, 911, 919, 929, 937, 941, 947, 953, 967, 971, 977, 983, 991, 997, 1009, 1013, 1019, 1021, 1031, 1033, 1039, 1049, 1051, 1061, 1063, 1069, 1087, 1091, 1093, 1097, 1103, 1109, 1117, 1123, 1129, 1151, 1153, 1163, 1171, 1181, 1187, 1193, 1201, 1213, 1217, 1223, 1229, 1231, 1237, 1249, 1259, 1277, 1279, 1283, 1289, 1291, 1297, 1301, 1303, 1307, 1319, 1321, 1327, 1361, 1367, 1373, 1381, 1399, 1409, 1423, 1427, 1429, 1433, 1439, 1447, 1451, 1453, 1459, 1471, 1481, 1483, 1487, 1489, 1493, 1499, 1511, 1523, 1531, 1543, 1549, 1553, 1559, 1567, 1571, 1579, 1583, 1597, 1601, 1607, 1609, 1613, 1619, 1621, 1627, 1637, 1657, 1663, 1667, 1669, 1693, 1697, 1699, 1709, 1721, 1723, 1733, 1741, 1747, 1753, 1759, 1777, 1783, 1787, 1789, 1801, 1811, 1823, 1831, 1847, 1861, 1867, 1871, 1873, 1877, 1879, 1889, 1901, 1907, 1913, 1931, 1933, 1949, 1951, 1973, 1979, 1987, 1993, 1997, 1999, 2003, 2011, 2017, 2027, 2029, 2039, 2053, 2063, 2069, 2081, 2083, 2087, 2089, 2099, 2111, 2113, 2129, 2131, 2137, 2141, 2143, 2153, 2161, 2179, 2203, 2207, 2213, 2221, 2237, 2239, 2243, 2251, 2267, 2269, 2273, 2281, 2287, 2293, 2297, 2309, 2311, 2333, 2339, 2341, 2347, 2351, 2357, 2371, 2377, 2381, 2383, 2389, 2393, 2399, 2411, 2417, 2423, 2437, 2441, 2447, 2459, 2467, 2473, 2477, 2503, 2521, 2531, 2539, 2543, 2549, 2551, 2557, 2579, 2591, 2593, 2609, 2617, 2621, 2633, 2647, 2657, 2659, 2663, 2671, 2677, 2683, 2687, 2689, 2693, 2699, 2707, 2711, 2713, 2719, 2729, 2731, 2741, 2749, 2753, 2767, 2777, 2789, 2791, 2797, 2801, 2803, 2819, 2833, 2837, 2843, 2851, 2857, 2861, 2879, 2887, 2897, 2903, 2909, 2917, 2927, 2939, 2953, 2957, 2963, 2969, 2971, 2999, 3001, 3011, 3019, 3023, 3037, 3041, 3049, 3061, 3067, 3079, 3083, 3089, 3109, 3119, 3121, 3137, 3163, 3167, 3169, 3181, 3187, 3191, 3203, 3209, 3217, 3221, 3229, 3251, 3253, 3257, 3259, 3271, 3299, 3301, 3307, 3313, 3319, 3323, 3329, 3331, 3343, 3347, 3359, 3361, 3371, 3373, 3389, 3391, 3407, 3413, 3433, 3449, 3457, 3461, 3463, 3467, 3469, 3491, 3499, 3511, 3517, 3527, 3529, 3533, 3539, 3541, 3547, 3557, 3559, 3571, 3581, 3583, 3593, 3607, 3613, 3617, 3623, 3631, 3637, 3643, 3659, 3671, 3673, 3677, 3691, 3697, 3701, 3709, 3719, 3727, 3733, 3739, 3761, 3767, 3769, 3779, 3793, 3797, 3803, 3821, 3823, 3833, 3847, 3851, 3853, 3863, 3877, 3881, 3889, 3907, 3911, 3917, 3919, 3923, 3929, 3931, 3943, 3947, 3967, 3989, 4001, 4003, 4007, 4013, 4019, 4021, 4027, 4049, 4051, 4057, 4073, 4079, 4091, 4093, 4099, 4111, 4127, 4129, 4133, 4139, 4153, 4157, 4159, 4177, 4201, 4211, 4217, 4219, 4229, 4231, 4241, 4243, 4253, 4259, 4261, 4271, 4273, 4283, 4289, 4297, 4327, 4337, 4339, 4349, 4357, 4363, 4373, 4391, 4397, 4409, 4421, 4423, 4441, 4447, 4451, 4457, 4463, 4481, 4483, 4493, 4507, 4513, 4517, 4519, 4523, 4547, 4549, 4561, 4567, 4583, 4591, 4597, 4603, 4621, 4637, 4639, 4643, 4649, 4651, 4657, 4663, 4673, 4679, 4691, 4703, 4721, 4723, 4729, 4733, 4751, 4759, 4783, 4787, 4789, 4793, 4799, 4801, 4813, 4817, 4831, 4861, 4871, 4877, 4889, 4903, 4909, 4919, 4931, 4933, 4937, 4943, 4951, 4957, 4967, 4969, 4973, 4987, 4993, 4999, 5003, 5009, 5011, 5021, 5023, 5039, 5051, 5059, 5077, 5081, 5087, 5099, 5101, 5107, 5113, 5119, 5147, 5153, 5167, 5171, 5179, 5189, 5197, 5209, 5227, 5231, 5233, 5237, 5261, 5273, 5279, 5281, 5297, 5303, 5309, 5323, 5333, 5347, 5351, 5381, 5387, 5393, 5399, 5407, 5413, 5417, 5419, 5431, 5437, 5441, 5443, 5449, 5471, 5477, 5479, 5483, 5501, 5503, 5507, 5519, 5521, 5527, 5531, 5557, 5563, 5569, 5573, 5581, 5591, 5623, 5639, 5641, 5647, 5651, 5653, 5657, 5659, 5669, 5683, 5689, 5693, 5701, 5711, 5717, 5737, 5741, 5743, 5749, 5779, 5783, 5791, 5801, 5807, 5813, 5821, 5827, 5839, 5843, 5849, 5851, 5857, 5861, 5867, 5869, 5879, 5881, 5897, 5903, 5923, 5927, 5939, 5953, 5981, 5987, 6007, 6011, 6029, 6037, 6043, 6047, 6053, 6067, 6073, 6079, 6089, 6091, 6101, 6113, 6121, 6131, 6133, 6143, 6151, 6163, 6173, 6197, 6199, 6203, 6211, 6217, 6221, 6229, 6247, 6257, 6263, 6269, 6271, 6277, 6287, 6299, 6301, 6311, 6317, 6323, 6329, 6337, 6343, 6353, 6359, 6361, 6367, 6373, 6379, 6389, 6397, 6421, 6427, 6449, 6451, 6469, 6473, 6481, 6491, 6521, 6529, 6547, 6551, 6553, 6563, 6569, 6571, 6577, 6581, 6599, 6607, 6619, 6637, 6653, 6659, 6661, 6673, 6679, 6689, 6691, 6701, 6703, 6709, 6719, 6733, 6737, 6761, 6763, 6779, 6781, 6791, 6793, 6803, 6823, 6827, 6829, 6833, 6841, 6857, 6863, 6869, 6871, 6883, 6899, 6907, 6911, 6917, 6947, 6949, 6959, 6961, 6967, 6971, 6977, 6983, 6991, 6997, 7001, 7013, 7019, 7027, 7039, 7043, 7057, 7069, 7079, 7103, 7109, 7121, 7127, 7129, 7151, 7159, 7177, 7187, 7193, 7207, 7211, 7213, 7219, 7229, 7237, 7243, 7247, 7253, 7283, 7297, 7307, 7309, 7321, 7331, 7333, 7349, 7351, 7369, 7393, 7411, 7417, 7433, 7451, 7457, 7459, 7477, 7481, 7487, 7489, 7499, 7507, 7517, 7523, 7529, 7537, 7541, 7547, 7549, 7559, 7561, 7573, 7577, 7583, 7589, 7591, 7603, 7607, 7621, 7639, 7643, 7649, 7669, 7673, 7681, 7687, 7691, 7699, 7703, 7717, 7723, 7727, 7741, 7753, 7757, 7759, 7789, 7793, 7817, 7823, 7829, 7841, 7853, 7867, 7873, 7877, 7879, 7883, 7901, 7907, 7919, 7927, 7933, 7937, 7949, 7951, 7963, 7993, 8009, 8011, 8017, 8039, 8053, 8059, 8069, 8081, 8087, 8089, 8093, 8101, 8111, 8117, 8123, 8147, 8161, 8167, 8171, 8179, 8191, 8209, 8219, 8221, 8231, 8233, 8237, 8243, 8263, 8269, 8273, 8287, 8291, 8293, 8297, 8311, 8317, 8329, 8353, 8363, 8369, 8377, 8387, 8389, 8419, 8423, 8429, 8431, 8443, 8447, 8461, 8467, 8501, 8513, 8521, 8527, 8537, 8539, 8543, 8563, 8573, 8581, 8597, 8599, 8609, 8623, 8627, 8629, 8641, 8647, 8663, 8669, 8677, 8681, 8689, 8693, 8699, 8707, 8713, 8719, 8731, 8737, 8741, 8747, 8753, 8761, 8779, 8783, 8803, 8807, 8819, 8821, 8831, 8837, 8839, 8849, 8861, 8863, 8867, 8887, 8893, 8923, 8929, 8933, 8941, 8951, 8963, 8969, 8971, 8999, 9001, 9007, 9011, 9013, 9029, 9041, 9043, 9049, 9059, 9067, 9091, 9103, 9109, 9127, 9133, 9137, 9151, 9157, 9161, 9173, 9181, 9187, 9199, 9203, 9209, 9221, 9227, 9239, 9241, 9257, 9277, 9281, 9283, 9293, 9311, 9319, 9323, 9337, 9341, 9343, 9349, 9371, 9377, 9391, 9397, 9403, 9413, 9419, 9421, 9431, 9433, 9437, 9439, 9461, 9463, 9467, 9473, 9479, 9491, 9497, 9511, 9521, 9533, 9539, 9547, 9551, 9587, 9601, 9613, 9619, 9623, 9629, 9631, 9643, 9649, 9661, 9677, 9679, 9689, 9697, 9719, 9721, 9733, 9739, 9743, 9749, 9767, 9769, 9781, 9787, 9791, 9803, 9811, 9817, 9829, 9833, 9839, 9851, 9857, 9859, 9871, 9883, 9887, 9901, 9907, 9923, 9929, 9931, 9941, 9949, 9967, 9973];
14
+ if (nb === undefined) {
15
+ return primesValues;
16
+ }
17
+ else {
18
+ return primesValues.slice(0, Math.min(primesValues.length, nb));
19
+ }
20
+ }
21
+ /**
22
+ * Get the list of all dividers of a number.
23
+ * @param value
24
+ */
25
+ static dividers(value) {
26
+ let D;
27
+ const maxV = Math.sqrt(Math.abs(value));
28
+ // Initialize the list of dividers.
29
+ D = [];
30
+ for (let i = 1; i <= maxV; i++) {
31
+ if (value % i === 0) {
32
+ D.push(i);
33
+ D.push(value / i);
34
+ }
35
+ }
36
+ // Order numbers.
37
+ D.sort(function (a, b) { return a - b; });
38
+ // Make sure the array of value is unique.
39
+ return [...new Set(D)];
40
+ }
41
+ /**
42
+ * Great Common Divisor
43
+ * @param values : number values
44
+ */
45
+ static gcd(...values) {
46
+ // Define the gcd for two number
47
+ let gcd2 = function (a, b) {
48
+ if (b === 0) {
49
+ return a;
50
+ }
51
+ return gcd2(b, a % b);
52
+ };
53
+ let g = 1, i = 2;
54
+ // Nothing is given
55
+ if (values.length === 0) {
56
+ return 1;
57
+ }
58
+ // Only one number is given
59
+ if (values.length === 1) {
60
+ // The first number is zero
61
+ if (values[0] === 0) {
62
+ return 1;
63
+ }
64
+ // Return the number
65
+ return values[0];
66
+ }
67
+ // We have at least 2 numbers.
68
+ g = gcd2(values[0], values[1]);
69
+ // The gcd of the two first value is one ? It's already finished.
70
+ if (g === 1) {
71
+ return 1;
72
+ }
73
+ // The current gcd isn't one. Continue with all next values.
74
+ for (i = 2; i < values.length; i++) {
75
+ g = gcd2(g, values[i]);
76
+ // Escape if gcd is already one.
77
+ if (g === 1) {
78
+ break;
79
+ }
80
+ }
81
+ return Math.abs(g);
82
+ }
83
+ static divideNumbersByGCD(...values) {
84
+ let gcd = Numeric.gcd(...values);
85
+ return values.map(x => x / gcd);
86
+ }
87
+ /**
88
+ * Least Common Multiple
89
+ * @param values: list of numbers
90
+ */
91
+ static lcm(...values) {
92
+ return values.reduce(function (a, b) {
93
+ return Math.abs(a * b / Numeric.gcd(a, b));
94
+ });
95
+ }
96
+ static pythagoricianTripletsWithTarget(target, targetIsSquare) {
97
+ // méthode inverse, à partir du triplet.
98
+ const triplets = [], targetValue = targetIsSquare === true ? +target : target ** 2;
99
+ for (let u = 0; u <= target; u++) {
100
+ for (let v = 0; v <= target; v++) {
101
+ if (u ** 2 + v ** 2 === targetValue) {
102
+ triplets.push([u, v, target]);
103
+ }
104
+ }
105
+ }
106
+ return triplets;
107
+ }
108
+ static numberCorrection(value, epsilonDigit = 1, epsilonNumberOfDigits = 10, number_of_digits = 8) {
109
+ return +value.toFixed(number_of_digits);
110
+ //
111
+ // // Must modify the number if it's like:
112
+ // // a: 3.0000000000000003
113
+ // // b: 3.9999999999999994
114
+ // // remove the last character
115
+ // // check if around n last characters are either 0 or 9
116
+ // // if it is, 'round' the number.
117
+ // function extractDecimalPart(valueToExtract: number, decimalLength: number){
118
+ // let decimal = valueToExtract.toString()
119
+ //
120
+ // if (!decimal.includes('.')) {
121
+ // return ''
122
+ // }
123
+ //
124
+ // decimal = decimal.split('.')[1]
125
+ // return decimal.substring(0, decimalLength)
126
+ // }
127
+ //
128
+ // const epsilon = Number(`0.${"0".repeat(epsilonNumberOfDigits-1)}${epsilonDigit}`)
129
+ // const decimal = extractDecimalPart(value, epsilonNumberOfDigits)
130
+ // if(decimal===''){return value}
131
+ //
132
+ // const n9 = decimal.match(/9+$/g)
133
+ // const n0 = decimal.match(/0+$/g)
134
+ //
135
+ // if (n9 && n9[0].length >= number_of_digits) {
136
+ // // New tested values.
137
+ // const mod = extractDecimalPart(value + epsilon, epsilonNumberOfDigits),
138
+ // mod0 = mod.match(/0+$/g)
139
+ //
140
+ // if(mod0 && mod0[0].length>= number_of_digits){
141
+ // return +((value+epsilon).toString().split(mod0[0])[0])
142
+ // }
143
+ // }
144
+ //
145
+ // if (n0 && n0[0].length >= number_of_digits) {
146
+ // // New tested values.
147
+ // const mod = extractDecimalPart(value - epsilon, epsilonNumberOfDigits),
148
+ // mod9 = mod.match(/9+$/g)
149
+ //
150
+ // if(mod9 && mod9[0].length>= number_of_digits){
151
+ // // The value can be changed. Remove all nines!
152
+ // return +(value.toString().split(n0[0])[0])
153
+ // }
154
+ // }
155
+ //
156
+ // return value
157
+ }
158
+ static periodic(value) {
159
+ if (Number.isSafeInteger(value)) {
160
+ return 0;
161
+ }
162
+ // Assume it's with decimal.
163
+ let decimal = (value.toString()).split('.')[0];
164
+ // The decimal part is limited
165
+ if (decimal.length < 10) {
166
+ return 0;
167
+ }
168
+ // Find the periodic if it exists.
169
+ }
170
+ static decompose(value) {
171
+ let dividers = Numeric.dividers(value), limit = Math.sqrt(value), arr = [], u, v;
172
+ while (dividers.length > 0) {
173
+ u = dividers.shift();
174
+ v = dividers.length > 0 ? dividers.pop() : +u;
175
+ arr.push([u, v]);
176
+ }
177
+ return arr;
178
+ }
179
+ }
180
+ exports.Numeric = Numeric;
181
181
  //# sourceMappingURL=numeric.js.map
@@ -0,0 +1,19 @@
1
+ export declare class NumExp {
2
+ private _rpn;
3
+ private _expression;
4
+ private _isValid;
5
+ constructor(value: string, uniformize?: boolean);
6
+ get rpn(): {
7
+ token: string;
8
+ tokenType: string;
9
+ }[];
10
+ get isValid(): boolean;
11
+ set isValid(value: boolean);
12
+ get expression(): string;
13
+ private _extractDecimalPart;
14
+ private _numberCorrection;
15
+ private _addToStack;
16
+ evaluate(values: {
17
+ [Key: string]: number;
18
+ }): number;
19
+ }
@@ -0,0 +1,186 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NumExp = void 0;
4
+ const shutingyard_1 = require("./shutingyard");
5
+ const fraction_1 = require("./coefficients/fraction");
6
+ class NumExp {
7
+ constructor(value, uniformize) {
8
+ this._expression = value;
9
+ try {
10
+ this._rpn = new shutingyard_1.Shutingyard(shutingyard_1.ShutingyardMode.NUMERIC).parse(value, uniformize || uniformize === undefined).rpn;
11
+ }
12
+ catch (e) {
13
+ this._rpn = null;
14
+ this._isValid = false;
15
+ }
16
+ }
17
+ get rpn() {
18
+ return this._rpn;
19
+ }
20
+ get isValid() {
21
+ if (this._isValid === undefined) {
22
+ try {
23
+ const v = this.evaluate({ x: 0 });
24
+ }
25
+ catch {
26
+ this._isValid = false;
27
+ }
28
+ }
29
+ return this._isValid;
30
+ }
31
+ set isValid(value) {
32
+ this._isValid = value;
33
+ }
34
+ get expression() {
35
+ return this._expression;
36
+ }
37
+ _extractDecimalPart(value) {
38
+ let decimal = value.toString();
39
+ if (!decimal.includes('.')) {
40
+ return '';
41
+ }
42
+ decimal = decimal.split('.')[1];
43
+ return decimal.substring(0, decimal.length - 2);
44
+ }
45
+ _numberCorrection(value) {
46
+ // Must modify the number if it's like:
47
+ // a: 3.0000000000000003
48
+ // b: 3.9999999999999994
49
+ // remove the last character
50
+ // check if around n last characters are either 0 or 9
51
+ // if it is, 'round' the number.
52
+ const epsilon = 0.00000000000001, number_of_digits = 6;
53
+ const decimal = this._extractDecimalPart(value);
54
+ if (decimal === '') {
55
+ return value;
56
+ }
57
+ const n9 = decimal.match(/9+$/g);
58
+ const n0 = decimal.match(/0+$/g);
59
+ if (n9 && n9[0].length >= number_of_digits) {
60
+ // New tested values.
61
+ const mod = this._extractDecimalPart(value + epsilon), mod0 = mod.match(/0+$/g);
62
+ if (mod0 && mod0[0].length >= number_of_digits) {
63
+ // The value can be changed. Remove all zeros!
64
+ return +((value + epsilon).toString().split(mod0[0])[0]);
65
+ }
66
+ }
67
+ if (n0 && n0[0].length >= number_of_digits) {
68
+ // New tested values.
69
+ const mod = this._extractDecimalPart(value - epsilon), mod9 = mod.match(/9+$/g);
70
+ if (mod9 && mod9[0].length >= number_of_digits) {
71
+ // The value can be changed. Remove all nines!
72
+ return +(value.toString().split(n0[0])[0]);
73
+ }
74
+ }
75
+ return value;
76
+ }
77
+ _addToStack(stack, value) {
78
+ stack.push(this._numberCorrection(value));
79
+ }
80
+ evaluate(values) {
81
+ const stack = [];
82
+ if (this._rpn === null) {
83
+ this._isValid = false;
84
+ return 0;
85
+ }
86
+ this.isValid = true;
87
+ for (const element of this._rpn) {
88
+ if (element.tokenType === shutingyard_1.ShutingyardType.COEFFICIENT) {
89
+ // May be a numeric value or a Fraction.
90
+ if (!isNaN(+element.token)) {
91
+ this._addToStack(stack, +element.token);
92
+ }
93
+ else {
94
+ this._addToStack(stack, new fraction_1.Fraction(element.token).value);
95
+ }
96
+ }
97
+ else if (element.tokenType === shutingyard_1.ShutingyardType.VARIABLE) {
98
+ if (values[element.token] !== undefined) {
99
+ this._addToStack(stack, +values[element.token]);
100
+ }
101
+ }
102
+ else if (element.tokenType === shutingyard_1.ShutingyardType.CONSTANT) {
103
+ this._addToStack(stack, shutingyard_1.tokenConstant[element.token]);
104
+ }
105
+ else if (element.tokenType === shutingyard_1.ShutingyardType.OPERATION) {
106
+ if (element.token === '*') {
107
+ const b = stack.pop(), a = stack.pop();
108
+ if (a === undefined || b === undefined) {
109
+ this.isValid = false;
110
+ }
111
+ this._addToStack(stack, a * b);
112
+ }
113
+ else if (element.token === '/') {
114
+ const b = stack.pop(), a = stack.pop();
115
+ if (a === undefined || b === undefined) {
116
+ this.isValid = false;
117
+ }
118
+ this._addToStack(stack, a / b);
119
+ }
120
+ else if (element.token === '+') {
121
+ const b = stack.pop(), a = stack.pop();
122
+ if (a === undefined || b === undefined) {
123
+ this.isValid = false;
124
+ }
125
+ this._addToStack(stack, (+a) + (+b));
126
+ }
127
+ else if (element.token === '-') {
128
+ const b = stack.pop(), a = stack.pop() || 0;
129
+ if (b === undefined) {
130
+ this.isValid = false;
131
+ }
132
+ this._addToStack(stack, a - b);
133
+ }
134
+ else if (element.token === '^') {
135
+ const b = stack.pop(), a = stack.pop();
136
+ if (a === undefined || b === undefined) {
137
+ this.isValid = false;
138
+ }
139
+ this._addToStack(stack, Math.pow(a, b));
140
+ }
141
+ }
142
+ else if (element.tokenType === shutingyard_1.ShutingyardType.FUNCTION) {
143
+ const a = stack.pop();
144
+ if (a === undefined) {
145
+ this.isValid = false;
146
+ }
147
+ if (element.token === 'sin') {
148
+ this._addToStack(stack, Math.sin(a));
149
+ }
150
+ else if (element.token === 'cos') {
151
+ this._addToStack(stack, Math.cos(a));
152
+ }
153
+ else if (element.token === 'tan') {
154
+ this._addToStack(stack, Math.tan(a));
155
+ }
156
+ else if (element.token === 'sqrt') {
157
+ this._addToStack(stack, Math.sqrt(a));
158
+ }
159
+ else if (element.token === 'nthrt') {
160
+ // TODO: support nthrt in num. exp.
161
+ let b = stack.pop();
162
+ if (a % 2 === 0 && b < 0) {
163
+ this._addToStack(stack, NaN);
164
+ }
165
+ else {
166
+ this._addToStack(stack, (b < 0 ? -1 : 1) * Math.pow(Math.abs(b), 1 / a));
167
+ }
168
+ }
169
+ else if (element.token === 'ln') {
170
+ this._addToStack(stack, Math.log(a));
171
+ }
172
+ else if (element.token === 'log') {
173
+ this._addToStack(stack, Math.log10(a));
174
+ }
175
+ }
176
+ }
177
+ if (stack.length === 1) {
178
+ return stack[0];
179
+ }
180
+ else {
181
+ throw `There was a problem parsing: ${this._expression}`;
182
+ }
183
+ }
184
+ }
185
+ exports.NumExp = NumExp;
186
+ //# sourceMappingURL=numexp.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"numexp.js","sourceRoot":"","sources":["../../src/maths/numexp.ts"],"names":[],"mappings":"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"}
@@ -1,23 +1,23 @@
1
- import { randomCoefficientConfig, randomGeometryLineConfig, randomGeometryPointConfig, randomMonomConfig, randomPolynomConfig } from "./rndTypes";
2
- import { Polynom } from "../algebra/polynom";
3
- import { Monom } from "../algebra/monom";
4
- import { Fraction } from "../coefficients/fraction";
5
- import { Line } from "../geometry/line";
6
- import { Point } from "../geometry/point";
7
- export * from "./rndTypes";
8
- export declare namespace Random {
9
- function polynom(config?: randomPolynomConfig): Polynom;
10
- function monom(config?: randomMonomConfig): Monom;
11
- function fraction(config?: randomCoefficientConfig): Fraction;
12
- function number(from: number, to: number): number;
13
- function numberSym(max: number, allowZero?: boolean): number;
14
- function prime(max: number): number;
15
- function bool(percent?: number): boolean;
16
- function array(arr: any[], number?: number): any[];
17
- function item(arr: any[]): any;
18
- function shuffle(arr: any[]): any[];
19
- namespace Geometry {
20
- function line(config?: randomGeometryLineConfig): Line;
21
- function point(config?: randomGeometryPointConfig): Point;
22
- }
23
- }
1
+ import { randomCoefficientConfig, randomGeometryLineConfig, randomGeometryPointConfig, randomMonomConfig, randomPolynomConfig } from "./rndTypes";
2
+ import { Polynom } from "../algebra/polynom";
3
+ import { Monom } from "../algebra/monom";
4
+ import { Fraction } from "../coefficients/fraction";
5
+ import { Line } from "../geometry/line";
6
+ import { Point } from "../geometry/point";
7
+ export * from "./rndTypes";
8
+ export declare namespace Random {
9
+ function polynom(config?: randomPolynomConfig): Polynom;
10
+ function monom(config?: randomMonomConfig): Monom;
11
+ function fraction(config?: randomCoefficientConfig): Fraction;
12
+ function number(from: number, to: number): number;
13
+ function numberSym(max: number, allowZero?: boolean): number;
14
+ function prime(max: number): number;
15
+ function bool(percent?: number): boolean;
16
+ function array(arr: any[], number?: number): any[];
17
+ function item(arr: any[]): any;
18
+ function shuffle(arr: any[]): any[];
19
+ namespace Geometry {
20
+ function line(config?: randomGeometryLineConfig): Line;
21
+ function point(config?: randomGeometryPointConfig): Point;
22
+ }
23
+ }