math-exercises 3.0.125 → 3.0.127

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 (291) hide show
  1. package/lib/exercises/math/calcul/fractions/fractionsSumsPrimeDenominators.d.ts.map +1 -1
  2. package/lib/exercises/math/calcul/fractions/fractionsSumsPrimeDenominators.js +61 -1
  3. package/lib/exercises/math/calcul/mentalCaluls/index.d.ts +1 -0
  4. package/lib/exercises/math/calcul/mentalCaluls/index.d.ts.map +1 -1
  5. package/lib/exercises/math/calcul/mentalCaluls/index.js +1 -0
  6. package/lib/exercises/math/calcul/mentalCaluls/mentalProgramSolve.d.ts +15 -0
  7. package/lib/exercises/math/calcul/mentalCaluls/mentalProgramSolve.d.ts.map +1 -0
  8. package/lib/exercises/math/calcul/mentalCaluls/mentalProgramSolve.js +231 -0
  9. package/lib/exercises/math/calcul/ordering/compareA10N.d.ts +16 -0
  10. package/lib/exercises/math/calcul/ordering/compareA10N.d.ts.map +1 -0
  11. package/lib/exercises/math/calcul/ordering/compareA10N.js +327 -0
  12. package/lib/exercises/math/calcul/ordering/compareABUsingQuotient.d.ts +8 -0
  13. package/lib/exercises/math/calcul/ordering/compareABUsingQuotient.d.ts.map +1 -0
  14. package/lib/exercises/math/calcul/ordering/compareABUsingQuotient.js +123 -0
  15. package/lib/exercises/math/calcul/ordering/compareFracABWithFracAPlusCBPlusC.d.ts +9 -0
  16. package/lib/exercises/math/calcul/ordering/compareFracABWithFracAPlusCBPlusC.d.ts.map +1 -0
  17. package/lib/exercises/math/calcul/ordering/compareFracABWithFracAPlusCBPlusC.js +149 -0
  18. package/lib/exercises/math/calcul/ordering/compareFracAndDec.d.ts +29 -0
  19. package/lib/exercises/math/calcul/ordering/compareFracAndDec.d.ts.map +1 -0
  20. package/lib/exercises/math/calcul/ordering/compareFracAndDec.js +368 -0
  21. package/lib/exercises/math/calcul/ordering/comparePowersOfFracs.d.ts +12 -0
  22. package/lib/exercises/math/calcul/ordering/comparePowersOfFracs.d.ts.map +1 -0
  23. package/lib/exercises/math/calcul/ordering/comparePowersOfFracs.js +164 -0
  24. package/lib/exercises/math/calcul/ordering/compareWithSquareRoots.d.ts +9 -0
  25. package/lib/exercises/math/calcul/ordering/compareWithSquareRoots.d.ts.map +1 -0
  26. package/lib/exercises/math/calcul/ordering/compareWithSquareRoots.js +140 -0
  27. package/lib/exercises/math/calcul/ordering/index.d.ts +6 -0
  28. package/lib/exercises/math/calcul/ordering/index.d.ts.map +1 -1
  29. package/lib/exercises/math/calcul/ordering/index.js +6 -0
  30. package/lib/exercises/math/calcul/rounding/estimateAroundPow10NTimesAroundPow10N.d.ts +9 -0
  31. package/lib/exercises/math/calcul/rounding/estimateAroundPow10NTimesAroundPow10N.d.ts.map +1 -0
  32. package/lib/exercises/math/calcul/rounding/estimateAroundPow10NTimesAroundPow10N.js +84 -0
  33. package/lib/exercises/math/calcul/rounding/estimatePow10NPlusPow10MinusN.d.ts +8 -0
  34. package/lib/exercises/math/calcul/rounding/estimatePow10NPlusPow10MinusN.d.ts.map +1 -0
  35. package/lib/exercises/math/calcul/rounding/estimatePow10NPlusPow10MinusN.js +90 -0
  36. package/lib/exercises/math/calcul/rounding/index.d.ts +2 -0
  37. package/lib/exercises/math/calcul/rounding/index.d.ts.map +1 -1
  38. package/lib/exercises/math/calcul/rounding/index.js +2 -0
  39. package/lib/exercises/math/calculLitteral/equation/equationFromProblem.d.ts +13 -0
  40. package/lib/exercises/math/calculLitteral/equation/equationFromProblem.d.ts.map +1 -0
  41. package/lib/exercises/math/calculLitteral/equation/equationFromProblem.js +454 -0
  42. package/lib/exercises/math/calculLitteral/equation/index.d.ts +1 -0
  43. package/lib/exercises/math/calculLitteral/equation/index.d.ts.map +1 -1
  44. package/lib/exercises/math/calculLitteral/equation/index.js +1 -0
  45. package/lib/exercises/math/calculLitteral/factorisation/factorizeAX2PlusBX.d.ts +10 -0
  46. package/lib/exercises/math/calculLitteral/factorisation/factorizeAX2PlusBX.d.ts.map +1 -0
  47. package/lib/exercises/math/calculLitteral/factorisation/factorizeAX2PlusBX.js +70 -0
  48. package/lib/exercises/math/calculLitteral/factorisation/index.d.ts +1 -0
  49. package/lib/exercises/math/calculLitteral/factorisation/index.d.ts.map +1 -1
  50. package/lib/exercises/math/calculLitteral/factorisation/index.js +1 -0
  51. package/lib/exercises/math/calculLitteral/index.d.ts +2 -0
  52. package/lib/exercises/math/calculLitteral/index.d.ts.map +1 -1
  53. package/lib/exercises/math/calculLitteral/index.js +2 -0
  54. package/lib/exercises/math/calculLitteral/isolate/index.d.ts +2 -1
  55. package/lib/exercises/math/calculLitteral/isolate/index.d.ts.map +1 -1
  56. package/lib/exercises/math/calculLitteral/isolate/index.js +2 -1
  57. package/lib/exercises/math/calculLitteral/isolate/isolateUInInvXPlusInvYEqualsInvU.d.ts +8 -0
  58. package/lib/exercises/math/calculLitteral/isolate/isolateUInInvXPlusInvYEqualsInvU.d.ts.map +1 -0
  59. package/lib/exercises/math/calculLitteral/isolate/isolateUInInvXPlusInvYEqualsInvU.js +86 -0
  60. package/lib/exercises/math/calculLitteral/isolate/isolateXInInvXPlusInvYEqualsInvU.d.ts +7 -0
  61. package/lib/exercises/math/calculLitteral/isolate/isolateXInInvXPlusInvYEqualsInvU.d.ts.map +1 -0
  62. package/lib/exercises/math/calculLitteral/isolate/isolateXInInvXPlusInvYEqualsInvU.js +80 -0
  63. package/lib/exercises/math/calculLitteral/ordering/compareAMinusB.d.ts +10 -0
  64. package/lib/exercises/math/calculLitteral/ordering/compareAMinusB.d.ts.map +1 -0
  65. package/lib/exercises/math/calculLitteral/ordering/compareAMinusB.js +180 -0
  66. package/lib/exercises/math/calculLitteral/ordering/compareFromPiMinusFrac.d.ts +9 -0
  67. package/lib/exercises/math/calculLitteral/ordering/compareFromPiMinusFrac.d.ts.map +1 -0
  68. package/lib/exercises/math/calculLitteral/ordering/compareFromPiMinusFrac.js +144 -0
  69. package/lib/exercises/math/calculLitteral/ordering/index.d.ts +3 -0
  70. package/lib/exercises/math/calculLitteral/ordering/index.d.ts.map +1 -0
  71. package/lib/exercises/math/calculLitteral/ordering/index.js +2 -0
  72. package/lib/exercises/math/calculLitteral/simplifying/compareATimes0.d.ts +11 -0
  73. package/lib/exercises/math/calculLitteral/simplifying/compareATimes0.d.ts.map +1 -0
  74. package/lib/exercises/math/calculLitteral/simplifying/compareATimes0.js +120 -0
  75. package/lib/exercises/math/calculLitteral/simplifying/compareFracXA.d.ts +8 -0
  76. package/lib/exercises/math/calculLitteral/simplifying/compareFracXA.d.ts.map +1 -0
  77. package/lib/exercises/math/calculLitteral/simplifying/compareFracXA.js +67 -0
  78. package/lib/exercises/math/calculLitteral/simplifying/compareMinusA.d.ts +11 -0
  79. package/lib/exercises/math/calculLitteral/simplifying/compareMinusA.d.ts.map +1 -0
  80. package/lib/exercises/math/calculLitteral/simplifying/compareMinusA.js +114 -0
  81. package/lib/exercises/math/calculLitteral/simplifying/index.d.ts +5 -0
  82. package/lib/exercises/math/calculLitteral/simplifying/index.d.ts.map +1 -1
  83. package/lib/exercises/math/calculLitteral/simplifying/index.js +5 -0
  84. package/lib/exercises/math/calculLitteral/simplifying/pickSameAsAPercentOfB.d.ts +13 -0
  85. package/lib/exercises/math/calculLitteral/simplifying/pickSameAsAPercentOfB.d.ts.map +1 -0
  86. package/lib/exercises/math/calculLitteral/simplifying/pickSameAsAPercentOfB.js +125 -0
  87. package/lib/exercises/math/calculLitteral/simplifying/pickSameAsInverseOfFracAB.d.ts +14 -0
  88. package/lib/exercises/math/calculLitteral/simplifying/pickSameAsInverseOfFracAB.d.ts.map +1 -0
  89. package/lib/exercises/math/calculLitteral/simplifying/pickSameAsInverseOfFracAB.js +148 -0
  90. package/lib/exercises/math/calculLitteral/writing/writeLitExpFromFrenchExp.d.ts +5 -27
  91. package/lib/exercises/math/calculLitteral/writing/writeLitExpFromFrenchExp.d.ts.map +1 -1
  92. package/lib/exercises/math/calculLitteral/writing/writeLitExpFromFrenchExp.js +231 -248
  93. package/lib/exercises/math/conversion/index.d.ts +4 -0
  94. package/lib/exercises/math/conversion/index.d.ts.map +1 -1
  95. package/lib/exercises/math/conversion/index.js +4 -0
  96. package/lib/exercises/math/conversion/kmPerMinToKmPerHourConversion.d.ts +11 -0
  97. package/lib/exercises/math/conversion/kmPerMinToKmPerHourConversion.d.ts.map +1 -0
  98. package/lib/exercises/math/conversion/kmPerMinToKmPerHourConversion.js +116 -0
  99. package/lib/exercises/math/conversion/minutesToHours.d.ts +10 -0
  100. package/lib/exercises/math/conversion/minutesToHours.d.ts.map +1 -0
  101. package/lib/exercises/math/conversion/minutesToHours.js +150 -0
  102. package/lib/exercises/math/conversion/prefixToNumber.d.ts +15 -0
  103. package/lib/exercises/math/conversion/prefixToNumber.d.ts.map +1 -0
  104. package/lib/exercises/math/conversion/prefixToNumber.js +243 -0
  105. package/lib/exercises/math/conversion/secondsToHours.d.ts +10 -0
  106. package/lib/exercises/math/conversion/secondsToHours.d.ts.map +1 -0
  107. package/lib/exercises/math/conversion/secondsToHours.js +150 -0
  108. package/lib/exercises/math/dataRepresentations/barChartInterpreting.d.ts +53 -0
  109. package/lib/exercises/math/dataRepresentations/barChartInterpreting.d.ts.map +1 -0
  110. package/lib/exercises/math/dataRepresentations/barChartInterpreting.js +533 -0
  111. package/lib/exercises/math/dataRepresentations/boxPlotInterpreting.d.ts +7 -0
  112. package/lib/exercises/math/dataRepresentations/boxPlotInterpreting.d.ts.map +1 -0
  113. package/lib/exercises/math/dataRepresentations/boxPlotInterpreting.js +223 -0
  114. package/lib/exercises/math/dataRepresentations/cartesianGraphExtremaReading.d.ts +10 -0
  115. package/lib/exercises/math/dataRepresentations/cartesianGraphExtremaReading.d.ts.map +1 -0
  116. package/lib/exercises/math/dataRepresentations/cartesianGraphExtremaReading.js +140 -0
  117. package/lib/exercises/math/dataRepresentations/dataToGraphGraphToData.d.ts +8 -0
  118. package/lib/exercises/math/dataRepresentations/dataToGraphGraphToData.d.ts.map +1 -0
  119. package/lib/exercises/math/dataRepresentations/dataToGraphGraphToData.js +133 -0
  120. package/lib/exercises/math/dataRepresentations/graphReading.d.ts +8 -0
  121. package/lib/exercises/math/dataRepresentations/graphReading.d.ts.map +1 -0
  122. package/lib/exercises/math/dataRepresentations/graphReading.js +136 -0
  123. package/lib/exercises/math/dataRepresentations/halfPieChartCommenting.d.ts +18 -0
  124. package/lib/exercises/math/dataRepresentations/halfPieChartCommenting.d.ts.map +1 -0
  125. package/lib/exercises/math/dataRepresentations/halfPieChartCommenting.js +228 -0
  126. package/lib/exercises/math/dataRepresentations/halfPieChartReading.d.ts +8 -0
  127. package/lib/exercises/math/dataRepresentations/halfPieChartReading.d.ts.map +1 -0
  128. package/lib/exercises/math/dataRepresentations/halfPieChartReading.js +213 -0
  129. package/lib/exercises/math/dataRepresentations/histogramReading.d.ts +9 -0
  130. package/lib/exercises/math/dataRepresentations/histogramReading.d.ts.map +1 -0
  131. package/lib/exercises/math/dataRepresentations/histogramReading.js +163 -0
  132. package/lib/exercises/math/dataRepresentations/index.d.ts +10 -0
  133. package/lib/exercises/math/dataRepresentations/index.d.ts.map +1 -1
  134. package/lib/exercises/math/dataRepresentations/index.js +10 -0
  135. package/lib/exercises/math/dataRepresentations/plausibleGraph.d.ts +9 -0
  136. package/lib/exercises/math/dataRepresentations/plausibleGraph.d.ts.map +1 -0
  137. package/lib/exercises/math/dataRepresentations/plausibleGraph.js +194 -0
  138. package/lib/exercises/math/dataRepresentations/scatterPlotCommenting.d.ts +9 -0
  139. package/lib/exercises/math/dataRepresentations/scatterPlotCommenting.d.ts.map +1 -0
  140. package/lib/exercises/math/dataRepresentations/scatterPlotCommenting.js +308 -0
  141. package/lib/exercises/math/derivation/derivative/exp/expDerivativeFour.d.ts.map +1 -1
  142. package/lib/exercises/math/derivation/derivative/exp/expDerivativeFour.js +5 -6
  143. package/lib/exercises/math/functions/affines/coordsOfPointOnAffineFindX.d.ts +8 -0
  144. package/lib/exercises/math/functions/affines/coordsOfPointOnAffineFindX.d.ts.map +1 -0
  145. package/lib/exercises/math/functions/affines/coordsOfPointOnAffineFindX.js +117 -0
  146. package/lib/exercises/math/functions/affines/coordsOfPointOnAffineFindY.d.ts +8 -0
  147. package/lib/exercises/math/functions/affines/coordsOfPointOnAffineFindY.d.ts.map +1 -0
  148. package/lib/exercises/math/functions/affines/coordsOfPointOnAffineFindY.js +118 -0
  149. package/lib/exercises/math/functions/affines/drawAffineFromPointAndLeadingCoeff.d.ts +16 -0
  150. package/lib/exercises/math/functions/affines/drawAffineFromPointAndLeadingCoeff.d.ts.map +1 -0
  151. package/lib/exercises/math/functions/affines/drawAffineFromPointAndLeadingCoeff.js +215 -0
  152. package/lib/exercises/math/functions/affines/drawAffineFromProgCalc.d.ts +13 -0
  153. package/lib/exercises/math/functions/affines/drawAffineFromProgCalc.d.ts.map +1 -0
  154. package/lib/exercises/math/functions/affines/drawAffineFromProgCalc.js +223 -0
  155. package/lib/exercises/math/functions/affines/index.d.ts +7 -0
  156. package/lib/exercises/math/functions/affines/index.d.ts.map +1 -1
  157. package/lib/exercises/math/functions/affines/index.js +7 -0
  158. package/lib/exercises/math/functions/affines/recognizeExprAffine.d.ts +20 -0
  159. package/lib/exercises/math/functions/affines/recognizeExprAffine.d.ts.map +1 -0
  160. package/lib/exercises/math/functions/affines/recognizeExprAffine.js +284 -0
  161. package/lib/exercises/math/functions/affines/representationOfAffine.d.ts +16 -0
  162. package/lib/exercises/math/functions/affines/representationOfAffine.d.ts.map +1 -0
  163. package/lib/exercises/math/functions/affines/representationOfAffine.js +275 -0
  164. package/lib/exercises/math/functions/basics/coordsOfPointOnCurveFindY.d.ts +14 -0
  165. package/lib/exercises/math/functions/basics/coordsOfPointOnCurveFindY.d.ts.map +1 -0
  166. package/lib/exercises/math/functions/basics/coordsOfPointOnCurveFindY.js +235 -0
  167. package/lib/exercises/math/functions/basics/index.d.ts +1 -0
  168. package/lib/exercises/math/functions/basics/index.d.ts.map +1 -1
  169. package/lib/exercises/math/functions/basics/index.js +1 -0
  170. package/lib/exercises/math/functions/composition/functionComposition.d.ts +8 -0
  171. package/lib/exercises/math/functions/composition/functionComposition.d.ts.map +1 -0
  172. package/lib/exercises/math/functions/composition/functionComposition.js +238 -0
  173. package/lib/exercises/math/functions/composition/index.d.ts +2 -0
  174. package/lib/exercises/math/functions/composition/index.d.ts.map +1 -0
  175. package/lib/exercises/math/functions/composition/index.js +1 -0
  176. package/lib/exercises/math/functions/index.d.ts +1 -0
  177. package/lib/exercises/math/functions/index.d.ts.map +1 -1
  178. package/lib/exercises/math/functions/index.js +1 -0
  179. package/lib/exercises/math/geometry/angles/anglesUsingIsParallel.d.ts +23 -0
  180. package/lib/exercises/math/geometry/angles/anglesUsingIsParallel.d.ts.map +1 -0
  181. package/lib/exercises/math/geometry/angles/anglesUsingIsParallel.js +448 -0
  182. package/lib/exercises/math/geometry/angles/index.js +2 -0
  183. package/lib/exercises/math/geometry/angles/isParallelUsingAngles.d.ts +23 -0
  184. package/lib/exercises/math/geometry/angles/isParallelUsingAngles.d.ts.map +1 -0
  185. package/lib/exercises/math/geometry/angles/isParallelUsingAngles.js +402 -0
  186. package/lib/exercises/math/geometry/cartesian/placeAbscissOnSemiLine.d.ts +9 -6
  187. package/lib/exercises/math/geometry/cartesian/placeAbscissOnSemiLine.d.ts.map +1 -1
  188. package/lib/exercises/math/geometry/cartesian/placeAbscissOnSemiLine.js +140 -60
  189. package/lib/exercises/math/geometry/convexity/convexityQuadrinomialsGeo.js +1 -1
  190. package/lib/exercises/math/geometry/vectors/colinearity/colinearityFromPicture.d.ts.map +1 -1
  191. package/lib/exercises/math/geometry/vectors/colinearity/colinearityFromPicture.js +121 -104
  192. package/lib/exercises/math/geometry/vectors/vectorRepresentative.d.ts.map +1 -1
  193. package/lib/exercises/math/geometry/vectors/vectorRepresentative.js +3 -2
  194. package/lib/exercises/math/probaStat/basicProbas/index.d.ts +1 -0
  195. package/lib/exercises/math/probaStat/basicProbas/index.d.ts.map +1 -1
  196. package/lib/exercises/math/probaStat/basicProbas/index.js +1 -0
  197. package/lib/exercises/math/probaStat/basicProbas/possibleValuesForProba.d.ts +0 -1
  198. package/lib/exercises/math/probaStat/basicProbas/possibleValuesForProba.d.ts.map +1 -1
  199. package/lib/exercises/math/probaStat/basicProbas/possibleValuesForProba.js +65 -88
  200. package/lib/exercises/math/probaStat/conditionalProbaWriteFromFrench.d.ts +9 -0
  201. package/lib/exercises/math/probaStat/conditionalProbaWriteFromFrench.d.ts.map +1 -0
  202. package/lib/exercises/math/probaStat/conditionalProbaWriteFromFrench.js +221 -0
  203. package/lib/exercises/math/probaStat/index.d.ts +2 -0
  204. package/lib/exercises/math/probaStat/index.d.ts.map +1 -1
  205. package/lib/exercises/math/probaStat/index.js +2 -0
  206. package/lib/exercises/math/probaStat/probaAsSumOfProbas.d.ts +29 -0
  207. package/lib/exercises/math/probaStat/probaAsSumOfProbas.d.ts.map +1 -0
  208. package/lib/exercises/math/probaStat/probaAsSumOfProbas.js +547 -0
  209. package/lib/exercises/math/probaStat/stats1var/index.d.ts +2 -0
  210. package/lib/exercises/math/probaStat/stats1var/index.d.ts.map +1 -1
  211. package/lib/exercises/math/probaStat/stats1var/index.js +2 -0
  212. package/lib/exercises/math/probaStat/stats1var/interpretIndicatorsForLists.d.ts +9 -0
  213. package/lib/exercises/math/probaStat/stats1var/interpretIndicatorsForLists.d.ts.map +1 -0
  214. package/lib/exercises/math/probaStat/stats1var/interpretIndicatorsForLists.js +89 -0
  215. package/lib/exercises/math/probaStat/stats1var/plausibilityOfAverage.d.ts +10 -0
  216. package/lib/exercises/math/probaStat/stats1var/plausibilityOfAverage.d.ts.map +1 -0
  217. package/lib/exercises/math/probaStat/stats1var/plausibilityOfAverage.js +152 -0
  218. package/lib/exercises/pc/electricity/calculateUEqualsRI.d.ts +7 -0
  219. package/lib/exercises/pc/electricity/calculateUEqualsRI.d.ts.map +1 -0
  220. package/lib/exercises/pc/electricity/calculateUEqualsRI.js +73 -0
  221. package/lib/exercises/pc/electricity/index.d.ts +1 -0
  222. package/lib/exercises/pc/electricity/index.d.ts.map +1 -1
  223. package/lib/exercises/pc/electricity/index.js +1 -0
  224. package/lib/exercises/pc/index.d.ts +1 -0
  225. package/lib/exercises/pc/index.d.ts.map +1 -1
  226. package/lib/exercises/pc/index.js +1 -0
  227. package/lib/exercises/pc/moleculeFormula.d.ts.map +1 -1
  228. package/lib/exercises/pc/moleculeFormula.js +4 -3
  229. package/lib/exercises/pc/optics/index.d.ts +2 -0
  230. package/lib/exercises/pc/optics/index.d.ts.map +1 -0
  231. package/lib/exercises/pc/optics/index.js +1 -0
  232. package/lib/exercises/pc/optics/lensFormula.d.ts +21 -0
  233. package/lib/exercises/pc/optics/lensFormula.d.ts.map +1 -0
  234. package/lib/exercises/pc/optics/lensFormula.js +415 -0
  235. package/lib/exercises/pc/weight/calculateWeight.d.ts +8 -1
  236. package/lib/exercises/pc/weight/calculateWeight.d.ts.map +1 -1
  237. package/lib/exercises/pc/weight/calculateWeight.js +113 -38
  238. package/lib/geogebra/parsers/geogebraParser.d.ts +4 -0
  239. package/lib/geogebra/parsers/geogebraParser.d.ts.map +1 -1
  240. package/lib/geogebra/parsers/geogebraParser.js +17 -0
  241. package/lib/index.d.ts +351 -12
  242. package/lib/index.d.ts.map +1 -1
  243. package/lib/latexTester.d.ts.map +1 -1
  244. package/lib/latexTester.js +1 -0
  245. package/lib/math/geometry/CloudPoints.d.ts +10 -0
  246. package/lib/math/geometry/CloudPoints.d.ts.map +1 -1
  247. package/lib/math/geometry/CloudPoints.js +119 -0
  248. package/lib/math/geometry/line.d.ts +1 -0
  249. package/lib/math/geometry/line.d.ts.map +1 -1
  250. package/lib/math/geometry/line.js +10 -2
  251. package/lib/math/geometry/vector.d.ts +1 -0
  252. package/lib/math/geometry/vector.d.ts.map +1 -1
  253. package/lib/math/geometry/vector.js +12 -0
  254. package/lib/math/progCalc/progCalc.d.ts +46 -0
  255. package/lib/math/progCalc/progCalc.d.ts.map +1 -0
  256. package/lib/math/progCalc/progCalc.js +239 -0
  257. package/lib/math/utils/latex/realize.d.ts +12 -0
  258. package/lib/math/utils/latex/realize.d.ts.map +1 -0
  259. package/lib/math/utils/latex/realize.js +43 -0
  260. package/lib/pc/constants/molecularChemistry/molecule.d.ts +2 -0
  261. package/lib/pc/constants/molecularChemistry/molecule.d.ts.map +1 -1
  262. package/lib/pc/constants/molecularChemistry/molecule.js +52 -0
  263. package/lib/tests/questionTest.d.ts.map +1 -1
  264. package/lib/tests/questionTest.js +1 -1
  265. package/lib/tests/singleExo.test.js +3 -3
  266. package/lib/tree/nodes/algebraicNode.d.ts.map +1 -1
  267. package/lib/tree/nodes/operators/addNode.d.ts +4 -2
  268. package/lib/tree/nodes/operators/addNode.d.ts.map +1 -1
  269. package/lib/tree/nodes/operators/addNode.js +8 -17
  270. package/lib/tree/nodes/operators/fractionNode.d.ts +1 -1
  271. package/lib/tree/nodes/operators/fractionNode.d.ts.map +1 -1
  272. package/lib/tree/nodes/operators/fractionNode.js +5 -1
  273. package/lib/tree/nodes/operators/multiplyNode.d.ts +4 -2
  274. package/lib/tree/nodes/operators/multiplyNode.d.ts.map +1 -1
  275. package/lib/tree/nodes/operators/multiplyNode.js +8 -17
  276. package/lib/tree/nodes/operators/operatorNode.d.ts +3 -3
  277. package/lib/tree/nodes/operators/operatorNode.d.ts.map +1 -1
  278. package/lib/tree/nodes/variables/variableNode.d.ts +1 -1
  279. package/lib/tree/nodes/variables/variableNode.d.ts.map +1 -1
  280. package/lib/tree/utilities/nodeShuffler.d.ts +12 -0
  281. package/lib/tree/utilities/nodeShuffler.d.ts.map +1 -0
  282. package/lib/tree/utilities/nodeShuffler.js +123 -0
  283. package/lib/utils/arrays/getAllPicks.d.ts +2 -0
  284. package/lib/utils/arrays/getAllPicks.d.ts.map +1 -0
  285. package/lib/utils/arrays/getAllPicks.js +17 -0
  286. package/lib/utils/errors/handleVEAError.d.ts +1 -1
  287. package/lib/utils/errors/handleVEAError.d.ts.map +1 -1
  288. package/lib/utils/strings/decapitalize.d.ts +2 -0
  289. package/lib/utils/strings/decapitalize.d.ts.map +1 -0
  290. package/lib/utils/strings/decapitalize.js +3 -0
  291. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"fractionsSumsPrimeDenominators.d.ts","sourceRoot":"","sources":["../../../../../src/exercises/math/calcul/fractions/fractionsSumsPrimeDenominators.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAgBT,MAAM,6BAA6B,CAAC;AAYrC,KAAK,WAAW,GAAG;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAuHF,eAAO,MAAM,8BAA8B,EAAE,QAAQ,CAAC,WAAW,CAiBhE,CAAC"}
