math-exercises 1.3.31 → 1.3.32

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 (368) hide show
  1. package/README.md +73 -73
  2. package/lib/exercises/calcul/addAndSub.d.ts +6 -6
  3. package/lib/exercises/calcul/addAndSub.js +41 -41
  4. package/lib/exercises/calcul/addAndSubWithoutRelatives.d.ts +6 -6
  5. package/lib/exercises/calcul/addAndSubWithoutRelatives.js +51 -51
  6. package/lib/exercises/calcul/fractions/fractionAndIntegerDivision.d.ts +3 -3
  7. package/lib/exercises/calcul/fractions/fractionAndIntegerDivision.js +37 -37
  8. package/lib/exercises/calcul/fractions/fractionAndIntegerProduct.d.ts +3 -3
  9. package/lib/exercises/calcul/fractions/fractionAndIntegerProduct.js +34 -34
  10. package/lib/exercises/calcul/fractions/fractionAndIntegerSum.d.ts +3 -3
  11. package/lib/exercises/calcul/fractions/fractionAndIntegerSum.js +34 -34
  12. package/lib/exercises/calcul/fractions/fractionToPercentToDecimal.d.ts +3 -3
  13. package/lib/exercises/calcul/fractions/fractionToPercentToDecimal.js +69 -69
  14. package/lib/exercises/calcul/fractions/fractionsDivision.d.ts +3 -3
  15. package/lib/exercises/calcul/fractions/fractionsDivision.js +31 -31
  16. package/lib/exercises/calcul/fractions/fractionsProduct.d.ts +3 -3
  17. package/lib/exercises/calcul/fractions/fractionsProduct.js +30 -30
  18. package/lib/exercises/calcul/fractions/fractionsSum.d.ts +3 -3
  19. package/lib/exercises/calcul/fractions/fractionsSum.js +30 -30
  20. package/lib/exercises/calcul/fractions/simplifyFraction.d.ts +3 -3
  21. package/lib/exercises/calcul/fractions/simplifyFraction.js +26 -26
  22. package/lib/exercises/calcul/mentalCaluls.ts/mentalAddAndSub.d.ts +3 -3
  23. package/lib/exercises/calcul/mentalCaluls.ts/mentalAddAndSub.js +46 -46
  24. package/lib/exercises/calcul/mentalCaluls.ts/mentalDivisions.d.ts +3 -3
  25. package/lib/exercises/calcul/mentalCaluls.ts/mentalDivisions.js +64 -64
  26. package/lib/exercises/calcul/mentalCaluls.ts/mentalMultiplications.d.ts +3 -3
  27. package/lib/exercises/calcul/mentalCaluls.ts/mentalMultiplications.js +51 -51
  28. package/lib/exercises/calcul/mentalCaluls.ts/mentalPercentage.d.ts +3 -3
  29. package/lib/exercises/calcul/mentalCaluls.ts/mentalPercentage.js +67 -67
  30. package/lib/exercises/calcul/operations/operationsPriorities.d.ts +10 -10
  31. package/lib/exercises/calcul/operations/operationsPriorities.js +100 -100
  32. package/lib/exercises/calcul/operations/operationsPrioritiesWithoutRelative.d.ts +10 -10
  33. package/lib/exercises/calcul/operations/operationsPrioritiesWithoutRelative.js +181 -181
  34. package/lib/exercises/calcul/operationsPriorities.js +88 -0
  35. package/lib/exercises/calcul/rounding/rounding.d.ts +19 -19
  36. package/lib/exercises/calcul/rounding/rounding.js +87 -87
  37. package/lib/exercises/calculLitteral/distributivity/allIdentities.d.ts +3 -3
  38. package/lib/exercises/calculLitteral/distributivity/allIdentities.js +27 -27
  39. package/lib/exercises/calculLitteral/distributivity/doubleDistributivity.d.ts +3 -3
  40. package/lib/exercises/calculLitteral/distributivity/doubleDistributivity.js +32 -32
  41. package/lib/exercises/calculLitteral/distributivity/firstIdentity.d.ts +3 -3
  42. package/lib/exercises/calculLitteral/distributivity/firstIdentity.js +33 -33
  43. package/lib/exercises/calculLitteral/distributivity/secondIdentity.d.ts +3 -3
  44. package/lib/exercises/calculLitteral/distributivity/secondIdentity.js +34 -34
  45. package/lib/exercises/calculLitteral/distributivity/simpleDistributivity.d.ts +3 -3
  46. package/lib/exercises/calculLitteral/distributivity/simpleDistributivity.js +34 -34
  47. package/lib/exercises/calculLitteral/distributivity/thirdIdentity.d.ts +3 -3
  48. package/lib/exercises/calculLitteral/distributivity/thirdIdentity.js +33 -33
  49. package/lib/exercises/calculLitteral/equation/equationSimpleSquare.d.ts +3 -3
  50. package/lib/exercises/calculLitteral/equation/equationSimpleSquare.js +47 -47
  51. package/lib/exercises/calculLitteral/equation/equationType1Exercise.d.ts +6 -6
  52. package/lib/exercises/calculLitteral/equation/equationType1Exercise.js +39 -39
  53. package/lib/exercises/calculLitteral/equation/equationType2Exercise.d.ts +6 -6
  54. package/lib/exercises/calculLitteral/equation/equationType2Exercise.js +42 -42
  55. package/lib/exercises/calculLitteral/equation/equationType3Exercise.d.ts +6 -6
  56. package/lib/exercises/calculLitteral/equation/equationType3Exercise.js +43 -43
  57. package/lib/exercises/calculLitteral/equation/equationType4Exercise.d.ts +6 -6
  58. package/lib/exercises/calculLitteral/equation/equationType4Exercise.js +45 -45
  59. package/lib/exercises/calculLitteral/equation/firstDegreeEquation.d.ts +3 -3
  60. package/lib/exercises/calculLitteral/equation/firstDegreeEquation.js +30 -30
  61. package/lib/exercises/calculLitteral/equation/firstDegreeGeneralEquation.d.ts +3 -3
  62. package/lib/exercises/calculLitteral/equation/firstDegreeGeneralEquation.js +32 -32
  63. package/lib/exercises/calculLitteral/equation/fractionEquation.d.ts +4 -0
  64. package/lib/exercises/calculLitteral/equation/fractionEquation.d.ts.map +1 -0
  65. package/lib/exercises/calculLitteral/equation/fractionEquation.js +39 -0
  66. package/lib/exercises/calculLitteral/equation/multiplicationEquation.d.ts +4 -0
  67. package/lib/exercises/calculLitteral/equation/multiplicationEquation.d.ts.map +1 -0
  68. package/lib/exercises/calculLitteral/equation/multiplicationEquation.js +39 -0
  69. package/lib/exercises/calculLitteral/factorisation/factoIdRmq1.d.ts +3 -3
  70. package/lib/exercises/calculLitteral/factorisation/factoIdRmq1.js +34 -34
  71. package/lib/exercises/calculLitteral/factorisation/factoIdRmq2.d.ts +3 -3
  72. package/lib/exercises/calculLitteral/factorisation/factoIdRmq2.js +35 -35
  73. package/lib/exercises/calculLitteral/factorisation/factoIdRmq3.d.ts +3 -3
  74. package/lib/exercises/calculLitteral/factorisation/factoIdRmq3.js +34 -34
  75. package/lib/exercises/calculLitteral/factorisation/factoType1Exercise.d.ts +6 -6
  76. package/lib/exercises/calculLitteral/factorisation/factoType1Exercise.js +40 -40
  77. package/lib/exercises/conversion/aeraConversion.d.ts +3 -3
  78. package/lib/exercises/conversion/aeraConversion.js +32 -32
  79. package/lib/exercises/conversion/capacityConversion.d.ts +3 -3
  80. package/lib/exercises/conversion/capacityConversion.js +30 -30
  81. package/lib/exercises/conversion/lengthConversion.d.ts +3 -3
  82. package/lib/exercises/conversion/lengthConversion.js +30 -30
  83. package/lib/exercises/conversion/massConversion.d.ts +3 -3
  84. package/lib/exercises/conversion/massConversion.js +30 -30
  85. package/lib/exercises/conversion/volumeCapacityConversion.d.ts +3 -3
  86. package/lib/exercises/conversion/volumeCapacityConversion.js +47 -47
  87. package/lib/exercises/conversion/volumeConversion.d.ts +3 -3
  88. package/lib/exercises/conversion/volumeConversion.js +32 -32
  89. package/lib/exercises/derivation/derivative/affineDerivative.d.ts +4 -0
  90. package/lib/exercises/derivation/derivative/affineDerivative.d.ts.map +1 -0
  91. package/lib/exercises/derivation/derivative/affineDerivative.js +27 -0
  92. package/lib/exercises/derivation/derivative/constanteDerivative.d.ts +3 -3
  93. package/lib/exercises/derivation/derivative/constanteDerivative.js +27 -27
  94. package/lib/exercises/derivation/derivative/firstDegreeDerivative.d.ts +3 -3
  95. package/lib/exercises/derivation/derivative/firstDegreeDerivative.js +29 -29
  96. package/lib/exercises/derivation/derivative/inverseFunctionDerivative.d.ts +3 -3
  97. package/lib/exercises/derivation/derivative/inverseFunctionDerivative.js +27 -27
  98. package/lib/exercises/derivation/derivative/powerFunctionDerivative.d.ts +3 -3
  99. package/lib/exercises/derivation/derivative/powerFunctionDerivative.js +35 -35
  100. package/lib/exercises/derivation/derivative/rootFunctionDerivative.d.ts +3 -3
  101. package/lib/exercises/derivation/derivative/rootFunctionDerivative.js +40 -40
  102. package/lib/exercises/derivation/derivative/secondDegreeDerivative.d.ts +3 -3
  103. package/lib/exercises/derivation/derivative/secondDegreeDerivative.js +30 -30
  104. package/lib/exercises/derivation/derivative/thirdDegreeDerivative.d.ts +3 -3
  105. package/lib/exercises/derivation/derivative/thirdDegreeDerivative.js +33 -33
  106. package/lib/exercises/derivation/derivative/thridDegreeDerivative.d.ts +1 -0
  107. package/lib/exercises/derivation/derivative/thridDegreeDerivative.d.ts.map +1 -0
  108. package/lib/exercises/derivation/derivative/thridDegreeDerivative.js +1 -0
  109. package/lib/exercises/derivation/derivative/usualderivative.d.ts +3 -3
  110. package/lib/exercises/derivation/derivative/usualderivative.js +36 -36
  111. package/lib/exercises/exercise.d.ts +21 -21
  112. package/lib/exercises/exercise.js +7 -7
  113. package/lib/exercises/exercises.d.ts +1 -1
  114. package/lib/exercises/exercises.d.ts.map +1 -1
  115. package/lib/exercises/exercises.js +224 -198
  116. package/lib/exercises/geometry/cartesian/derivativeNumberReading.d.ts +3 -3
  117. package/lib/exercises/geometry/cartesian/derivativeNumberReading.js +51 -51
  118. package/lib/exercises/geometry/cartesian/derivativeNumberReading2.js +91 -91
  119. package/lib/exercises/geometry/cartesian/leadingCoefficient.d.ts +3 -3
  120. package/lib/exercises/geometry/cartesian/leadingCoefficient.js +60 -60
  121. package/lib/exercises/geometry/cartesian/leadingCoefficientCalculV1.d.ts +4 -0
  122. package/lib/exercises/geometry/cartesian/leadingCoefficientCalculV1.d.ts.map +1 -0
  123. package/lib/exercises/geometry/cartesian/leadingCoefficientCalculV1.js +30 -0
  124. package/lib/exercises/geometry/cartesian/leadingCoefficientCalculV2.d.ts +4 -0
  125. package/lib/exercises/geometry/cartesian/leadingCoefficientCalculV2.d.ts.map +1 -0
  126. package/lib/exercises/geometry/cartesian/leadingCoefficientCalculV2.js +29 -0
  127. package/lib/exercises/geometry/cartesian/midpoint.d.ts +3 -3
  128. package/lib/exercises/geometry/cartesian/midpoint.js +31 -31
  129. package/lib/exercises/geometry/euclidean/TriangleArea.d.ts +4 -0
  130. package/lib/exercises/geometry/euclidean/TriangleArea.d.ts.map +1 -0
  131. package/lib/exercises/geometry/euclidean/TriangleArea.js +53 -0
  132. package/lib/exercises/geometry/euclidean/pythagore.d.ts +4 -0
  133. package/lib/exercises/geometry/euclidean/pythagore.d.ts.map +1 -0
  134. package/lib/exercises/geometry/euclidean/pythagore.js +31 -0
  135. package/lib/exercises/geometry/euclidean/pythagoreCalcul.d.ts +4 -0
  136. package/lib/exercises/geometry/euclidean/pythagoreCalcul.d.ts.map +1 -0
  137. package/lib/exercises/geometry/euclidean/pythagoreCalcul.js +60 -0
  138. package/lib/exercises/geometry/euclidean/rightTriangleArea.d.ts +4 -0
  139. package/lib/exercises/geometry/euclidean/rightTriangleArea.d.ts.map +1 -0
  140. package/lib/exercises/geometry/euclidean/rightTriangleArea.js +39 -0
  141. package/lib/exercises/geometry/euclidean/thales.d.ts +4 -0
  142. package/lib/exercises/geometry/euclidean/thales.d.ts.map +1 -0
  143. package/lib/exercises/geometry/euclidean/thales.js +67 -0
  144. package/lib/exercises/geometry/euclidean/thalesCalcul.d.ts +4 -0
  145. package/lib/exercises/geometry/euclidean/thalesCalcul.d.ts.map +1 -0
  146. package/lib/exercises/geometry/euclidean/thalesCalcul.js +104 -0
  147. package/lib/exercises/geometry/euclidean/trigonometry.d.ts +4 -0
  148. package/lib/exercises/geometry/euclidean/trigonometry.d.ts.map +1 -0
  149. package/lib/exercises/geometry/euclidean/trigonometry.js +55 -0
  150. package/lib/exercises/geometry/euclidean/trigonometryAngleCalcul.d.ts +4 -0
  151. package/lib/exercises/geometry/euclidean/trigonometryAngleCalcul.d.ts.map +1 -0
  152. package/lib/exercises/geometry/euclidean/trigonometryAngleCalcul.js +42 -0
  153. package/lib/exercises/geometry/euclidean/trigonometrySideCalcul.d.ts +4 -0
  154. package/lib/exercises/geometry/euclidean/trigonometrySideCalcul.d.ts.map +1 -0
  155. package/lib/exercises/geometry/euclidean/trigonometrySideCalcul.js +52 -0
  156. package/lib/exercises/geometry/vectors/scalarProductViaCoords.d.ts +3 -3
  157. package/lib/exercises/geometry/vectors/scalarProductViaCoords.js +30 -30
  158. package/lib/exercises/geometry/vectors/scalarProductViaNorms.js +27 -27
  159. package/lib/exercises/percent/applyPercent.d.ts +3 -3
  160. package/lib/exercises/percent/applyPercent.js +41 -41
  161. package/lib/exercises/percent/averageEvolutionRate.d.ts +3 -3
  162. package/lib/exercises/percent/averageEvolutionRate.js +30 -30
  163. package/lib/exercises/percent/globalPercent.d.ts +3 -3
  164. package/lib/exercises/percent/globalPercent.js +44 -44
  165. package/lib/exercises/percent/reciprocalPercentage.d.ts +3 -3
  166. package/lib/exercises/percent/reciprocalPercentage.js +32 -32
  167. package/lib/exercises/powers/powersDivision.d.ts +7 -7
  168. package/lib/exercises/powers/powersDivision.js +46 -46
  169. package/lib/exercises/powers/powersOfTenToDecimal.d.ts +6 -6
  170. package/lib/exercises/powers/powersOfTenToDecimal.js +34 -34
  171. package/lib/exercises/powers/powersPower.d.ts +7 -7
  172. package/lib/exercises/powers/powersPower.js +45 -45
  173. package/lib/exercises/powers/powersProduct.d.ts +7 -7
  174. package/lib/exercises/powers/powersProduct.js +46 -46
  175. package/lib/exercises/powers/scientificToDecimal.d.ts +6 -6
  176. package/lib/exercises/powers/scientificToDecimal.js +39 -39
  177. package/lib/exercises/proba/conditionalProbability.d.ts +3 -3
  178. package/lib/exercises/proba/conditionalProbability.js +74 -74
  179. package/lib/exercises/proba/marginalAndConditionalFrequency.d.ts +3 -3
  180. package/lib/exercises/proba/marginalAndConditionalFrequency.js +81 -81
  181. package/lib/exercises/proba/probabilityTree.d.ts +3 -3
  182. package/lib/exercises/proba/probabilityTree.js +105 -105
  183. package/lib/exercises/sequences/arithmetic/arithmeticExplicitFormulaUsage.d.ts +3 -3
  184. package/lib/exercises/sequences/arithmetic/arithmeticExplicitFormulaUsage.js +31 -31
  185. package/lib/exercises/sequences/arithmetic/arithmeticFindExplicitFormula.d.ts +3 -3
  186. package/lib/exercises/sequences/arithmetic/arithmeticFindExplicitFormula.js +31 -31
  187. package/lib/exercises/sequences/arithmetic/arithmeticFindReason.d.ts +3 -3
  188. package/lib/exercises/sequences/arithmetic/arithmeticFindReason.js +31 -31
  189. package/lib/exercises/sequences/arithmetic/arithmeticReasonUsage.d.ts +3 -3
  190. package/lib/exercises/sequences/arithmetic/arithmeticReasonUsage.js +30 -30
  191. package/lib/exercises/sequences/arithmetic/arithmeticRecurrenceFormulaUsage.d.ts +3 -3
  192. package/lib/exercises/sequences/arithmetic/arithmeticRecurrenceFormulaUsage.js +30 -30
  193. package/lib/exercises/sequences/arithmetic/arithmeticThresholdFind.d.ts +3 -3
  194. package/lib/exercises/sequences/arithmetic/arithmeticThresholdFind.js +40 -40
  195. package/lib/exercises/sequences/geometric/geometricExplicitFormulaUsage.d.ts +3 -3
  196. package/lib/exercises/sequences/geometric/geometricExplicitFormulaUsage.js +36 -36
  197. package/lib/exercises/sequences/geometric/geometricFindExplicitFormula.d.ts +3 -3
  198. package/lib/exercises/sequences/geometric/geometricFindExplicitFormula.js +35 -35
  199. package/lib/exercises/sequences/geometric/geometricFindReason.d.ts +3 -3
  200. package/lib/exercises/sequences/geometric/geometricFindReason.js +31 -31
  201. package/lib/exercises/sequences/geometric/geometricReasonUsage.d.ts +3 -3
  202. package/lib/exercises/sequences/geometric/geometricReasonUsage.js +30 -30
  203. package/lib/exercises/sequences/geometric/geometricRecurrenceFormulaUsage.d.ts +7 -7
  204. package/lib/exercises/sequences/geometric/geometricRecurrenceFormulaUsage.js +30 -30
  205. package/lib/exercises/squareRoots/simpifySquareRoot.d.ts +3 -3
  206. package/lib/exercises/squareRoots/simpifySquareRoot.js +29 -29
  207. package/lib/exercises/trigonometry/mainRemarkableValues.d.ts +3 -3
  208. package/lib/exercises/trigonometry/mainRemarkableValues.js +30 -30
  209. package/lib/exercises/trigonometry/remarkableValues.d.ts +3 -3
  210. package/lib/exercises/trigonometry/remarkableValues.js +30 -30
  211. package/lib/exercises/utils/getDistinctQuestions.d.ts +3 -3
  212. package/lib/exercises/utils/getDistinctQuestions.js +28 -28
  213. package/lib/geometry/point.js +27 -0
  214. package/lib/geometry/vector.js +31 -0
  215. package/lib/index.d.ts +2 -2
  216. package/lib/index.js +6 -6
  217. package/lib/math/geometry/droite.d.ts +19 -19
  218. package/lib/math/geometry/droite.d.ts.map +1 -1
  219. package/lib/math/geometry/droite.js +62 -61
  220. package/lib/math/geometry/point.d.ts +29 -25
  221. package/lib/math/geometry/point.d.ts.map +1 -1
  222. package/lib/math/geometry/point.js +55 -40
  223. package/lib/math/geometry/triangles.d.ts +54 -0
  224. package/lib/math/geometry/triangles.d.ts.map +1 -0
  225. package/lib/math/geometry/triangles.js +183 -0
  226. package/lib/math/geometry/vector.d.ts +15 -15
  227. package/lib/math/geometry/vector.js +31 -31
  228. package/lib/math/numbers/decimals/decimal.d.ts +24 -24
  229. package/lib/math/numbers/decimals/decimal.js +140 -140
  230. package/lib/math/numbers/epsilon.d.ts +1 -1
  231. package/lib/math/numbers/epsilon.js +10 -10
  232. package/lib/math/numbers/integer/integer.d.ts +14 -14
  233. package/lib/math/numbers/integer/integer.js +68 -68
  234. package/lib/math/numbers/integer/power.d.ts +13 -13
  235. package/lib/math/numbers/integer/power.js +52 -52
  236. package/lib/math/numbers/nombre.d.ts +13 -13
  237. package/lib/math/numbers/nombre.js +10 -10
  238. package/lib/math/numbers/rationals/rational.d.ts +25 -25
  239. package/lib/math/numbers/rationals/rational.js +113 -113
  240. package/lib/math/numbers/reals/real.d.ts +9 -9
  241. package/lib/math/numbers/reals/real.js +16 -16
  242. package/lib/math/numbers/reals/squareRoot.d.ts +18 -18
  243. package/lib/math/numbers/reals/squareRoot.js +63 -63
  244. package/lib/math/polynomials/affine.d.ts +15 -15
  245. package/lib/math/polynomials/affine.js +42 -42
  246. package/lib/math/polynomials/polynomial.d.ts +25 -25
  247. package/lib/math/polynomials/polynomial.js +131 -131
  248. package/lib/math/sequences/arithmeticSequence.js +1 -1
  249. package/lib/math/sequences/geometricSequence.d.ts +3 -3
  250. package/lib/math/sequences/geometricSequence.js +8 -8
  251. package/lib/math/sequences/sequence.d.ts +22 -22
  252. package/lib/math/sequences/sequence.js +21 -21
  253. package/lib/math/sets/discreteSet.d.ts +10 -10
  254. package/lib/math/sets/discreteSet.js +28 -28
  255. package/lib/math/sets/emptySet.js +6 -6
  256. package/lib/math/sets/intervals/intervals.d.ts +26 -26
  257. package/lib/math/sets/intervals/intervals.js +104 -104
  258. package/lib/math/sets/mathSet.d.ts +7 -7
  259. package/lib/math/sets/mathSet.js +10 -10
  260. package/lib/math/sets/mathSetInterface.d.ts +5 -5
  261. package/lib/math/sets/mathSetInterface.js +2 -2
  262. package/lib/math/trigonometry/remarkableValue.d.ts +10 -10
  263. package/lib/math/trigonometry/remarkableValue.js +29 -29
  264. package/lib/math/trigonometry/remarkableValues.d.ts +2 -2
  265. package/lib/math/trigonometry/remarkableValues.js +51 -51
  266. package/lib/math/utils/arithmetic/coprimesOf.d.ts +1 -1
  267. package/lib/math/utils/arithmetic/coprimesOf.js +13 -13
  268. package/lib/math/utils/arithmetic/dividersOf.d.ts +1 -1
  269. package/lib/math/utils/arithmetic/dividersOf.js +12 -12
  270. package/lib/math/utils/arithmetic/gcd.d.ts +1 -1
  271. package/lib/math/utils/arithmetic/gcd.js +7 -7
  272. package/lib/math/utils/arithmetic/isSquare.d.ts +1 -1
  273. package/lib/math/utils/arithmetic/isSquare.js +7 -7
  274. package/lib/math/utils/arithmetic/lcd.d.ts +1 -1
  275. package/lib/math/utils/arithmetic/lcd.js +12 -12
  276. package/lib/math/utils/arithmetic/nonCoprimesOf.d.ts +1 -1
  277. package/lib/math/utils/arithmetic/nonCoprimesOf.js +13 -13
  278. package/lib/math/utils/arithmetic/nonDividersOf.d.ts +1 -1
  279. package/lib/math/utils/arithmetic/nonDividersOf.js +14 -14
  280. package/lib/math/utils/arithmetic/primeFactors.d.ts +5 -5
  281. package/lib/math/utils/arithmetic/primeFactors.js +22 -22
  282. package/lib/math/utils/decimals/decimalPartLengthOf.d.ts +1 -1
  283. package/lib/math/utils/decimals/decimalPartLengthOf.js +14 -14
  284. package/lib/math/utils/random/randTupleInt.d.ts +13 -13
  285. package/lib/math/utils/random/randTupleInt.js +30 -30
  286. package/lib/math/utils/random/randint.d.ts +4 -4
  287. package/lib/math/utils/random/randint.js +18 -18
  288. package/lib/math/utils/round.d.ts +1 -1
  289. package/lib/math/utils/round.js +8 -8
  290. package/lib/mathutils/arithmetic/coprimesOf.js +13 -0
  291. package/lib/mathutils/arithmetic/dividersOf.js +12 -0
  292. package/lib/mathutils/arithmetic/gcd.js +7 -0
  293. package/lib/mathutils/arithmetic/isSquare.js +7 -0
  294. package/lib/mathutils/arithmetic/lcd.js +12 -0
  295. package/lib/mathutils/arithmetic/nonCoprimesOf.js +13 -0
  296. package/lib/mathutils/arithmetic/nonDividersOf.js +14 -0
  297. package/lib/mathutils/arithmetic/primeFactors.js +22 -0
  298. package/lib/mathutils/decimals/decimalPartLengthOf.js +14 -0
  299. package/lib/mathutils/random/randTupleInt.js +30 -0
  300. package/lib/mathutils/random/randint.js +18 -0
  301. package/lib/mathutils/round.js +8 -0
  302. package/lib/numbers/decimals/decimal.js +140 -0
  303. package/lib/numbers/epsilon.js +10 -0
  304. package/lib/numbers/integer/integer.js +68 -0
  305. package/lib/numbers/integer/power.js +52 -0
  306. package/lib/numbers/nombre.js +10 -0
  307. package/lib/numbers/rationals/rational.js +113 -0
  308. package/lib/numbers/reals/real.js +16 -0
  309. package/lib/numbers/reals/squareRoot.js +63 -0
  310. package/lib/polynomials/affine.js +42 -0
  311. package/lib/polynomials/polynomial.js +125 -0
  312. package/lib/server.d.ts +1 -1
  313. package/lib/server.js +53 -53
  314. package/lib/sets/discreteSet.js +28 -0
  315. package/lib/sets/emptySet.js +6 -0
  316. package/lib/sets/intervals/intervals.js +108 -0
  317. package/lib/sets/intervals/union.js +1 -0
  318. package/lib/sets/mathSet.js +10 -0
  319. package/lib/sets/mathSetInterface.js +2 -0
  320. package/lib/tree/nodes/functions/cosNode.d.ts +9 -9
  321. package/lib/tree/nodes/functions/cosNode.js +21 -21
  322. package/lib/tree/nodes/functions/functionNode.d.ts +14 -14
  323. package/lib/tree/nodes/functions/functionNode.js +20 -20
  324. package/lib/tree/nodes/functions/oppositeNode.d.ts +7 -7
  325. package/lib/tree/nodes/functions/oppositeNode.js +26 -26
  326. package/lib/tree/nodes/functions/sinNode.js +1 -1
  327. package/lib/tree/nodes/functions/sqrtNode.d.ts +8 -8
  328. package/lib/tree/nodes/functions/sqrtNode.js +18 -18
  329. package/lib/tree/nodes/node.d.ts +12 -12
  330. package/lib/tree/nodes/node.js +11 -11
  331. package/lib/tree/nodes/numbers/constantNode.d.ts +9 -9
  332. package/lib/tree/nodes/numbers/constantNode.js +18 -18
  333. package/lib/tree/nodes/numbers/numberNode.d.ts +10 -10
  334. package/lib/tree/nodes/numbers/numberNode.js +19 -19
  335. package/lib/tree/nodes/numbers/piNode.d.ts +2 -2
  336. package/lib/tree/nodes/numbers/piNode.js +5 -5
  337. package/lib/tree/nodes/operators/addNode.d.ts +7 -7
  338. package/lib/tree/nodes/operators/addNode.js +19 -19
  339. package/lib/tree/nodes/operators/divideNode.d.ts +11 -11
  340. package/lib/tree/nodes/operators/divideNode.js +34 -34
  341. package/lib/tree/nodes/operators/equalNode.d.ts +7 -7
  342. package/lib/tree/nodes/operators/equalNode.js +16 -16
  343. package/lib/tree/nodes/operators/fractionNode.d.ts +11 -11
  344. package/lib/tree/nodes/operators/fractionNode.js +20 -20
  345. package/lib/tree/nodes/operators/multiplyNode.d.ts +7 -7
  346. package/lib/tree/nodes/operators/multiplyNode.js +43 -43
  347. package/lib/tree/nodes/operators/operatorNode.d.ts +21 -21
  348. package/lib/tree/nodes/operators/operatorNode.js +35 -35
  349. package/lib/tree/nodes/operators/powerNode.d.ts +7 -7
  350. package/lib/tree/nodes/operators/powerNode.js +33 -33
  351. package/lib/tree/nodes/operators/substractNode.d.ts +7 -7
  352. package/lib/tree/nodes/operators/substractNode.js +24 -24
  353. package/lib/tree/nodes/variables/variableNode.d.ts +8 -8
  354. package/lib/tree/nodes/variables/variableNode.js +19 -19
  355. package/lib/tree/parsers/derivateParser.js +62 -62
  356. package/lib/tree/parsers/latexParser.js +110 -0
  357. package/lib/tree/parsers/simplify.d.ts +2 -2
  358. package/lib/tree/parsers/simplify.js +52 -52
  359. package/lib/utils/arrayEqual.d.ts +1 -1
  360. package/lib/utils/arrayEqual.js +13 -13
  361. package/lib/utils/coin.js +7 -0
  362. package/lib/utils/coinFlip.d.ts +1 -1
  363. package/lib/utils/coinFlip.js +7 -7
  364. package/lib/utils/random.d.ts +1 -1
  365. package/lib/utils/random.js +7 -7
  366. package/lib/utils/shuffle.d.ts +1 -1
  367. package/lib/utils/shuffle.js +15 -15
  368. package/package.json +50 -50
@@ -1,15 +1,15 @@
1
- import { Node } from '../../../tree/nodes/node';
2
- import { Nombre, NumberType } from '../nombre';
3
- export declare abstract class IntegerConstructor {
4
- static random(nbOfDigits: number): number;
5
- }
6
- export declare class Integer implements Nombre {
7
- value: number;
8
- tex: string;
9
- type: NumberType;
10
- constructor(value: number, tex?: string);
11
- toTree(): Node;
12
- round(precision: number): Integer;
13
- divide(nb: Nombre): Nombre;
14
- }
1
+ import { Node } from '../../../tree/nodes/node';
2
+ import { Nombre, NumberType } from '../nombre';
3
+ export declare abstract class IntegerConstructor {
4
+ static random(nbOfDigits: number): number;
5
+ }
6
+ export declare class Integer implements Nombre {
7
+ value: number;
8
+ tex: string;
9
+ type: NumberType;
10
+ constructor(value: number, tex?: string);
11
+ toTree(): Node;
12
+ round(precision: number): Integer;
13
+ divide(nb: Nombre): Nombre;
14
+ }
15
15
  //# sourceMappingURL=integer.d.ts.map
@@ -1,68 +1,68 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Integer = exports.IntegerConstructor = void 0;
4
- const randint_1 = require("../../../math/utils/random/randint");
5
- const numberNode_1 = require("../../../tree/nodes/numbers/numberNode");
6
- const nombre_1 = require("../nombre");
7
- const rational_1 = require("../rationals/rational");
8
- class IntegerConstructor {
9
- static random(nbOfDigits) {
10
- return (0, randint_1.randint)(0, 10 ** nbOfDigits);
11
- }
12
- }
13
- exports.IntegerConstructor = IntegerConstructor;
14
- class Integer {
15
- constructor(value, tex) {
16
- this.value = value;
17
- this.tex = tex || value + '';
18
- this.type = nombre_1.NumberType.Integer;
19
- }
20
- toTree() {
21
- return new numberNode_1.NumberNode(this.value, this.tex);
22
- }
23
- round(precision) {
24
- const intString = this.value + '';
25
- if (precision >= intString.length || precision < 1)
26
- throw Error("can't round to higher precision");
27
- let newInt = '';
28
- const shouldRoundUp = Number(intString[intString.length - precision]) > 4;
29
- if (shouldRoundUp) {
30
- for (let i = 0; i < precision; i++) {
31
- newInt += '0';
32
- }
33
- let retenue = true;
34
- let i = intString.length - precision - 1;
35
- while (retenue) {
36
- const nb = (Number(intString[i]) + 1) % 10;
37
- newInt = '' + nb + newInt;
38
- if (nb === 0) {
39
- i--;
40
- }
41
- else {
42
- retenue = false;
43
- for (let j = i - 1; j > -1; j--) {
44
- newInt = intString[j] + newInt;
45
- }
46
- }
47
- }
48
- }
49
- else {
50
- for (let i = 0; i < intString.length; i++) {
51
- newInt += i < intString.length - precision ? intString[i] : '0';
52
- }
53
- }
54
- return new Integer(Number(newInt));
55
- }
56
- divide(nb) {
57
- switch (nb.type) {
58
- case nombre_1.NumberType.Integer:
59
- return new rational_1.Rational(this.value, nb.value).simplify();
60
- case nombre_1.NumberType.Rational:
61
- const rational = nb;
62
- return new rational_1.Rational(this.value * rational.denum, rational.num).simplify();
63
- default:
64
- throw Error('not implemented');
65
- }
66
- }
67
- }
68
- exports.Integer = Integer;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Integer = exports.IntegerConstructor = void 0;
4
+ const randint_1 = require("../../../math/utils/random/randint");
5
+ const numberNode_1 = require("../../../tree/nodes/numbers/numberNode");
6
+ const nombre_1 = require("../nombre");
7
+ const rational_1 = require("../rationals/rational");
8
+ class IntegerConstructor {
9
+ static random(nbOfDigits) {
10
+ return (0, randint_1.randint)(0, 10 ** nbOfDigits);
11
+ }
12
+ }
13
+ exports.IntegerConstructor = IntegerConstructor;
14
+ class Integer {
15
+ constructor(value, tex) {
16
+ this.value = value;
17
+ this.tex = tex || value + '';
18
+ this.type = nombre_1.NumberType.Integer;
19
+ }
20
+ toTree() {
21
+ return new numberNode_1.NumberNode(this.value, this.tex);
22
+ }
23
+ round(precision) {
24
+ const intString = this.value + '';
25
+ if (precision >= intString.length || precision < 1)
26
+ throw Error("can't round to higher precision");
27
+ let newInt = '';
28
+ const shouldRoundUp = Number(intString[intString.length - precision]) > 4;
29
+ if (shouldRoundUp) {
30
+ for (let i = 0; i < precision; i++) {
31
+ newInt += '0';
32
+ }
33
+ let retenue = true;
34
+ let i = intString.length - precision - 1;
35
+ while (retenue) {
36
+ const nb = (Number(intString[i]) + 1) % 10;
37
+ newInt = '' + nb + newInt;
38
+ if (nb === 0) {
39
+ i--;
40
+ }
41
+ else {
42
+ retenue = false;
43
+ for (let j = i - 1; j > -1; j--) {
44
+ newInt = intString[j] + newInt;
45
+ }
46
+ }
47
+ }
48
+ }
49
+ else {
50
+ for (let i = 0; i < intString.length; i++) {
51
+ newInt += i < intString.length - precision ? intString[i] : '0';
52
+ }
53
+ }
54
+ return new Integer(Number(newInt));
55
+ }
56
+ divide(nb) {
57
+ switch (nb.type) {
58
+ case nombre_1.NumberType.Integer:
59
+ return new rational_1.Rational(this.value, nb.value).simplify();
60
+ case nombre_1.NumberType.Rational:
61
+ const rational = nb;
62
+ return new rational_1.Rational(this.value * rational.denum, rational.num).simplify();
63
+ default:
64
+ throw Error('not implemented');
65
+ }
66
+ }
67
+ }
68
+ exports.Integer = Integer;
@@ -1,14 +1,14 @@
1
- import { Node } from '../../../tree/nodes/node';
2
- import { Nombre, NumberType } from '../nombre';
3
- export declare class Power implements Nombre {
4
- value: number;
5
- tex: string;
6
- type: NumberType;
7
- operand: number;
8
- power: number;
9
- constructor(a: number, b: number);
10
- simplify(): Node;
11
- toDecimalWriting(): Nombre;
12
- toTree(): Node;
13
- }
1
+ import { Node } from '../../../tree/nodes/node';
2
+ import { Nombre, NumberType } from '../nombre';
3
+ export declare class Power implements Nombre {
4
+ value: number;
5
+ tex: string;
6
+ type: NumberType;
7
+ operand: number;
8
+ power: number;
9
+ constructor(a: number, b: number);
10
+ simplify(): Node;
11
+ toDecimalWriting(): Nombre;
12
+ toTree(): Node;
13
+ }
14
14
  //# sourceMappingURL=power.d.ts.map