1
+ {"version":3,"file":"fractionsSumsPrimeDenominators.d.ts","sourceRoot":"","sources":["../../../../../src/exercises/math/calcul/fractions/fractionsSumsPrimeDenominators.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAkBT,MAAM,6BAA6B,CAAC;AAcrC,KAAK,WAAW,GAAG;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAyLF,eAAO,MAAM,8BAA8B,EAAE,QAAQ,CAAC,WAAW,CAkBhE,CAAC"}
@@ -3,7 +3,9 @@ import { getDistinctQuestions } from "../../../../exercises/utils/getDistinctQue
3
3
  import { Rational, RationalConstructor, } from "../../../../math/numbers/rationals/rational.js";
4
4
  import { gcd } from "../../../../math/utils/arithmetic/gcd.js";
5
5
  import { randint } from "../../../../math/utils/random/randint.js";
6
- import { AddNode } from "../../../../tree/nodes/operators/addNode.js";
6
+ import { add, AddNode } from "../../../../tree/nodes/operators/addNode.js";
7
+ import { frac } from "../../../../tree/nodes/operators/fractionNode.js";
8
+ import { multiply } from "../../../../tree/nodes/operators/multiplyNode.js";
7
9
  import { rationalParser } from "../../../../tree/parsers/rationalParser.js";
8
10
  import { handleVEAError } from "../../../../utils/errors/handleVEAError.js";
9
11
  const getInstruction = (identifiers, opts) => {
@@ -26,6 +28,61 @@ const getAnswer = (identifiers) => {
26
28
  const answer = ratio1.add(ratio2).toTree().toTex();
27
29
  return answer;
28
30
  };
31
+ const getHint = () => {
32
+ return `Il faut tout d'abord mettre les fractions au même dénominateur. Ensuite, additionne les numérateurs, puis simplifie le résultat obtenu.`;
33
+ };
34
+ const getCorrection = (identifiers) => {
35
+ const { denom1, denom2, num1, num2 } = identifiers;
36
+ const firstFrac = frac(num1, denom1);
37
+ const secondFrac = frac(num2, denom2);
38
+ let technique = "";
39
+ let firstFracFinal = firstFrac;
40
+ let secondFracFinal = secondFrac;
41
+ const firstProduct = frac(multiply(num1, denom2), multiply(num2, denom2));
42
+ firstFracFinal = firstProduct.simplify({
43
+ forbidRationalSimplification: true,
44
+ });
45
+ const secondProduct = frac(multiply(num2, denom1), multiply(denom2, denom1));
46
+ secondFracFinal = secondProduct.simplify({
47
+ forbidRationalSimplification: true,
48
+ });
49
+ technique = `on multiple le numérateur et le dénominateur de la première fraction par $${denom2}$, et le numérateur et dénominateur de la deuxième fraction par $${denom1}$ :
50
+
51
+ $$
52
+ ${firstFrac.toTex()} = ${firstProduct.toTex({
53
+ forceNoSimplification: true,
54
+ })} = ${firstFracFinal.toTex()}
55
+ $$
56
+
57
+ $$
58
+ ${secondFrac.toTex()} = ${secondProduct.toTex({
59
+ forceNoSimplification: true,
60
+ })} = ${secondFracFinal.toTex()}
61
+ $$
62
+ `;
63
+ const sumFinal = add(firstFracFinal, secondFracFinal);
64
+ const subSumFinal = frac(add(firstFracFinal.leftChild, secondFracFinal.leftChild), firstFracFinal.rightChild);
65
+ const finalNonSimp = subSumFinal.simplify({
66
+ forbidRationalSimplification: true,
67
+ });
68
+ const final = subSumFinal.simplify();
69
+ const isSimplifiable = finalNonSimp.toTex() !== final.toTex();
70
+ return `On commence par mettre les fractions au même dénominateur. Pour cela, ${technique}
71
+
72
+ On peut alors additionner les deux fractions :
73
+
74
+ $$
75
+ ${sumFinal.toTex()} = ${subSumFinal.toTex()} = ${finalNonSimp.toTex()}
76
+ $$
77
+
78
+ ${isSimplifiable
79
+ ? `On peut alors simplifier cette fraction :
80
+
81
+ $$
82
+ ${finalNonSimp.toTex()} = ${final.toTex()}
83
+ $$`
84
+ : "Cette fraction est déjà simplifiée."}`;
85
+ };
29
86
  const getQuestionFromIdentifiers = (identifiers) => {
30
87
  const question = {
31
88
  answer: getAnswer(identifiers),
@@ -33,6 +90,8 @@ const getQuestionFromIdentifiers = (identifiers) => {
33
90
  keys: [],
34
91
  answerFormat: "tex",
35
92
  identifiers,
93
+ hint: getHint(identifiers),
94
+ correction: getCorrection(identifiers),
36
95
  };
37
96
  return question;
38
97
  };
@@ -103,4 +162,5 @@ export const fractionsSumsPrimeDenominators = {
103
162
  subject: "Mathématiques",
104
163
  options,
105
164
  getQuestionFromIdentifiers,
165
+ hasHintAndCorrection: true,
106
166
  };
@@ -4,4 +4,5 @@ export * from "./mentalMultiplications.js";
4
4
  export * from "./mentalPercentage.js";
5
5
  export * from "./mentalAddAndSubNoRelative.js";
6
6
  export * from "./mentalMultiplicationsNoRelative.js";
7
+ export * from "./mentalProgramSolve.js";
7
8
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/exercises/math/calcul/mentalCaluls/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,sBAAsB,CAAC;AACrC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,uBAAuB,CAAC;AACtC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,sCAAsC,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/exercises/math/calcul/mentalCaluls/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,sBAAsB,CAAC;AACrC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,uBAAuB,CAAC;AACtC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,sCAAsC,CAAC;AACrD,cAAc,yBAAyB,CAAC"}
@@ -4,3 +4,4 @@ export * from "./mentalMultiplications.js";
4
4
  export * from "./mentalPercentage.js";
5
5
  export * from "./mentalAddAndSubNoRelative.js";
6
6
  export * from "./mentalMultiplicationsNoRelative.js";
7
+ export * from "./mentalProgramSolve.js";
@@ -0,0 +1,15 @@
1
+ import { Exercise } from "../../../../exercises/exercise.js";
2
+ import { NodeIdentifiers } from "../../../../tree/nodes/nodeConstructor.js";
3
+ import { ProgCalcIdentifiers } from "../../../../math/progCalc/progCalc.js";
4
+ type Identifiers = {
5
+ nodeIdsStartingNumber: NodeIdentifiers;
6
+ progCalcIds: ProgCalcIdentifiers;
7
+ };
8
+ type Options = {
9
+ numberType: "Entier" | "Décimal";
10
+ nbSteps: number;
11
+ nbDigits: number;
12
+ };
13
+ export declare const mentalProgramSolve: Exercise<Identifiers, Options>;
14
+ export {};
15
+ //# sourceMappingURL=mentalProgramSolve.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mentalProgramSolve.d.ts","sourceRoot":"","sources":["../../../../../src/exercises/math/calcul/mentalCaluls/mentalProgramSolve.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAiBT,MAAM,6BAA6B,CAAC;AAIrC,OAAO,EAEL,eAAe,EAChB,MAAM,qCAAqC,CAAC;AAG7C,OAAO,EAGL,mBAAmB,EACpB,MAAM,iCAAiC,CAAC;AAgCzC,KAAK,WAAW,GAAG;IACjB,qBAAqB,EAAE,eAAe,CAAC;IACvC,WAAW,EAAE,mBAAmB,CAAC;CAClC,CAAC;AA8MF,KAAK,OAAO,GAAG;IACb,UAAU,EAAE,QAAQ,GAAG,SAAS,CAAC;IACjC,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AAiCF,eAAO,MAAM,kBAAkB,EAAE,QAAQ,CAAC,WAAW,EAAE,OAAO,CA0B7D,CAAC"}
@@ -0,0 +1,231 @@
1
+ import { addValidProp, shuffleProps, GeneratorOptionTarget, GeneratorOptionType, tryToAddWrongProp, } from "../../../../exercises/exercise.js";
2
+ import { getDistinctQuestions } from "../../../../exercises/utils/getDistinctQuestions.js";
3
+ import { randint } from "../../../../math/utils/random/randint.js";
4
+ import { NodeConstructor, } from "../../../../tree/nodes/nodeConstructor.js";
5
+ import { handleVEAError } from "../../../../utils/errors/handleVEAError.js";
6
+ import { parseAlgebraic } from "../../../../tree/parsers/latexParser.js";
7
+ import { ProgCalc, ProgCalcConstructor, } from "../../../../math/progCalc/progCalc.js";
8
+ import { isAddNode } from "../../../../tree/nodes/operators/addNode.js";
9
+ import { abs } from "../../../../tree/nodes/functions/absNode.js";
10
+ import { shuffle } from "../../../../utils/alea/shuffle.js";
11
+ import { isOppositeNode } from "../../../../tree/nodes/functions/oppositeNode.js";
12
+ import { alignTex } from "../../../../utils/latex/alignTex.js";
13
+ const getStrSolvingStep = (nodeStep) => {
14
+ //write 10 + (-8) instead of 10 - 8
15
+ function isNegative(node) {
16
+ return !abs(node).simplify().equals(node.simplify());
17
+ }
18
+ if (isAddNode(nodeStep) && isNegative(nodeStep.rightChild)) {
19
+ return `${nodeStep.leftChild.toTex()} + (${nodeStep.rightChild.toTex()}) = ${nodeStep
20
+ .simplify()
21
+ .toTex()}`;
22
+ }
23
+ else if (isOppositeNode(nodeStep)) {
24
+ return `-(${nodeStep.child.toTex()}) = ${nodeStep.simplify().toTex()}`;
25
+ }
26
+ else {
27
+ const texL = nodeStep.toTex({
28
+ allowDoubleMinus: true,
29
+ forceTimesSign: true,
30
+ forceParenthesis: true,
31
+ forceNoSimplification: true,
32
+ allowMinusAnywhereInFraction: true,
33
+ });
34
+ const texR = nodeStep.simplify().toTex();
35
+ return `${texL} = ${texR}`;
36
+ }
37
+ };
38
+ const getPropositions = (n, { answer, progCalcIds, nodeIdsStartingNumber }) => {
39
+ const propositions = [];
40
+ addValidProp(propositions, answer);
41
+ const nodeStartingNumber = NodeConstructor.fromIdentifiers(nodeIdsStartingNumber);
42
+ const progCalc = ProgCalcConstructor.fromIdentifiers(progCalcIds);
43
+ const nodeFinalNumber = progCalc.apply(nodeStartingNumber).simplify();
44
+ //applies progCalc to finalNumber
45
+ tryToAddWrongProp(propositions, progCalc.apply(nodeFinalNumber).simplify().toTex());
46
+ //applies progCalc operations in reverse to finalNumber
47
+ const progCalcReversed = new ProgCalc(progCalc.operations.toReversed());
48
+ tryToAddWrongProp(propositions, progCalcReversed.apply(nodeFinalNumber).simplify().toTex());
49
+ //stops at intermediary step (stops before goal)
50
+ const progCalcInverse = progCalc.getInverseProgCalc();
51
+ const inverseOperations = progCalcInverse.operations;
52
+ const arrStepNodes = [nodeFinalNumber];
53
+ for (let i = 0; i < inverseOperations.length - 1; i++) {
54
+ const nodePrevious = arrStepNodes[arrStepNodes.length - 1].simplify();
55
+ const operation = inverseOperations[i];
56
+ const nodeStep = operation.func(nodePrevious);
57
+ arrStepNodes.push(nodeStep);
58
+ }
59
+ shuffle(arrStepNodes).forEach((nodeStep) => {
60
+ if (propositions.length < n) {
61
+ tryToAddWrongProp(propositions, nodeStep.simplify().toTex());
62
+ }
63
+ });
64
+ return shuffleProps(propositions, n);
65
+ };
66
+ const getAnswerNode = (identifiers) => {
67
+ const { nodeIdsStartingNumber } = identifiers;
68
+ return NodeConstructor.fromIdentifiers(nodeIdsStartingNumber);
69
+ };
70
+ const getAnswer = (identifiers) => {
71
+ return getAnswerNode(identifiers).toTex();
72
+ };
73
+ const getInstruction = (identifiers, opts) => {
74
+ const { nodeIdsStartingNumber, progCalcIds } = identifiers;
75
+ const nodeStartingNumber = NodeConstructor.fromIdentifiers(nodeIdsStartingNumber);
76
+ const progCalc = ProgCalcConstructor.fromIdentifiers(progCalcIds);
77
+ const nodeFinalNumber = progCalc.apply(nodeStartingNumber).simplify();
78
+ const strFinalNumber = opts?.numberType == "Entier"
79
+ ? nodeFinalNumber.evaluate().frenchify()
80
+ : nodeFinalNumber
81
+ .evaluate()
82
+ .toFixed(opts?.nbDigits ?? 0)
83
+ .replace(".", ",");
84
+ return `Voici un programme de calcul :
85
+
86
+ > Choisir un nombre
87
+
88
+ ${progCalc.getArrOfFrenchStrings().map((str) => `> ${str}`).join(`
89
+
90
+ `)}
91
+
92
+ Quel nombre faut-il choisir au départ pour obtenir $ ${strFinalNumber} $ à la fin ?`;
93
+ };
94
+ const getHint = () => {
95
+ return `Pars du résultat obtenu à la fin et remonte à l'envers en inversant chaque étape.`;
96
+ };
97
+ const getCorrection = (identifiers) => {
98
+ const { nodeIdsStartingNumber, progCalcIds } = identifiers;
99
+ const nodeStartingNumber = NodeConstructor.fromIdentifiers(nodeIdsStartingNumber);
100
+ const progCalc = ProgCalcConstructor.fromIdentifiers(progCalcIds);
101
+ const nodeFinalNumber = progCalc.apply(nodeStartingNumber).simplify();
102
+ const arrOpInverse = progCalc.getInverseProgCalc().operations;
103
+ const arrStrSolvingSteps = [];
104
+ let nodePrevious = nodeFinalNumber;
105
+ for (let i = 0; i < arrOpInverse.length; i++) {
106
+ const operation = arrOpInverse[i];
107
+ if (nodePrevious.opts) {
108
+ nodePrevious.opts.forceParenthesis = true;
109
+ }
110
+ else {
111
+ nodePrevious.opts = {
112
+ forceParenthesis: true,
113
+ };
114
+ }
115
+ const nodeStep = operation.func(nodePrevious);
116
+ const strSolvingStep = getStrSolvingStep(nodeStep);
117
+ nodePrevious = nodeStep.simplify();
118
+ arrStrSolvingSteps.push(strSolvingStep);
119
+ }
120
+ return `
121
+ On part de la fin et on remonte à l'envers en inversant chaque étape.
122
+
123
+ ${alignTex(arrStrSolvingSteps.map((str) => {
124
+ const [lhs, rhs] = str.split("=");
125
+ return [lhs, "=", rhs];
126
+ }))}
127
+
128
+ Le nombre choisi au départ était donc $ ${nodeStartingNumber.toTex()} $.`;
129
+ };
130
+ const getKeys = () => {
131
+ return [];
132
+ };
133
+ const isAnswerValid = (ans, { answer }) => {
134
+ try {
135
+ const parsed = parseAlgebraic(ans);
136
+ return parsed.simplify().toTex() === answer;
137
+ }
138
+ catch (err) {
139
+ return handleVEAError(err);
140
+ }
141
+ };
142
+ const getMentalProgramSolveQuestion = (optsIn) => {
143
+ const opts = optsIn ? Object.assign(optsDefault, optsIn) : optsDefault;
144
+ let nbDigits = 0;
145
+ switch (opts.numberType) {
146
+ case "Décimal":
147
+ nbDigits = opts.nbDigits ?? 2;
148
+ break;
149
+ default:
150
+ case "Entier":
151
+ nbDigits = 0;
152
+ break;
153
+ }
154
+ const powerOf10 = Math.pow(10, nbDigits);
155
+ const valueStart = randint(0, 33 * powerOf10, []) / powerOf10;
156
+ const nodeStartingNumber = valueStart.toTree();
157
+ const isSingleUseOperators = false;
158
+ const progCalc = ProgCalcConstructor.randomMental(opts.nbSteps, nodeStartingNumber, nbDigits, isSingleUseOperators);
159
+ const identifiers = {
160
+ nodeIdsStartingNumber: valueStart.toTree().toIdentifiers(),
161
+ progCalcIds: progCalc.toIdentifiers(),
162
+ };
163
+ return getQuestionFromIdentifiers(identifiers, opts);
164
+ };
165
+ const getQuestionFromIdentifiers = (identifiers, opts) => {
166
+ return {
167
+ answer: getAnswer(identifiers, opts),
168
+ instruction: getInstruction(identifiers, opts),
169
+ keys: getKeys(identifiers, opts),
170
+ answerFormat: "tex",
171
+ identifiers,
172
+ hint: getHint(identifiers, opts),
173
+ correction: getCorrection(identifiers, opts),
174
+ };
175
+ };
176
+ const optsDefault = {
177
+ numberType: "Entier",
178
+ nbSteps: 4,
179
+ nbDigits: 0,
180
+ };
181
+ const options = [
182
+ {
183
+ id: "numberType",
184
+ label: "Type de nombres utilisés",
185
+ defaultValue: optsDefault.numberType,
186
+ values: ["Entier", "Décimal"],
187
+ target: GeneratorOptionTarget.generation,
188
+ type: GeneratorOptionType.select,
189
+ },
190
+ {
191
+ id: "nbSteps",
192
+ label: "Nombre d'étapes de transformation",
193
+ defaultValue: optsDefault.nbSteps,
194
+ values: [2, 3, 4, 5, 6],
195
+ target: GeneratorOptionTarget.generation,
196
+ type: GeneratorOptionType.select,
197
+ },
198
+ {
199
+ id: "nbDigits",
200
+ label: "Nombre de décimales",
201
+ defaultValue: optsDefault.nbDigits,
202
+ values: [0, 1, 2],
203
+ target: GeneratorOptionTarget.generation,
204
+ type: GeneratorOptionType.select,
205
+ },
206
+ ];
207
+ export const mentalProgramSolve = {
208
+ id: "mentalProgramSolve",
209
+ label: "Résoudre un problème basé sur un programme de calcul avec des entiers ou des décimaux",
210
+ isSingleStep: true,
211
+ generator: (nb, opts) => getDistinctQuestions(() => getMentalProgramSolveQuestion(opts), nb),
212
+ options,
213
+ validateOptions: (opts) => {
214
+ return {
215
+ valid: !!opts?.numberType,
216
+ message: "Veuillez choisir un type de nombres.",
217
+ };
218
+ },
219
+ qcmTimer: 60,
220
+ freeTimer: 60,
221
+ getPropositions,
222
+ isAnswerValid,
223
+ subject: "Mathématiques",
224
+ getInstruction,
225
+ getHint,
226
+ getCorrection,
227
+ getAnswer,
228
+ getQuestionFromIdentifiers,
229
+ hasHintAndCorrection: true,
230
+ answerType: "QCU",
231
+ };
@@ -0,0 +1,16 @@
1
+ import { Exercise } from "../../../../exercises/exercise.js";
2
+ type A10N = {
3
+ a: number;
4
+ n: number;
5
+ };
6
+ type Identifiers = {
7
+ signType: string;
8
+ items: A10N[];
9
+ };
10
+ type Options = {
11
+ signTypes: string[];
12
+ nbCollisions: number[];
13
+ };
14
+ export declare const compareA10N: Exercise<Identifiers, Options>;
15
+ export {};
16
+ //# sourceMappingURL=compareA10N.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compareA10N.d.ts","sourceRoot":"","sources":["../../../../../src/exercises/math/calcul/ordering/compareA10N.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAkBT,MAAM,6BAA6B,CAAC;AAmBrC,KAAK,IAAI,GAAG;IACV,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;CACX,CAAC;AAEF,KAAK,WAAW,GAAG;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,IAAI,EAAE,CAAC;CACf,CAAC;AAwTF,KAAK,OAAO,GAAG;IACb,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,YAAY,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AA0CF,eAAO,MAAM,WAAW,EAAE,QAAQ,CAAC,WAAW,EAAE,OAAO,CAgBtD,CAAC"}