@@ -1,52 +1,52 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Power = void 0;
4
- const numberNode_1 = require("../../../tree/nodes/numbers/numberNode");
5
- const powerNode_1 = require("../../../tree/nodes/operators/powerNode");
6
- const nombre_1 = require("../nombre");
7
- const integer_1 = require("./integer");
8
- class Power {
9
- constructor(a, b) {
10
- this.operand = a;
11
- this.power = b;
12
- this.value = Math.pow(a, b);
13
- this.tex = `${a}^{${b}}`;
14
- this.type = b < 0 ? nombre_1.NumberType.Rational : nombre_1.NumberType.Integer;
15
- }
16
- simplify() {
17
- if (this.power === 0)
18
- return new numberNode_1.NumberNode(1);
19
- if (this.power === 1)
20
- return new numberNode_1.NumberNode(this.operand);
21
- if (this.operand === 1)
22
- return new numberNode_1.NumberNode(1);
23
- if (this.operand === 0)
24
- return new numberNode_1.NumberNode(0);
25
- if (this.operand === -1)
26
- return new numberNode_1.NumberNode(this.power % 2 === 0 ? 1 : -1);
27
- return this.toTree();
28
- }
29
- toDecimalWriting() {
30
- if (this.operand !== 10)
31
- throw Error('only implemented for powers of ten so far');
32
- let s = '';
33
- if (this.power > -1) {
34
- s += '1';
35
- for (let i = 0; i < this.power; i++) {
36
- s += 0;
37
- }
38
- }
39
- else {
40
- s += '1';
41
- for (let i = 1; i < Math.abs(this.power); i++) {
42
- s = '0' + s;
43
- }
44
- s = '0.' + s;
45
- }
46
- return new integer_1.Integer(Number(s), s);
47
- }
48
- toTree() {
49
- return new powerNode_1.PowerNode(new numberNode_1.NumberNode(this.operand), new numberNode_1.NumberNode(this.power));
50
- }
51
- }
52
- exports.Power = Power;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Power = void 0;
4
+ const numberNode_1 = require("../../../tree/nodes/numbers/numberNode");
5
+ const powerNode_1 = require("../../../tree/nodes/operators/powerNode");
6
+ const nombre_1 = require("../nombre");
7
+ const integer_1 = require("./integer");
8
+ class Power {
9
+ constructor(a, b) {
10
+ this.operand = a;
11
+ this.power = b;
12
+ this.value = Math.pow(a, b);
13
+ this.tex = `${a}^{${b}}`;
14
+ this.type = b < 0 ? nombre_1.NumberType.Rational : nombre_1.NumberType.Integer;
15
+ }
16
+ simplify() {
17
+ if (this.power === 0)
18
+ return new numberNode_1.NumberNode(1);
19
+ if (this.power === 1)
20
+ return new numberNode_1.NumberNode(this.operand);
21
+ if (this.operand === 1)
22
+ return new numberNode_1.NumberNode(1);
23
+ if (this.operand === 0)
24
+ return new numberNode_1.NumberNode(0);
25
+ if (this.operand === -1)
26
+ return new numberNode_1.NumberNode(this.power % 2 === 0 ? 1 : -1);
27
+ return this.toTree();
28
+ }
29
+ toDecimalWriting() {
30
+ if (this.operand !== 10)
31
+ throw Error('only implemented for powers of ten so far');
32
+ let s = '';
33
+ if (this.power > -1) {
34
+ s += '1';
35
+ for (let i = 0; i < this.power; i++) {
36
+ s += 0;
37
+ }
38
+ }
39
+ else {
40
+ s += '1';
41
+ for (let i = 1; i < Math.abs(this.power); i++) {
42
+ s = '0' + s;
43
+ }
44
+ s = '0.' + s;
45
+ }
46
+ return new integer_1.Integer(Number(s), s);
47
+ }
48
+ toTree() {
49
+ return new powerNode_1.PowerNode(new numberNode_1.NumberNode(this.operand), new numberNode_1.NumberNode(this.power));
50
+ }
51
+ }
52
+ exports.Power = Power;
@@ -1,14 +1,14 @@
1
- import { Node } from '../../tree/nodes/node';
2
- export declare enum NumberType {
3
- Integer = 0,
4
- Decimal = 1,
5
- Rational = 2,
6
- Real = 3
7
- }
8
- export interface Nombre {
9
- value: number;
10
- tex: string;
11
- type: NumberType;
12
- toTree: () => Node;
13
- }
1
+ import { Node } from '../../tree/nodes/node';
2
+ export declare enum NumberType {
3
+ Integer = 0,
4
+ Decimal = 1,
5
+ Rational = 2,
6
+ Real = 3
7
+ }
8
+ export interface Nombre {
9
+ value: number;
10
+ tex: string;
11
+ type: NumberType;
12
+ toTree: () => Node;
13
+ }
14
14
  //# sourceMappingURL=nombre.d.ts.map
@@ -1,10 +1,10 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.NumberType = void 0;
4
- var NumberType;
5
- (function (NumberType) {
6
- NumberType[NumberType["Integer"] = 0] = "Integer";
7
- NumberType[NumberType["Decimal"] = 1] = "Decimal";
8
- NumberType[NumberType["Rational"] = 2] = "Rational";
9
- NumberType[NumberType["Real"] = 3] = "Real";
10
- })(NumberType = exports.NumberType || (exports.NumberType = {}));
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NumberType = void 0;
4
+ var NumberType;
5
+ (function (NumberType) {
6
+ NumberType[NumberType["Integer"] = 0] = "Integer";
7
+ NumberType[NumberType["Decimal"] = 1] = "Decimal";
8
+ NumberType[NumberType["Rational"] = 2] = "Rational";
9
+ NumberType[NumberType["Real"] = 3] = "Real";
10
+ })(NumberType = exports.NumberType || (exports.NumberType = {}));
@@ -1,26 +1,26 @@
1
- import { Node } from '../../../tree/nodes/node';
2
- import { Nombre, NumberType } from '../nombre';
3
- export declare abstract class RationalConstructor {
4
- /**
5
- * @param maxGcd max number by which the fraction is simplifiable
6
- */
7
- static randomSimplifiable(maxGcd?: number): Rational;
8
- static randomIrreductible(max?: number): Rational;
9
- }
10
- export declare class Rational implements Nombre {
11
- num: number;
12
- denum: number;
13
- tex: string;
14
- value: number;
15
- isSimplified: boolean;
16
- type: NumberType;
17
- constructor(numerator: number, denumerator: number);
18
- toTex(): string;
19
- add(nb: Nombre): Nombre;
20
- multiply(nb: Nombre): Nombre;
21
- divide(nb: Nombre): Nombre;
22
- opposite(): Rational;
23
- toTree(): Node;
24
- simplify(): Nombre;
25
- }
1
+ import { Node } from '../../../tree/nodes/node';
2
+ import { Nombre, NumberType } from '../nombre';
3
+ export declare abstract class RationalConstructor {
4
+ /**
5
+ * @param maxGcd max number by which the fraction is simplifiable
6
+ */
7
+ static randomSimplifiable(maxGcd?: number): Rational;
8
+ static randomIrreductible(max?: number): Rational;
9
+ }
10
+ export declare class Rational implements Nombre {
11
+ num: number;
12
+ denum: number;
13
+ tex: string;
14
+ value: number;
15
+ isSimplified: boolean;
16
+ type: NumberType;
17
+ constructor(numerator: number, denumerator: number);
18
+ toTex(): string;
19
+ add(nb: Nombre): Nombre;
20
+ multiply(nb: Nombre): Nombre;
21
+ divide(nb: Nombre): Nombre;
22
+ opposite(): Rational;
23
+ toTree(): Node;
24
+ simplify(): Nombre;
25
+ }
26
26
  //# sourceMappingURL=rational.d.ts.map
@@ -1,113 +1,113 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Rational = exports.RationalConstructor = void 0;
4
- const coprimesOf_1 = require("../../../math/utils/arithmetic/coprimesOf");
5
- const gcd_1 = require("../../../math/utils/arithmetic/gcd");
6
- const lcd_1 = require("../../../math/utils/arithmetic/lcd");
7
- const randint_1 = require("../../../math/utils/random/randint");
8
- const numberNode_1 = require("../../../tree/nodes/numbers/numberNode");
9
- const fractionNode_1 = require("../../../tree/nodes/operators/fractionNode");
10
- const random_1 = require("../../../utils/random");
11
- const shuffle_1 = require("../../../utils/shuffle");
12
- const integer_1 = require("../integer/integer");
13
- const nombre_1 = require("../nombre");
14
- class RationalConstructor {
15
- /**
16
- * @param maxGcd max number by which the fraction is simplifiable
17
- */
18
- static randomSimplifiable(maxGcd = 10) {
19
- const gcd = (0, randint_1.randint)(2, maxGcd);
20
- const max = (0, randint_1.randint)(3, 11);
21
- const min = (0, random_1.random)((0, coprimesOf_1.coprimesOf)(max));
22
- let [num, denum] = (0, shuffle_1.shuffle)([gcd * min, gcd * max]);
23
- if (denum === gcd) {
24
- //si 10/2 on transforme en 2/10
25
- return new Rational(denum, num);
26
- }
27
- return new Rational(num, denum);
28
- }
29
- static randomIrreductible(max = 11) {
30
- const a = (0, randint_1.randint)(2, max);
31
- const b = (0, random_1.random)([...(0, coprimesOf_1.coprimesOf)(a), 1]);
32
- if (b === 1)
33
- return new Rational(b, a);
34
- const [num, denum] = (0, shuffle_1.shuffle)([a, b]);
35
- return new Rational(num, denum);
36
- }
37
- }
38
- exports.RationalConstructor = RationalConstructor;
39
- class Rational {
40
- constructor(numerator, denumerator) {
41
- if (denumerator === 0)
42
- throw Error('division by zero');
43
- this.num = numerator;
44
- this.denum = denumerator;
45
- this.value = numerator / denumerator;
46
- this.isSimplified = Math.abs((0, gcd_1.gcd)(numerator, denumerator)) === 1;
47
- this.tex = `\\frac{${this.num}}{${this.denum}}`;
48
- this.type = nombre_1.NumberType.Rational;
49
- }
50
- toTex() {
51
- return `\\frac{${this.num}}{${this.denum}}`;
52
- }
53
- add(nb) {
54
- switch (nb.type) {
55
- case nombre_1.NumberType.Integer: {
56
- const num = this.num + this.denum * nb.value;
57
- return new Rational(num, this.denum).simplify();
58
- }
59
- case nombre_1.NumberType.Rational: {
60
- const rational = nb;
61
- const ppcm = (0, lcd_1.lcd)(rational.denum, this.denum);
62
- const num = this.num * (ppcm / this.denum) + rational.num * (ppcm / rational.denum);
63
- return new Rational(num, ppcm).simplify();
64
- }
65
- }
66
- throw Error('not implemented yet');
67
- }
68
- multiply(nb) {
69
- switch (nb.type) {
70
- case nombre_1.NumberType.Integer: {
71
- const num = this.num * nb.value;
72
- const denum = this.denum;
73
- return new Rational(num, denum).simplify();
74
- }
75
- case nombre_1.NumberType.Rational: {
76
- const rational = nb;
77
- const num = this.num * rational.num;
78
- const denum = this.denum * rational.denum;
79
- return new Rational(num, denum).simplify();
80
- }
81
- }
82
- throw Error('not implemented yet');
83
- }
84
- divide(nb) {
85
- switch (nb.type) {
86
- case nombre_1.NumberType.Integer: {
87
- const denum = this.denum * nb.value;
88
- return new Rational(this.num, denum).simplify();
89
- }
90
- case nombre_1.NumberType.Rational: {
91
- const rational = nb;
92
- const num = this.num * rational.denum;
93
- const denum = this.denum * rational.num;
94
- return new Rational(num, denum).simplify();
95
- }
96
- }
97
- throw Error('not implemented yet');
98
- }
99
- opposite() {
100
- return new Rational(-this.num, this.denum);
101
- }
102
- toTree() {
103
- return new fractionNode_1.FractionNode(new numberNode_1.NumberNode(this.num), new numberNode_1.NumberNode(this.denum));
104
- }
105
- simplify() {
106
- const sign = (this.num > 0 && this.denum > 0) || (this.num < 0 && this.denum < 0) ? 1 : -1;
107
- const div = Math.abs((0, gcd_1.gcd)(this.num, this.denum));
108
- if (Math.abs(this.denum) === div)
109
- return new integer_1.Integer(this.num / this.denum);
110
- return new Rational((sign * Math.abs(this.num)) / div, Math.abs(this.denum) / div);
111
- }
112
- }
113
- exports.Rational = Rational;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Rational = exports.RationalConstructor = void 0;
4
+ const coprimesOf_1 = require("../../../math/utils/arithmetic/coprimesOf");
5
+ const gcd_1 = require("../../../math/utils/arithmetic/gcd");
6
+ const lcd_1 = require("../../../math/utils/arithmetic/lcd");
7
+ const randint_1 = require("../../../math/utils/random/randint");
8
+ const numberNode_1 = require("../../../tree/nodes/numbers/numberNode");
9
+ const fractionNode_1 = require("../../../tree/nodes/operators/fractionNode");
10
+ const random_1 = require("../../../utils/random");
11
+ const shuffle_1 = require("../../../utils/shuffle");
12
+ const integer_1 = require("../integer/integer");
13
+ const nombre_1 = require("../nombre");
14
+ class RationalConstructor {
15
+ /**
16
+ * @param maxGcd max number by which the fraction is simplifiable
17
+ */
18
+ static randomSimplifiable(maxGcd = 10) {
19
+ const gcd = (0, randint_1.randint)(2, maxGcd);
20
+ const max = (0, randint_1.randint)(3, 11);
21
+ const min = (0, random_1.random)((0, coprimesOf_1.coprimesOf)(max));
22
+ let [num, denum] = (0, shuffle_1.shuffle)([gcd * min, gcd * max]);
23
+ if (denum === gcd) {
24
+ //si 10/2 on transforme en 2/10
25
+ return new Rational(denum, num);
26
+ }
27
+ return new Rational(num, denum);
28
+ }
29
+ static randomIrreductible(max = 11) {
30
+ const a = (0, randint_1.randint)(2, max);
31
+ const b = (0, random_1.random)([...(0, coprimesOf_1.coprimesOf)(a), 1]);
32
+ if (b === 1)
33
+ return new Rational(b, a);
34
+ const [num, denum] = (0, shuffle_1.shuffle)([a, b]);
35
+ return new Rational(num, denum);
36
+ }
37
+ }
38
+ exports.RationalConstructor = RationalConstructor;
39
+ class Rational {
40
+ constructor(numerator, denumerator) {
41
+ if (denumerator === 0)
42
+ throw Error('division by zero');
43
+ this.num = numerator;
44
+ this.denum = denumerator;
45
+ this.value = numerator / denumerator;
46
+ this.isSimplified = Math.abs((0, gcd_1.gcd)(numerator, denumerator)) === 1;
47
+ this.tex = `\\frac{${this.num}}{${this.denum}}`;
48
+ this.type = nombre_1.NumberType.Rational;
49
+ }
50
+ toTex() {
51
+ return `\\frac{${this.num}}{${this.denum}}`;
52
+ }
53
+ add(nb) {
54
+ switch (nb.type) {
55
+ case nombre_1.NumberType.Integer: {
56
+ const num = this.num + this.denum * nb.value;
57
+ return new Rational(num, this.denum).simplify();
58
+ }
59
+ case nombre_1.NumberType.Rational: {
60
+ const rational = nb;
61
+ const ppcm = (0, lcd_1.lcd)(rational.denum, this.denum);
62
+ const num = this.num * (ppcm / this.denum) + rational.num * (ppcm / rational.denum);
63
+ return new Rational(num, ppcm).simplify();
64
+ }
65
+ }
66
+ throw Error('not implemented yet');
67
+ }
68
+ multiply(nb) {
69
+ switch (nb.type) {
70
+ case nombre_1.NumberType.Integer: {
71
+ const num = this.num * nb.value;
72
+ const denum = this.denum;
73
+ return new Rational(num, denum).simplify();
74
+ }
75
+ case nombre_1.NumberType.Rational: {
76
+ const rational = nb;
77
+ const num = this.num * rational.num;
78
+ const denum = this.denum * rational.denum;
79
+ return new Rational(num, denum).simplify();
80
+ }
81
+ }
82
+ throw Error('not implemented yet');
83
+ }
84
+ divide(nb) {
85
+ switch (nb.type) {
86
+ case nombre_1.NumberType.Integer: {
87
+ const denum = this.denum * nb.value;
88
+ return new Rational(this.num, denum).simplify();
89
+ }
90
+ case nombre_1.NumberType.Rational: {
91
+ const rational = nb;
92
+ const num = this.num * rational.denum;
93
+ const denum = this.denum * rational.num;
94
+ return new Rational(num, denum).simplify();
95
+ }
96
+ }
97
+ throw Error('not implemented yet');
98
+ }
99
+ opposite() {
100
+ return new Rational(-this.num, this.denum);
101
+ }
102
+ toTree() {
103
+ return new fractionNode_1.FractionNode(new numberNode_1.NumberNode(this.num), new numberNode_1.NumberNode(this.denum));
104
+ }
105
+ simplify() {
106
+ const sign = (this.num > 0 && this.denum > 0) || (this.num < 0 && this.denum < 0) ? 1 : -1;
107
+ const div = Math.abs((0, gcd_1.gcd)(this.num, this.denum));
108
+ if (Math.abs(this.denum) === div)
109
+ return new integer_1.Integer(this.num / this.denum);
110
+ return new Rational((sign * Math.abs(this.num)) / div, Math.abs(this.denum) / div);
111
+ }
112
+ }
113
+ exports.Rational = Rational;
@@ -1,10 +1,10 @@
1
- import { Node } from '../../../tree/nodes/node';
2
- import { Nombre, NumberType } from '../nombre';
3
- export declare class Real implements Nombre {
4
- value: number;
5
- tex: string;
6
- type: NumberType;
7
- constructor(value: number, tex: string);
8
- toTree(): Node;
9
- }
1
+ import { Node } from '../../../tree/nodes/node';
2
+ import { Nombre, NumberType } from '../nombre';
3
+ export declare class Real implements Nombre {
4
+ value: number;
5
+ tex: string;
6
+ type: NumberType;
7
+ constructor(value: number, tex: string);
8
+ toTree(): Node;
9
+ }
10
10
  //# sourceMappingURL=real.d.ts.map