math-exercises 3.0.157 → 3.0.159

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 (444) hide show
  1. package/lib/exercises/exercise.d.ts +7 -0
  2. package/lib/exercises/exercise.d.ts.map +1 -1
  3. package/lib/exercises/math/calculLitteral/equation/exp/expOfAffineEquals1Equation.d.ts +14 -0
  4. package/lib/exercises/math/calculLitteral/equation/exp/expOfAffineEquals1Equation.d.ts.map +1 -0
  5. package/lib/exercises/math/calculLitteral/equation/exp/expOfAffineEquals1Equation.js +145 -0
  6. package/lib/exercises/math/calculLitteral/equation/exp/expOfFEqualsExpOfGEquation.d.ts +16 -0
  7. package/lib/exercises/math/calculLitteral/equation/exp/expOfFEqualsExpOfGEquation.d.ts.map +1 -0
  8. package/lib/exercises/math/calculLitteral/equation/exp/expOfFEqualsExpOfGEquation.js +445 -0
  9. package/lib/exercises/math/calculLitteral/equation/exp/expOfTrinomEquals1Equation.d.ts +15 -0
  10. package/lib/exercises/math/calculLitteral/equation/exp/expOfTrinomEquals1Equation.d.ts.map +1 -0
  11. package/lib/exercises/math/calculLitteral/equation/exp/expOfTrinomEquals1Equation.js +371 -0
  12. package/lib/exercises/math/calculLitteral/equation/exp/index.d.ts +4 -0
  13. package/lib/exercises/math/calculLitteral/equation/exp/index.d.ts.map +1 -0
  14. package/lib/exercises/math/calculLitteral/equation/exp/index.js +3 -0
  15. package/lib/exercises/math/calculLitteral/equation/factorizeEquation.d.ts.map +1 -1
  16. package/lib/exercises/math/calculLitteral/equation/factorizeEquation.js +8 -2
  17. package/lib/exercises/math/calculLitteral/equation/index.d.ts +1 -0
  18. package/lib/exercises/math/calculLitteral/equation/index.d.ts.map +1 -1
  19. package/lib/exercises/math/calculLitteral/equation/index.js +1 -0
  20. package/lib/exercises/math/calculLitteral/equation/multiplicationEquation.d.ts.map +1 -1
  21. package/lib/exercises/math/calculLitteral/equation/multiplicationEquation.js +27 -2
  22. package/lib/exercises/math/calculLitteral/equation/solveByFactorizingWithIdRmq3.d.ts.map +1 -1
  23. package/lib/exercises/math/calculLitteral/equation/solveByFactorizingWithIdRmq3.js +0 -1
  24. package/lib/exercises/math/calculLitteral/equation/square/equationSquareWithSteps.d.ts.map +1 -1
  25. package/lib/exercises/math/calculLitteral/equation/square/equationSquareWithSteps.js +0 -1
  26. package/lib/exercises/math/calculLitteral/inequations/exp/expOfFEqualsExpOfGInequation.d.ts +18 -0
  27. package/lib/exercises/math/calculLitteral/inequations/exp/expOfFEqualsExpOfGInequation.d.ts.map +1 -0
  28. package/lib/exercises/math/calculLitteral/inequations/exp/expOfFEqualsExpOfGInequation.js +444 -0
  29. package/lib/exercises/math/calculLitteral/inequations/exp/index.d.ts +2 -0
  30. package/lib/exercises/math/calculLitteral/inequations/exp/index.d.ts.map +1 -0
  31. package/lib/exercises/math/calculLitteral/inequations/exp/index.js +1 -0
  32. package/lib/exercises/math/calculLitteral/inequations/firstDegreeInequationsType3.d.ts.map +1 -1
  33. package/lib/exercises/math/calculLitteral/inequations/firstDegreeInequationsType3.js +11 -5
  34. package/lib/exercises/math/calculLitteral/inequations/index.d.ts +1 -0
  35. package/lib/exercises/math/calculLitteral/inequations/index.d.ts.map +1 -1
  36. package/lib/exercises/math/calculLitteral/inequations/index.js +1 -0
  37. package/lib/exercises/math/derivation/derivative/exp/expDerivativeFour.d.ts.map +1 -1
  38. package/lib/exercises/math/derivation/derivative/exp/expDerivativeFour.js +91 -21
  39. package/lib/exercises/math/derivation/derivative/exp/expDerivativeOne.d.ts.map +1 -1
  40. package/lib/exercises/math/derivation/derivative/exp/expDerivativeOne.js +64 -15
  41. package/lib/exercises/math/derivation/derivative/exp/expDerivativeThree.d.ts.map +1 -1
  42. package/lib/exercises/math/derivation/derivative/exp/expDerivativeThree.js +71 -15
  43. package/lib/exercises/math/derivation/derivative/exp/expDerivativeTwo.d.ts.map +1 -1
  44. package/lib/exercises/math/derivation/derivative/exp/expDerivativeTwo.js +36 -17
  45. package/lib/exercises/math/derivation/derivative/exp/expOverExpDerivative.d.ts +10 -0
  46. package/lib/exercises/math/derivation/derivative/exp/expOverExpDerivative.d.ts.map +1 -0
  47. package/lib/exercises/math/derivation/derivative/exp/expOverExpDerivative.js +294 -0
  48. package/lib/exercises/math/derivation/derivative/exp/index.d.ts +1 -0
  49. package/lib/exercises/math/derivation/derivative/exp/index.d.ts.map +1 -1
  50. package/lib/exercises/math/derivation/derivative/exp/index.js +1 -0
  51. package/lib/exercises/math/derivation/derivative/inverseFunctionDerivative.d.ts.map +1 -1
  52. package/lib/exercises/math/derivation/derivative/inverseFunctionDerivative.js +30 -2
  53. package/lib/exercises/math/derivation/derivative/productDerivative.d.ts.map +1 -1
  54. package/lib/exercises/math/derivation/derivative/productDerivative.js +68 -1
  55. package/lib/exercises/math/derivation/derivative/quotientDerivative.d.ts.map +1 -1
  56. package/lib/exercises/math/derivation/derivative/quotientDerivative.js +40 -4
  57. package/lib/exercises/math/derivation/derivative/sqrt/sqrtCompositionDerivation.d.ts.map +1 -1
  58. package/lib/exercises/math/derivation/derivative/sqrt/sqrtCompositionDerivation.js +30 -3
  59. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeAlgebraicExpression.d.ts +12 -0
  60. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeAlgebraicExpression.d.ts.map +1 -0
  61. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeAlgebraicExpression.js +127 -0
  62. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeFromAlgebraic.d.ts +13 -0
  63. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeFromAlgebraic.d.ts.map +1 -0
  64. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeFromAlgebraic.js +161 -0
  65. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeFromImages.d.ts +11 -0
  66. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeFromImages.d.ts.map +1 -0
  67. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeFromImages.js +116 -0
  68. package/lib/exercises/math/derivation/derivativeNumber/derivativeNumberCalcul.d.ts +8 -0
  69. package/lib/exercises/math/derivation/derivativeNumber/derivativeNumberCalcul.d.ts.map +1 -0
  70. package/lib/exercises/math/derivation/derivativeNumber/derivativeNumberCalcul.js +142 -0
  71. package/lib/exercises/math/derivation/derivativeNumber/index.d.ts +4 -0
  72. package/lib/exercises/math/derivation/derivativeNumber/index.d.ts.map +1 -0
  73. package/lib/exercises/math/derivation/derivativeNumber/index.js +4 -0
  74. package/lib/exercises/math/derivation/index.d.ts +1 -1
  75. package/lib/exercises/math/derivation/index.js +1 -1
  76. package/lib/exercises/math/derivation/variations/index.d.ts +1 -0
  77. package/lib/exercises/math/derivation/variations/index.d.ts.map +1 -1
  78. package/lib/exercises/math/derivation/variations/index.js +1 -0
  79. package/lib/exercises/math/derivation/variations/readExtremaAbscissFromDerivativeCurve.d.ts +7 -0
  80. package/lib/exercises/math/derivation/variations/readExtremaAbscissFromDerivativeCurve.d.ts.map +1 -0
  81. package/lib/exercises/math/derivation/variations/readExtremaAbscissFromDerivativeCurve.js +174 -0
  82. package/lib/exercises/math/functions/exponential/algebraic/approxExpAPlusB.d.ts +13 -0
  83. package/lib/exercises/math/functions/exponential/algebraic/approxExpAPlusB.d.ts.map +1 -0
  84. package/lib/exercises/math/functions/exponential/algebraic/approxExpAPlusB.js +305 -0
  85. package/lib/exercises/math/functions/exponential/algebraic/approxExpKa.d.ts +11 -0
  86. package/lib/exercises/math/functions/exponential/algebraic/approxExpKa.d.ts.map +1 -0
  87. package/lib/exercises/math/functions/exponential/algebraic/approxExpKa.js +216 -0
  88. package/lib/exercises/math/functions/exponential/algebraic/approxExpN.d.ts +9 -0
  89. package/lib/exercises/math/functions/exponential/algebraic/approxExpN.d.ts.map +1 -0
  90. package/lib/exercises/math/functions/exponential/algebraic/approxExpN.js +142 -0
  91. package/lib/exercises/math/functions/exponential/algebraic/index.d.ts +5 -0
  92. package/lib/exercises/math/functions/exponential/algebraic/index.d.ts.map +1 -0
  93. package/lib/exercises/math/functions/exponential/algebraic/index.js +4 -0
  94. package/lib/exercises/math/functions/exponential/algebraic/rewriteExpUsingExpA.d.ts +14 -0
  95. package/lib/exercises/math/functions/exponential/algebraic/rewriteExpUsingExpA.d.ts.map +1 -0
  96. package/lib/exercises/math/functions/exponential/algebraic/rewriteExpUsingExpA.js +337 -0
  97. package/lib/exercises/math/functions/exponential/definition/approxExpAPlusH.d.ts +11 -0
  98. package/lib/exercises/math/functions/exponential/definition/approxExpAPlusH.d.ts.map +1 -0
  99. package/lib/exercises/math/functions/exponential/definition/approxExpAPlusH.js +223 -0
  100. package/lib/exercises/math/functions/exponential/definition/expAntecedentFromGraph.d.ts +9 -0
  101. package/lib/exercises/math/functions/exponential/definition/expAntecedentFromGraph.d.ts.map +1 -0
  102. package/lib/exercises/math/functions/exponential/definition/expAntecedentFromGraph.js +262 -0
  103. package/lib/exercises/math/functions/exponential/definition/expImageFromGraph.d.ts +9 -0
  104. package/lib/exercises/math/functions/exponential/definition/expImageFromGraph.d.ts.map +1 -0
  105. package/lib/exercises/math/functions/exponential/definition/expImageFromGraph.js +245 -0
  106. package/lib/exercises/math/functions/exponential/definition/index.d.ts +5 -0
  107. package/lib/exercises/math/functions/exponential/definition/index.d.ts.map +1 -0
  108. package/lib/exercises/math/functions/exponential/definition/index.js +4 -0
  109. package/lib/exercises/math/functions/exponential/definition/isPlausibleExpFromGraph.d.ts +13 -0
  110. package/lib/exercises/math/functions/exponential/definition/isPlausibleExpFromGraph.d.ts.map +1 -0
  111. package/lib/exercises/math/functions/exponential/definition/isPlausibleExpFromGraph.js +366 -0
  112. package/lib/exercises/math/functions/exponential/expFactorization.d.ts.map +1 -1
  113. package/lib/exercises/math/functions/exponential/expFactorization.js +54 -42
  114. package/lib/exercises/math/functions/exponential/index.d.ts +2 -0
  115. package/lib/exercises/math/functions/exponential/index.d.ts.map +1 -1
  116. package/lib/exercises/math/functions/exponential/index.js +2 -0
  117. package/lib/exercises/math/functions/trinoms/devForm/coefficientsIdentification.d.ts.map +1 -1
  118. package/lib/exercises/math/functions/trinoms/devForm/coefficientsIdentification.js +30 -3
  119. package/lib/exercises/math/functions/trinoms/equation/deltaTrinom.d.ts.map +1 -1
  120. package/lib/exercises/math/functions/trinoms/equation/deltaTrinom.js +35 -1
  121. package/lib/exercises/math/functions/trinoms/equation/secondDegreeInequation.js +3 -0
  122. package/lib/exercises/math/functions/trinoms/parabole/paraboleExpressionReading.d.ts.map +1 -1
  123. package/lib/exercises/math/functions/trinoms/parabole/paraboleExpressionReading.js +1 -1
  124. package/lib/exercises/math/functions/trinoms/summitAndCanonical/alphaBetaInCanonicalForm.d.ts.map +1 -1
  125. package/lib/exercises/math/functions/trinoms/summitAndCanonical/alphaBetaInCanonicalForm.js +23 -1
  126. package/lib/exercises/math/functions/trinoms/summitAndCanonical/extremumFromCanonicalForm.d.ts.map +1 -1
  127. package/lib/exercises/math/functions/trinoms/summitAndCanonical/extremumFromCanonicalForm.js +29 -0
  128. package/lib/exercises/math/functions/variations/exp/index.d.ts +3 -0
  129. package/lib/exercises/math/functions/variations/exp/index.d.ts.map +1 -0
  130. package/lib/exercises/math/functions/variations/exp/index.js +2 -0
  131. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusB.d.ts +9 -0
  132. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusB.d.ts.map +1 -0
  133. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusB.js +96 -0
  134. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusBOverCEXPlusD.d.ts +11 -0
  135. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusBOverCEXPlusD.d.ts.map +1 -0
  136. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusBOverCEXPlusD.js +190 -0
  137. package/lib/exercises/math/functions/variations/index.d.ts +1 -0
  138. package/lib/exercises/math/functions/variations/index.d.ts.map +1 -1
  139. package/lib/exercises/math/functions/variations/index.js +1 -0
  140. package/lib/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPerpendicularLine.d.ts +12 -0
  141. package/lib/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPerpendicularLine.d.ts.map +1 -0
  142. package/lib/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPerpendicularLine.js +230 -0
  143. package/lib/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPointAndNormalVector.d.ts +10 -0
  144. package/lib/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPointAndNormalVector.d.ts.map +1 -0
  145. package/lib/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPointAndNormalVector.js +167 -0
  146. package/lib/exercises/math/geometry/cartesian/index.d.ts +3 -0
  147. package/lib/exercises/math/geometry/cartesian/index.d.ts.map +1 -1
  148. package/lib/exercises/math/geometry/cartesian/index.js +3 -0
  149. package/lib/exercises/math/geometry/cartesian/normalVectorFromCartesianLineEquation.d.ts +10 -0
  150. package/lib/exercises/math/geometry/cartesian/normalVectorFromCartesianLineEquation.d.ts.map +1 -0
  151. package/lib/exercises/math/geometry/cartesian/normalVectorFromCartesianLineEquation.js +131 -0
  152. package/lib/exercises/math/geometry/circles/index.d.ts +2 -0
  153. package/lib/exercises/math/geometry/circles/index.d.ts.map +1 -0
  154. package/lib/exercises/math/geometry/circles/index.js +1 -0
  155. package/lib/exercises/math/geometry/circles/isPointOnCircleFromCartesianEquation.d.ts +11 -0
  156. package/lib/exercises/math/geometry/circles/isPointOnCircleFromCartesianEquation.d.ts.map +1 -0
  157. package/lib/exercises/math/geometry/circles/isPointOnCircleFromCartesianEquation.js +131 -0
  158. package/lib/exercises/math/geometry/euclidian/pinPointFromAxialOrCentralSymmetry.js +2 -2
  159. package/lib/exercises/math/geometry/euclidian/pinSegmentFromRotation.d.ts.map +1 -1
  160. package/lib/exercises/math/geometry/euclidian/pinSegmentFromRotation.js +0 -2
  161. package/lib/exercises/math/geometry/index.d.ts +1 -0
  162. package/lib/exercises/math/geometry/index.d.ts.map +1 -1
  163. package/lib/exercises/math/geometry/index.js +1 -0
  164. package/lib/exercises/math/geometry/thales/thales.js +1 -1
  165. package/lib/exercises/math/geometry/thales/thalesCalcul.js +1 -1
  166. package/lib/exercises/math/geometry/vectors/colinearity/determinant.js +1 -1
  167. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/index.d.ts +4 -0
  168. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/index.d.ts.map +1 -0
  169. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/index.js +3 -0
  170. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiAngle.d.ts +9 -0
  171. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiAngle.d.ts.map +1 -0
  172. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiAngle.js +247 -0
  173. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiBH.d.ts +13 -0
  174. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiBH.d.ts.map +1 -0
  175. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiBH.js +452 -0
  176. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiSideLength.d.ts +9 -0
  177. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiSideLength.d.ts.map +1 -0
  178. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiSideLength.js +253 -0
  179. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/index.d.ts +4 -0
  180. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/index.d.ts.map +1 -0
  181. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/index.js +3 -0
  182. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductIdentities.d.ts +10 -0
  183. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductIdentities.d.ts.map +1 -0
  184. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductIdentities.js +174 -0
  185. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductInOrthonormalBasisIJ.d.ts +9 -0
  186. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductInOrthonormalBasisIJ.d.ts.map +1 -0
  187. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductInOrthonormalBasisIJ.js +231 -0
  188. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductLamdbaULambdaV.d.ts +14 -0
  189. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductLamdbaULambdaV.d.ts.map +1 -0
  190. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductLamdbaULambdaV.js +292 -0
  191. package/lib/exercises/math/geometry/vectors/scalarProduct/angleFromScalarProduct.js +1 -1
  192. package/lib/exercises/math/geometry/vectors/scalarProduct/findCoordinatesToOrthogonalize.d.ts.map +1 -1
  193. package/lib/exercises/math/geometry/vectors/scalarProduct/findCoordinatesToOrthogonalize.js +33 -7
  194. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/index.d.ts +6 -0
  195. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/index.d.ts.map +1 -0
  196. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/index.js +5 -0
  197. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsOrthogonalVecsBasisIJ.d.ts +9 -0
  198. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsOrthogonalVecsBasisIJ.d.ts.map +1 -0
  199. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsOrthogonalVecsBasisIJ.js +202 -0
  200. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsOrthogonalVecsUsingCoords.d.ts +9 -0
  201. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsOrthogonalVecsUsingCoords.d.ts.map +1 -0
  202. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsOrthogonalVecsUsingCoords.js +127 -0
  203. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsPointOnCircle.d.ts +12 -0
  204. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsPointOnCircle.d.ts.map +1 -0
  205. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsPointOnCircle.js +167 -0
  206. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsPointOnPerpendicularBisector.d.ts +12 -0
  207. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsPointOnPerpendicularBisector.d.ts.map +1 -0
  208. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsPointOnPerpendicularBisector.js +180 -0
  209. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsRightTriangleUsingPointCoords.d.ts +12 -0
  210. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsRightTriangleUsingPointCoords.d.ts.map +1 -0
  211. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsRightTriangleUsingPointCoords.js +235 -0
  212. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductComputeBH.d.ts +12 -0
  213. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductComputeBH.d.ts.map +1 -0
  214. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductComputeBH.js +423 -0
  215. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductOfVectsOnGrid1.d.ts +17 -0
  216. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductOfVectsOnGrid1.d.ts.map +1 -0
  217. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductOfVectsOnGrid1.js +347 -0
  218. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductParallelogramDiagonalPlus.d.ts +8 -0
  219. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductParallelogramDiagonalPlus.d.ts.map +1 -0
  220. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductParallelogramDiagonalPlus.js +301 -0
  221. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductViaCoords.js +1 -1
  222. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductViaCos.d.ts.map +1 -1
  223. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductViaCos.js +38 -1
  224. package/lib/exercises/math/probaStat/conditionalProbability.d.ts +4 -1
  225. package/lib/exercises/math/probaStat/conditionalProbability.d.ts.map +1 -1
  226. package/lib/exercises/math/probaStat/conditionalProbability.js +38 -5
  227. package/lib/exercises/math/probaStat/independancy/independancy.d.ts +9 -0
  228. package/lib/exercises/math/probaStat/independancy/independancy.d.ts.map +1 -0
  229. package/lib/exercises/math/probaStat/independancy/independancy.js +114 -0
  230. package/lib/exercises/math/probaStat/independancy/independancyFindCap.d.ts +9 -0
  231. package/lib/exercises/math/probaStat/independancy/independancyFindCap.d.ts.map +1 -0
  232. package/lib/exercises/math/probaStat/independancy/independancyFindCap.js +101 -0
  233. package/lib/exercises/math/probaStat/independancy/independancyFindCup.d.ts +9 -0
  234. package/lib/exercises/math/probaStat/independancy/independancyFindCup.d.ts.map +1 -0
  235. package/lib/exercises/math/probaStat/independancy/independancyFindCup.js +118 -0
  236. package/lib/exercises/math/probaStat/independancy/index.d.ts +5 -0
  237. package/lib/exercises/math/probaStat/independancy/index.d.ts.map +1 -0
  238. package/lib/exercises/math/probaStat/independancy/index.js +4 -0
  239. package/lib/exercises/math/probaStat/independancy/isIndependantFromDefinition.d.ts +10 -0
  240. package/lib/exercises/math/probaStat/independancy/isIndependantFromDefinition.d.ts.map +1 -0
  241. package/lib/exercises/math/probaStat/independancy/isIndependantFromDefinition.js +106 -0
  242. package/lib/exercises/math/probaStat/index.d.ts +1 -1
  243. package/lib/exercises/math/probaStat/index.d.ts.map +1 -1
  244. package/lib/exercises/math/probaStat/index.js +1 -1
  245. package/lib/exercises/math/probaStat/randomVariable/findValueForFairRandomVariable.d.ts +9 -0
  246. package/lib/exercises/math/probaStat/randomVariable/findValueForFairRandomVariable.d.ts.map +1 -0
  247. package/lib/exercises/math/probaStat/randomVariable/findValueForFairRandomVariable.js +141 -0
  248. package/lib/exercises/math/probaStat/randomVariable/findValueToMatchRandomVariableAverage.d.ts +10 -0
  249. package/lib/exercises/math/probaStat/randomVariable/findValueToMatchRandomVariableAverage.d.ts.map +1 -0
  250. package/lib/exercises/math/probaStat/randomVariable/findValueToMatchRandomVariableAverage.js +174 -0
  251. package/lib/exercises/math/probaStat/randomVariable/index.d.ts +1 -0
  252. package/lib/exercises/math/probaStat/randomVariable/index.d.ts.map +1 -1
  253. package/lib/exercises/math/probaStat/randomVariable/index.js +2 -0
  254. package/lib/exercises/math/probaStat/randomVariable/randomVariableStandardDeviation.js +1 -1
  255. package/lib/exercises/math/probaStat/twoStepExperiments/headsOrTailsTwiceOutcomes.d.ts.map +1 -1
  256. package/lib/exercises/math/probaStat/twoStepExperiments/headsOrTailsTwiceOutcomes.js +7 -0
  257. package/lib/exercises/math/probaStat/twoStepExperiments/headsOrTailsTwiceProbas.d.ts.map +1 -1
  258. package/lib/exercises/math/probaStat/twoStepExperiments/headsOrTailsTwiceProbas.js +7 -0
  259. package/lib/exercises/math/probaStat/twoStepExperiments/numberPoolTwiceProbas.d.ts.map +1 -1
  260. package/lib/exercises/math/probaStat/twoStepExperiments/numberPoolTwiceProbas.js +7 -0
  261. package/lib/exercises/math/probaStat/twoStepExperiments/twoStepExperimentProbas.d.ts.map +1 -1
  262. package/lib/exercises/math/probaStat/twoStepExperiments/twoStepExperimentProbas.js +7 -0
  263. package/lib/exercises/math/sequences/arithmetic/arithmeticFindExplicitFormulaFirstTermRandom.d.ts +9 -0
  264. package/lib/exercises/math/sequences/arithmetic/arithmeticFindExplicitFormulaFirstTermRandom.d.ts.map +1 -0
  265. package/lib/exercises/math/sequences/arithmetic/arithmeticFindExplicitFormulaFirstTermRandom.js +118 -0
  266. package/lib/exercises/math/sequences/arithmetic/arithmeticFindRandomTermFromTwoTerms.d.ts.map +1 -1
  267. package/lib/exercises/math/sequences/arithmetic/arithmeticFindRandomTermFromTwoTerms.js +55 -6
  268. package/lib/exercises/math/sequences/arithmetic/arithmeticFindReasonRandomRange.d.ts.map +1 -1
  269. package/lib/exercises/math/sequences/arithmetic/arithmeticFindReasonRandomRange.js +42 -1
  270. package/lib/exercises/math/sequences/arithmetic/arithmeticFirstTermsSum.d.ts +4 -1
  271. package/lib/exercises/math/sequences/arithmetic/arithmeticFirstTermsSum.d.ts.map +1 -1
  272. package/lib/exercises/math/sequences/arithmetic/arithmeticFirstTermsSum.js +57 -7
  273. package/lib/exercises/math/sequences/arithmetic/arithmeticRecurrenceFormulaUsage.d.ts.map +1 -1
  274. package/lib/exercises/math/sequences/arithmetic/arithmeticRecurrenceFormulaUsage.js +24 -2
  275. package/lib/exercises/math/sequences/arithmetic/arithmeticThresholdFind.d.ts.map +1 -1
  276. package/lib/exercises/math/sequences/arithmetic/arithmeticThresholdFind.js +31 -8
  277. package/lib/exercises/math/sequences/arithmetic/index.d.ts +1 -1
  278. package/lib/exercises/math/sequences/arithmetic/index.d.ts.map +1 -1
  279. package/lib/exercises/math/sequences/arithmetic/index.js +1 -1
  280. package/lib/exercises/math/sequences/arithmetic/recognizeArithmeticFromGraph.d.ts.map +1 -1
  281. package/lib/exercises/math/sequences/arithmetic/recognizeArithmeticFromGraph.js +11 -1
  282. package/lib/exercises/math/sequences/generation/index.d.ts +2 -0
  283. package/lib/exercises/math/sequences/generation/index.d.ts.map +1 -0
  284. package/lib/exercises/math/sequences/generation/index.js +1 -0
  285. package/lib/exercises/math/sequences/generation/recognizeRecurrenceOrExplicit.d.ts +8 -0
  286. package/lib/exercises/math/sequences/generation/recognizeRecurrenceOrExplicit.d.ts.map +1 -0
  287. package/lib/exercises/math/sequences/generation/recognizeRecurrenceOrExplicit.js +63 -0
  288. package/lib/exercises/math/sequences/geometric/geometricFindExplicitFormulaFirstRankOne.js +5 -5
  289. package/lib/exercises/math/sequences/geometric/geometricFindExplicitFormulaFirstTermRandom.d.ts.map +1 -1
  290. package/lib/exercises/math/sequences/geometric/geometricFindExplicitFormulaFirstTermRandom.js +3 -1
  291. package/lib/exercises/math/sequences/geometric/geometricFindReason.d.ts.map +1 -1
  292. package/lib/exercises/math/sequences/geometric/geometricFindReason.js +41 -2
  293. package/lib/exercises/math/sequences/geometric/geometricRecurrenceFormulaUsage.d.ts.map +1 -1
  294. package/lib/exercises/math/sequences/geometric/geometricRecurrenceFormulaUsage.js +28 -2
  295. package/lib/exercises/math/sequences/graph/index.d.ts +2 -0
  296. package/lib/exercises/math/sequences/graph/index.d.ts.map +1 -0
  297. package/lib/exercises/math/sequences/graph/index.js +1 -0
  298. package/lib/exercises/math/sequences/graph/placeFirstSequencePoints.d.ts +11 -0
  299. package/lib/exercises/math/sequences/graph/placeFirstSequencePoints.d.ts.map +1 -0
  300. package/lib/exercises/math/sequences/graph/placeFirstSequencePoints.js +113 -0
  301. package/lib/exercises/math/sequences/index.d.ts +2 -0
  302. package/lib/exercises/math/sequences/index.d.ts.map +1 -1
  303. package/lib/exercises/math/sequences/index.js +2 -0
  304. package/lib/exercises/math/sequences/notation/identifyRankInSequenceTermsList.d.ts +12 -0
  305. package/lib/exercises/math/sequences/notation/identifyRankInSequenceTermsList.d.ts.map +1 -0
  306. package/lib/exercises/math/sequences/notation/identifyRankInSequenceTermsList.js +114 -0
  307. package/lib/exercises/math/sequences/notation/identifySequenceTermInList.d.ts +12 -0
  308. package/lib/exercises/math/sequences/notation/identifySequenceTermInList.d.ts.map +1 -0
  309. package/lib/exercises/math/sequences/notation/identifySequenceTermInList.js +111 -0
  310. package/lib/exercises/math/sequences/notation/index.d.ts +3 -0
  311. package/lib/exercises/math/sequences/notation/index.d.ts.map +1 -0
  312. package/lib/exercises/math/sequences/notation/index.js +2 -0
  313. package/lib/exercises/math/sequences/sequenceEvaluation.d.ts.map +1 -1
  314. package/lib/exercises/math/sequences/sequenceEvaluation.js +22 -2
  315. package/lib/exercises/math/spaceGeometry/basis/findSpacePointOnRectangularPrism.d.ts.map +1 -1
  316. package/lib/exercises/math/spaceGeometry/basis/findSpacePointOnRectangularPrism.js +0 -1
  317. package/lib/exercises/math/spaceGeometry/sphere/sphereLatLonReading.2d.d.ts.map +1 -1
  318. package/lib/exercises/math/spaceGeometry/sphere/sphereLatLonReading.2d.js +0 -2
  319. package/lib/exercises/math/trigonometry/circle/areReelsOnTheSameTrigoCirclePoint.d.ts +9 -0
  320. package/lib/exercises/math/trigonometry/circle/areReelsOnTheSameTrigoCirclePoint.d.ts.map +1 -0
  321. package/lib/exercises/math/trigonometry/circle/areReelsOnTheSameTrigoCirclePoint.js +107 -0
  322. package/lib/exercises/math/trigonometry/circle/associatePoint.d.ts +10 -0
  323. package/lib/exercises/math/trigonometry/circle/associatePoint.d.ts.map +1 -0
  324. package/lib/exercises/math/trigonometry/circle/associatePoint.js +86 -0
  325. package/lib/exercises/math/trigonometry/circle/associateReelToTrigoCirclePoint.d.ts +10 -0
  326. package/lib/exercises/math/trigonometry/circle/associateReelToTrigoCirclePoint.d.ts.map +1 -0
  327. package/lib/exercises/math/trigonometry/circle/associateReelToTrigoCirclePoint.js +205 -0
  328. package/lib/exercises/math/trigonometry/circle/findAngleFromCosAndSin.d.ts +7 -0
  329. package/lib/exercises/math/trigonometry/circle/findAngleFromCosAndSin.d.ts.map +1 -0
  330. package/lib/exercises/math/trigonometry/circle/findAngleFromCosAndSin.js +121 -0
  331. package/lib/exercises/math/trigonometry/circle/index.d.ts +7 -0
  332. package/lib/exercises/math/trigonometry/circle/index.d.ts.map +1 -0
  333. package/lib/exercises/math/trigonometry/circle/index.js +7 -0
  334. package/lib/exercises/math/trigonometry/circle/mainAngleMeasure.d.ts +10 -0
  335. package/lib/exercises/math/trigonometry/circle/mainAngleMeasure.d.ts.map +1 -0
  336. package/lib/exercises/math/trigonometry/circle/mainAngleMeasure.js +100 -0
  337. package/lib/exercises/math/trigonometry/circle/mainRemarkableValues.d.ts +8 -0
  338. package/lib/exercises/math/trigonometry/circle/mainRemarkableValues.d.ts.map +1 -0
  339. package/lib/exercises/math/trigonometry/circle/mainRemarkableValues.js +97 -0
  340. package/lib/exercises/math/trigonometry/circle/remarkableValues.d.ts +10 -0
  341. package/lib/exercises/math/trigonometry/circle/remarkableValues.d.ts.map +1 -0
  342. package/lib/exercises/math/trigonometry/circle/remarkableValues.js +112 -0
  343. package/lib/exercises/math/trigonometry/functions/basicEquationCos.d.ts +7 -0
  344. package/lib/exercises/math/trigonometry/functions/basicEquationCos.d.ts.map +1 -0
  345. package/lib/exercises/math/trigonometry/functions/basicEquationCos.js +92 -0
  346. package/lib/exercises/math/trigonometry/functions/basicEquationSin.d.ts +7 -0
  347. package/lib/exercises/math/trigonometry/functions/basicEquationSin.d.ts.map +1 -0
  348. package/lib/exercises/math/trigonometry/functions/basicEquationSin.js +104 -0
  349. package/lib/exercises/math/trigonometry/functions/basicTrigoSystemEquation.d.ts +7 -0
  350. package/lib/exercises/math/trigonometry/functions/basicTrigoSystemEquation.d.ts.map +1 -0
  351. package/lib/exercises/math/trigonometry/functions/basicTrigoSystemEquation.js +83 -0
  352. package/lib/exercises/math/trigonometry/functions/equationCosOnRandomInterval.d.ts +8 -0
  353. package/lib/exercises/math/trigonometry/functions/equationCosOnRandomInterval.d.ts.map +1 -0
  354. package/lib/exercises/math/trigonometry/functions/equationCosOnRandomInterval.js +111 -0
  355. package/lib/exercises/math/trigonometry/functions/equationSinOnRandomInterval.d.ts +8 -0
  356. package/lib/exercises/math/trigonometry/functions/equationSinOnRandomInterval.d.ts.map +1 -0
  357. package/lib/exercises/math/trigonometry/functions/equationSinOnRandomInterval.js +101 -0
  358. package/lib/exercises/math/trigonometry/functions/index.d.ts +6 -0
  359. package/lib/exercises/math/trigonometry/functions/index.d.ts.map +1 -0
  360. package/lib/exercises/math/trigonometry/functions/index.js +6 -0
  361. package/lib/exercises/math/trigonometry/functions/trigoAssociateAngle.d.ts +9 -0
  362. package/lib/exercises/math/trigonometry/functions/trigoAssociateAngle.d.ts.map +1 -0
  363. package/lib/exercises/math/trigonometry/functions/trigoAssociateAngle.js +151 -0
  364. package/lib/exercises/math/trigonometry/index.d.ts +3 -14
  365. package/lib/exercises/math/trigonometry/index.d.ts.map +1 -1
  366. package/lib/exercises/math/trigonometry/index.js +3 -14
  367. package/lib/exercises/math/trigonometry/triangle/index.d.ts +7 -0
  368. package/lib/exercises/math/trigonometry/triangle/index.d.ts.map +1 -0
  369. package/lib/exercises/math/trigonometry/triangle/index.js +6 -0
  370. package/lib/exercises/math/trigonometry/triangle/trigonometry.d.ts +10 -0
  371. package/lib/exercises/math/trigonometry/triangle/trigonometry.d.ts.map +1 -0
  372. package/lib/exercises/math/trigonometry/triangle/trigonometry.js +207 -0
  373. package/lib/exercises/math/trigonometry/triangle/trigonometryAngleCalcul.d.ts +10 -0
  374. package/lib/exercises/math/trigonometry/triangle/trigonometryAngleCalcul.d.ts.map +1 -0
  375. package/lib/exercises/math/trigonometry/triangle/trigonometryAngleCalcul.js +174 -0
  376. package/lib/exercises/math/trigonometry/triangle/trigonometrySideCalcul.d.ts +11 -0
  377. package/lib/exercises/math/trigonometry/triangle/trigonometrySideCalcul.d.ts.map +1 -0
  378. package/lib/exercises/math/trigonometry/triangle/trigonometrySideCalcul.js +224 -0
  379. package/lib/exercises/math/trigonometry/triangle/trigonometrySideName.d.ts +13 -0
  380. package/lib/exercises/math/trigonometry/triangle/trigonometrySideName.d.ts.map +1 -0
  381. package/lib/exercises/math/trigonometry/triangle/trigonometrySideName.js +189 -0
  382. package/lib/exercises/math/trigonometry/triangle/trigonometrySohcahtoaCalcul.d.ts +13 -0
  383. package/lib/exercises/math/trigonometry/triangle/trigonometrySohcahtoaCalcul.d.ts.map +1 -0
  384. package/lib/exercises/math/trigonometry/triangle/trigonometrySohcahtoaCalcul.js +290 -0
  385. package/lib/exercises/math/trigonometry/triangle/trigonometrySohcahtoaUse.d.ts +18 -0
  386. package/lib/exercises/math/trigonometry/triangle/trigonometrySohcahtoaUse.d.ts.map +1 -0
  387. package/lib/exercises/math/trigonometry/triangle/trigonometrySohcahtoaUse.js +386 -0
  388. package/lib/exercises/pc/mathExosInPC.d.ts +2 -2
  389. package/lib/exercises/pc/mathExosInPC.d.ts.map +1 -1
  390. package/lib/exercises/pc/mathExosInPC.js +2 -2
  391. package/lib/exercises/vea/cartesianLineVEA.d.ts +2 -0
  392. package/lib/exercises/vea/cartesianLineVEA.d.ts.map +1 -0
  393. package/lib/exercises/vea/cartesianLineVEA.js +1 -0
  394. package/lib/index.d.ts +186 -27
  395. package/lib/index.d.ts.map +1 -1
  396. package/lib/math/geometry/line.d.ts +2 -0
  397. package/lib/math/geometry/line.d.ts.map +1 -1
  398. package/lib/math/geometry/line.js +7 -0
  399. package/lib/math/geometry/point.d.ts +1 -0
  400. package/lib/math/geometry/point.d.ts.map +1 -1
  401. package/lib/math/geometry/point.js +5 -0
  402. package/lib/math/geometry/polygons/relationPP.d.ts +8 -0
  403. package/lib/math/geometry/polygons/relationPP.d.ts.map +1 -0
  404. package/lib/math/geometry/polygons/relationPP.js +41 -0
  405. package/lib/math/geometry/segment.d.ts +1 -1
  406. package/lib/math/geometry/vector.d.ts +2 -1
  407. package/lib/math/geometry/vector.d.ts.map +1 -1
  408. package/lib/math/geometry/vector.js +1 -1
  409. package/lib/math/numbers/reals/real.d.ts.map +1 -1
  410. package/lib/math/numbers/reals/real.js +2 -0
  411. package/lib/math/polynomials/trinom.d.ts +1 -1
  412. package/lib/math/polynomials/trinom.d.ts.map +1 -1
  413. package/lib/math/polynomials/trinom.js +15 -6
  414. package/lib/math/utils/arithmetic/primeFactors.js +1 -1
  415. package/lib/math/utils/geometry/randomVecs2.d.ts +6 -0
  416. package/lib/math/utils/geometry/randomVecs2.d.ts.map +1 -0
  417. package/lib/math/utils/geometry/randomVecs2.js +34 -0
  418. package/lib/playground.d.ts.map +1 -1
  419. package/lib/playground.js +3 -1
  420. package/lib/tests/questionTest.d.ts.map +1 -1
  421. package/lib/tests/questionTest.js +2 -2
  422. package/lib/tree/nodes/algebraicNode.d.ts +1 -0
  423. package/lib/tree/nodes/algebraicNode.d.ts.map +1 -1
  424. package/lib/tree/nodes/equations/equationSolutionNode.d.ts +1 -0
  425. package/lib/tree/nodes/equations/equationSolutionNode.d.ts.map +1 -1
  426. package/lib/tree/nodes/equations/equationSolutionNode.js +3 -0
  427. package/lib/tree/nodes/functions/expNode.d.ts +1 -1
  428. package/lib/tree/nodes/functions/expNode.d.ts.map +1 -1
  429. package/lib/tree/nodes/functions/sqrtNode.d.ts +2 -1
  430. package/lib/tree/nodes/functions/sqrtNode.d.ts.map +1 -1
  431. package/lib/tree/nodes/functions/sqrtNode.js +17 -6
  432. package/lib/tree/nodes/inequations/inequationSolutionNode.d.ts +1 -0
  433. package/lib/tree/nodes/inequations/inequationSolutionNode.d.ts.map +1 -1
  434. package/lib/tree/nodes/inequations/inequationSolutionNode.js +3 -0
  435. package/lib/tree/nodes/operators/fractionNode.d.ts +1 -1
  436. package/lib/tree/nodes/operators/fractionNode.d.ts.map +1 -1
  437. package/lib/tree/nodes/operators/fractionNode.js +6 -4
  438. package/lib/tree/nodes/operators/multiplyNode.js +1 -1
  439. package/lib/tree/nodes/sets/intervalNode.d.ts +6 -0
  440. package/lib/tree/nodes/sets/intervalNode.d.ts.map +1 -1
  441. package/lib/tree/nodes/sets/namedIntervalNode.d.ts +31 -0
  442. package/lib/tree/nodes/sets/namedIntervalNode.d.ts.map +1 -0
  443. package/lib/tree/nodes/sets/namedIntervalNode.js +77 -0
  444. package/package.json +1 -1
@@ -0,0 +1,305 @@
1
+ import { addValidProp, shuffleProps, tryToAddWrongProp, } from "../../../../../exercises/exercise.js";
2
+ import { getDistinctQuestions } from "../../../../../exercises/utils/getDistinctQuestions.js";
3
+ import { nodeBySubstitutingVar } from "../../../../../math/utils/functions/functionComposition.js";
4
+ import { randfloat } from "../../../../../math/utils/random/randfloat.js";
5
+ import { randint } from "../../../../../math/utils/random/randint.js";
6
+ import { round } from "../../../../../math/utils/round.js";
7
+ import { exp } from "../../../../../tree/nodes/functions/expNode.js";
8
+ import { NodeConstructor, } from "../../../../../tree/nodes/nodeConstructor.js";
9
+ import { add } from "../../../../../tree/nodes/operators/addNode.js";
10
+ import { frac } from "../../../../../tree/nodes/operators/fractionNode.js";
11
+ import { multiply } from "../../../../../tree/nodes/operators/multiplyNode.js";
12
+ import { power } from "../../../../../tree/nodes/operators/powerNode.js";
13
+ import { substract } from "../../../../../tree/nodes/operators/substractNode.js";
14
+ import { VariableNode } from "../../../../../tree/nodes/variables/variableNode.js";
15
+ import { parseAlgebraic } from "../../../../../tree/parsers/latexParser.js";
16
+ import { coinFlip } from "../../../../../utils/alea/coinFlip.js";
17
+ import { random } from "../../../../../utils/alea/random.js";
18
+ import { shuffle } from "../../../../../utils/alea/shuffle.js";
19
+ const getInstruction = (identifiers) => {
20
+ const { nodeIdsA, nodeIdsB, nodeIdsAOpB, expARounded, expBRounded, precision, } = identifiers;
21
+ const [nodeA, nodeB, nodeAOpB] = [nodeIdsA, nodeIdsB, nodeIdsAOpB].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
22
+ const [texA, texB] = [nodeA, nodeB].map((node) => node.toTex());
23
+ const nodeAOpBSubstituted = [
24
+ ["a", nodeA],
25
+ ["b", nodeB],
26
+ ]
27
+ .reduce((acc, [varName, nodeInjected]) => {
28
+ return nodeBySubstitutingVar(acc, nodeInjected, new VariableNode(varName));
29
+ }, nodeAOpB)
30
+ .simplify({ fractionsToDecimal: true });
31
+ const texAOpBSubstituted = nodeAOpBSubstituted.toTex();
32
+ return `Sachant que :
33
+
34
+ $$
35
+ \\exp(${texA})\\approx ${expARounded.frenchify()}
36
+ $$
37
+
38
+ $$
39
+ \\exp(${texB})\\approx ${expBRounded.frenchify()}
40
+ $$
41
+
42
+ donner une valeur approchée de $\\exp(${texAOpBSubstituted})$
43
+
44
+ avec $${precision}$ décimale${precision > 1 ? "s" : ""}.`;
45
+ };
46
+ const getAnswerNode = (identifiers) => {
47
+ const { nodeIdsAOpB, expARounded, expBRounded, precision } = identifiers;
48
+ const nodeAOpB = NodeConstructor.fromIdentifiers(nodeIdsAOpB);
49
+ const texAOpB = nodeAOpB.toTex();
50
+ switch (texAOpB) {
51
+ case "a+b":
52
+ return round(multiply(expARounded, expBRounded).evaluate(), precision).toTree();
53
+ case "a-b":
54
+ return round(frac(expARounded, expBRounded).evaluate(), precision).toTree();
55
+ default:
56
+ throw new Error("Unsupported texAOpB: " + texAOpB);
57
+ }
58
+ };
59
+ const getAnswer = (identifiers) => {
60
+ return getAnswerNode(identifiers).toTex();
61
+ };
62
+ const getHint = (identifiers) => {
63
+ const { nodeIdsAOpB } = identifiers;
64
+ const nodeAOpB = NodeConstructor.fromIdentifiers(nodeIdsAOpB);
65
+ const texAOpB = nodeAOpB.toTex();
66
+ switch (texAOpB) {
67
+ case "a+b":
68
+ return `Utilise la propriété :
69
+
70
+ Si $a$ et $b$ sont deux nombres réels, alors :
71
+
72
+ $$
73
+ \\exp(a+b) = \\exp(a) \\times \\exp(b)
74
+ $$
75
+
76
+ `;
77
+ case "a-b":
78
+ return `Utilise la propriété :
79
+
80
+ Si $a$ et $b$ sont deux nombres réels, alors :
81
+
82
+ $$
83
+ \\exp(a-b) = \\frac{\\exp(a)}{\\exp(b)}
84
+ $$
85
+
86
+ `;
87
+ default:
88
+ throw new Error("Unsupported texAOpB: " + texAOpB);
89
+ }
90
+ };
91
+ const getCorrection = (identifiers) => {
92
+ const { nodeIdsA, nodeIdsB, nodeIdsAOpB, expARounded, expBRounded } = identifiers;
93
+ const [nodeA, nodeB, nodeAOpB] = [nodeIdsA, nodeIdsB, nodeIdsAOpB].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
94
+ const [texA, texB, texAOpB] = [nodeA, nodeB, nodeAOpB].map((node) => node.toTex());
95
+ const texBPretty = texB[0] === "-" ? `(${texB})` : texB;
96
+ const nodeAOpBSubstituted = [
97
+ ["a", nodeA],
98
+ ["b", nodeB],
99
+ ]
100
+ .reduce((acc, [varName, nodeInjected]) => {
101
+ return nodeBySubstitutingVar(acc, nodeInjected, new VariableNode(varName));
102
+ }, nodeAOpB)
103
+ .simplify({ fractionsToDecimal: true });
104
+ const texAOpBSubstituted = nodeAOpBSubstituted.toTex();
105
+ switch (texAOpB) {
106
+ case "a+b":
107
+ return `On a :
108
+
109
+ $$
110
+ \\exp(${texAOpBSubstituted}) = \\exp(${texA} + ${texBPretty})
111
+ $$
112
+
113
+ Ainsi :
114
+
115
+ $$
116
+ \\exp(${texAOpBSubstituted}) = \\exp(${texA}) \\times \\exp(${texB})
117
+ $$
118
+
119
+ $$
120
+ \\exp(${texAOpBSubstituted}) \\approx ${expARounded.frenchify()} \\times ${expBRounded.frenchify()}
121
+ $$
122
+
123
+ $$
124
+ \\exp(${texAOpBSubstituted}) \\approx ${getAnswer(identifiers)}
125
+ $$
126
+
127
+ `;
128
+ case "a-b":
129
+ return `On a :
130
+
131
+ $$
132
+ \\exp(${texAOpBSubstituted}) = \\exp(${texA} - ${texBPretty})
133
+ $$
134
+
135
+ Ainsi :
136
+
137
+ $$
138
+ \\exp(${texAOpBSubstituted}) = \\frac{\\exp(${texA})}{\\exp(${texB})}
139
+ $$
140
+
141
+ $$
142
+ \\exp(${texAOpBSubstituted}) \\approx \\frac{${expARounded.frenchify()}}{${expBRounded.frenchify()}}
143
+ $$
144
+
145
+ $$
146
+ \\exp(${texAOpBSubstituted}) \\approx ${getAnswer(identifiers)}
147
+ $$
148
+
149
+ `;
150
+ default:
151
+ throw new Error("Unsupported texAOpB: " + texAOpB);
152
+ }
153
+ };
154
+ const getPropositions = (n, { answer, ...identifiers }) => {
155
+ const { nodeIdsA, nodeIdsB, expARounded, expBRounded, precision } = identifiers;
156
+ const [nodeA, nodeB] = [nodeIdsA, nodeIdsB].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
157
+ const propositions = [];
158
+ addValidProp(propositions, answer);
159
+ //exp(a)+exp(b)
160
+ {
161
+ const nodeWrong = round(add(expARounded, expBRounded).evaluate(), precision).toTree();
162
+ tryToAddWrongProp(propositions, nodeWrong.toTex());
163
+ }
164
+ //exp(a)-exp(b)
165
+ {
166
+ const nodeWrong = round(substract(expARounded, expBRounded).evaluate(), precision).toTree();
167
+ tryToAddWrongProp(propositions, nodeWrong.toTex());
168
+ }
169
+ //exp(a)^exp(b)
170
+ {
171
+ const nodeWrong = round(power(expARounded, expBRounded).evaluate(), precision).toTree();
172
+ const tex = nodeWrong.toTex();
173
+ if (tex !== "NaN") {
174
+ tryToAddWrongProp(propositions, tex);
175
+ }
176
+ }
177
+ //terror: student uses exp(a) and exp(b) instead of given approx values
178
+ {
179
+ const arrNode = [
180
+ round(add(exp(nodeA), exp(nodeB)).evaluate(), precision).toTree(),
181
+ round(substract(exp(nodeA), exp(nodeB)).evaluate(), precision).toTree(),
182
+ round(power(exp(nodeA), exp(nodeB)).evaluate(), precision).toTree(),
183
+ ];
184
+ shuffle(arrNode).forEach((node) => {
185
+ const tex = node.toTex();
186
+ if (tex !== "NaN") {
187
+ tryToAddWrongProp(propositions, tex);
188
+ }
189
+ });
190
+ }
191
+ //filler
192
+ if (propositions.length < n) {
193
+ //exp(b)-exp(a)
194
+ {
195
+ const nodeWrong = round(substract(expBRounded, expARounded).evaluate(), precision).toTree();
196
+ const tex = nodeWrong.toTex();
197
+ if (tex !== "NaN") {
198
+ tryToAddWrongProp(propositions, tex);
199
+ }
200
+ }
201
+ //exp(a)/exp(b)
202
+ {
203
+ const nodeWrong = round(frac(expARounded, expBRounded).evaluate(), precision).toTree();
204
+ const tex = nodeWrong.toTex();
205
+ if (tex !== "NaN") {
206
+ tryToAddWrongProp(propositions, tex);
207
+ }
208
+ }
209
+ //(exp(a)+exp(b))/2
210
+ {
211
+ const nodeWrong = round(frac(add(expARounded, expBRounded), 2).evaluate(), precision).toTree();
212
+ const tex = nodeWrong.toTex();
213
+ if (tex !== "NaN") {
214
+ tryToAddWrongProp(propositions, tex);
215
+ }
216
+ }
217
+ }
218
+ return shuffleProps(propositions, n);
219
+ };
220
+ const isAnswerValid = (ans, { answer }) => {
221
+ return ans === answer;
222
+ };
223
+ const getApproxExpAPlusBQuestion = () => {
224
+ function createRandomIdentifiers() {
225
+ const precision = randint(1, 6);
226
+ const nodeA = randfloat(0, 3, 2, [0]).toTree();
227
+ const expARounded = round(exp(nodeA).evaluate(), precision);
228
+ const nodeB = random([
229
+ //-1
230
+ (-1).toTree(),
231
+ //1/2
232
+ frac(1, 2),
233
+ //int
234
+ (() => randint(2, 11).toTree())(),
235
+ ]);
236
+ const expBRounded = round(exp(nodeB).evaluate(), precision);
237
+ const nodeAOpB = parseAlgebraic(coinFlip() ? "a+b" : "a-b");
238
+ const identifiers = {
239
+ nodeIdsA: nodeA.toIdentifiers(),
240
+ nodeIdsB: nodeB.toIdentifiers(),
241
+ nodeIdsAOpB: nodeAOpB.toIdentifiers(),
242
+ expARounded,
243
+ expBRounded,
244
+ precision,
245
+ nodeA,
246
+ nodeB,
247
+ };
248
+ return identifiers;
249
+ }
250
+ let identifiers;
251
+ let counter = -1;
252
+ let isValid = false;
253
+ while (!isValid && counter < 100) {
254
+ counter++;
255
+ const identifiersCandidate = createRandomIdentifiers();
256
+ isValid = (() => {
257
+ const { nodeA, nodeB } = identifiersCandidate;
258
+ return multiply(nodeA, nodeB).evaluate() < 15;
259
+ })();
260
+ if (isValid) {
261
+ identifiers = identifiersCandidate;
262
+ }
263
+ }
264
+ if (!isValid) {
265
+ const identifiersDefault = {
266
+ nodeIdsA: (2).toTree().toIdentifiers(),
267
+ nodeIdsB: frac(1, 3).toIdentifiers(),
268
+ nodeIdsAOpB: parseAlgebraic("a+b").toIdentifiers(),
269
+ precision: 2,
270
+ expARounded: round(exp(2).evaluate(), 2),
271
+ expBRounded: round(exp(frac(1, 3)).evaluate(), 2),
272
+ };
273
+ identifiers = identifiersDefault;
274
+ }
275
+ return getQuestionFromIdentifiers(identifiers);
276
+ };
277
+ const getQuestionFromIdentifiers = (identifiers, opts) => {
278
+ return {
279
+ answer: getAnswer(identifiers, opts),
280
+ instruction: getInstruction(identifiers, opts),
281
+ keys: [],
282
+ answerFormat: "tex",
283
+ identifiers,
284
+ hint: getHint(identifiers, opts),
285
+ correction: getCorrection(identifiers, opts),
286
+ };
287
+ };
288
+ export const approxExpAPlusB = {
289
+ id: "approxExpAPlusB",
290
+ label: "Déterminer une valeur approchée de $\\exp⁡(a \\pm b)$ à partir de $\\exp(a)$ et $\\exp(b)$",
291
+ isSingleStep: true,
292
+ generator: (nb, opts) => getDistinctQuestions(() => getApproxExpAPlusBQuestion(opts), nb),
293
+ qcmTimer: 60,
294
+ freeTimer: 60,
295
+ getPropositions,
296
+ isAnswerValid,
297
+ subject: "Mathématiques",
298
+ getInstruction,
299
+ getHint,
300
+ getCorrection,
301
+ getAnswer,
302
+ getQuestionFromIdentifiers,
303
+ hasHintAndCorrection: true,
304
+ shouldHaveCalculator: true,
305
+ };
@@ -0,0 +1,11 @@
1
+ import { Exercise } from "../../../../../exercises/exercise.js";
2
+ import { NodeIdentifiers } from "../../../../../tree/nodes/nodeConstructor.js";
3
+ type Identifiers = {
4
+ nodeIdsA: NodeIdentifiers;
5
+ nodeIdsK: NodeIdentifiers;
6
+ expARounded: number;
7
+ precision: number;
8
+ };
9
+ export declare const approxExpKa: Exercise<Identifiers>;
10
+ export {};
11
+ //# sourceMappingURL=approxExpKa.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"approxExpKa.d.ts","sourceRoot":"","sources":["../../../../../../src/exercises/math/functions/exponential/algebraic/approxExpKa.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAaT,MAAM,6BAA6B,CAAC;AAMrC,OAAO,EAEL,eAAe,EAChB,MAAM,qCAAqC,CAAC;AAS7C,KAAK,WAAW,GAAG;IACjB,QAAQ,EAAE,eAAe,CAAC;IAC1B,QAAQ,EAAE,eAAe,CAAC;IAC1B,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAqPF,eAAO,MAAM,WAAW,EAAE,QAAQ,CAAC,WAAW,CAkB7C,CAAC"}
@@ -0,0 +1,216 @@
1
+ import { addValidProp, shuffleProps, tryToAddWrongProp, } from "../../../../../exercises/exercise.js";
2
+ import { getDistinctQuestions } from "../../../../../exercises/utils/getDistinctQuestions.js";
3
+ import { randint } from "../../../../../math/utils/random/randint.js";
4
+ import { round } from "../../../../../math/utils/round.js";
5
+ import { exp } from "../../../../../tree/nodes/functions/expNode.js";
6
+ import { NodeConstructor, } from "../../../../../tree/nodes/nodeConstructor.js";
7
+ import { add } from "../../../../../tree/nodes/operators/addNode.js";
8
+ import { frac } from "../../../../../tree/nodes/operators/fractionNode.js";
9
+ import { multiply } from "../../../../../tree/nodes/operators/multiplyNode.js";
10
+ import { power } from "../../../../../tree/nodes/operators/powerNode.js";
11
+ import { substract } from "../../../../../tree/nodes/operators/substractNode.js";
12
+ import { random } from "../../../../../utils/alea/random.js";
13
+ import { shuffle } from "../../../../../utils/alea/shuffle.js";
14
+ const getInstruction = (identifiers) => {
15
+ const { nodeIdsA, nodeIdsK, expARounded, precision } = identifiers;
16
+ const [nodeA, nodeK] = [nodeIdsA, nodeIdsK].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
17
+ const [texA, _] = [nodeA, nodeK].map((node) => node.toTex({ roundTo: 2 }));
18
+ const nodeKA = multiply(nodeK, nodeA).simplify({ fractionsToDecimal: true });
19
+ const texKA = nodeKA.toTex();
20
+ return `Sachant que :
21
+
22
+ $$
23
+ \\exp(${texA})\\approx ${expARounded.frenchify()}
24
+ $$
25
+
26
+ donner une valeur approchée de $\\exp(${texKA})$
27
+
28
+ avec $${precision}$ décimale${precision > 1 ? "s" : ""}.`;
29
+ };
30
+ const getAnswerNode = (identifiers) => {
31
+ const { nodeIdsK, expARounded, precision } = identifiers;
32
+ const [nodeK] = [nodeIdsK].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
33
+ return round(power(expARounded, nodeK).evaluate(), precision).toTree();
34
+ };
35
+ const getAnswer = (identifiers) => {
36
+ return getAnswerNode(identifiers).toTex();
37
+ };
38
+ const getHint = (identifiers) => {
39
+ const { nodeIdsA, nodeIdsK } = identifiers;
40
+ const [nodeA, nodeK] = [nodeIdsA, nodeIdsK].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
41
+ const [texA, texK] = [nodeA, nodeK].map((node) => node.toTex({ roundTo: 2 }));
42
+ return `Utilise la propriété :
43
+
44
+ $$
45
+ \\exp(${texA} \\times ${texK}) = {\\exp(${texA})}^{${texK}}
46
+ $$
47
+
48
+ `;
49
+ };
50
+ const getCorrection = (identifiers) => {
51
+ const { nodeIdsA, nodeIdsK, expARounded } = identifiers;
52
+ const [nodeA, nodeK] = [nodeIdsA, nodeIdsK].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
53
+ const [texA, texK] = [nodeA, nodeK].map((node) => node.toTex({ roundTo: 2 }));
54
+ const nodeKA = multiply(nodeK, nodeA).simplify();
55
+ const texKA = nodeKA.toTex();
56
+ return `On a :
57
+
58
+ $$
59
+ \\exp(${texKA}) = \\exp(${texA} \\times ${texK}) = {\\exp(${texA})}^{${texK}}
60
+ $$
61
+
62
+ On utilise l'approximation fournie :
63
+
64
+ $$
65
+ \\exp(${texA}) \\approx ${expARounded.frenchify()}
66
+ $$
67
+
68
+ On a donc :
69
+
70
+ $$
71
+ \\exp(${texKA}) = (\\exp(${texA}))^{${texK}} \\approx ({${expARounded.frenchify()}})^{${texK}}
72
+ $$
73
+
74
+ $$
75
+ \\exp(${texKA}) \\approx ${getAnswer(identifiers)}
76
+ $$
77
+
78
+ `;
79
+ };
80
+ const getPropositions = (n, { answer, ...identifiers }) => {
81
+ const { nodeIdsA, nodeIdsK, expARounded, precision } = identifiers;
82
+ const [nodeA, nodeK] = [nodeIdsA, nodeIdsK].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
83
+ const propositions = [];
84
+ addValidProp(propositions, answer);
85
+ //k*exp(a)
86
+ {
87
+ const nodeWrong = round(multiply(expARounded, nodeK).evaluate(), precision).toTree();
88
+ tryToAddWrongProp(propositions, nodeWrong.toTex());
89
+ }
90
+ //exp(a)^{k-1}
91
+ {
92
+ const identifiersWrong = Object.assign({}, identifiers, {
93
+ nodeIdsK: substract(nodeK, 1).toIdentifiers(),
94
+ });
95
+ const texWrong = getAnswer(identifiersWrong);
96
+ tryToAddWrongProp(propositions, texWrong);
97
+ }
98
+ //exp(a)^{k+1}
99
+ {
100
+ const identifiersWrong = Object.assign({}, identifiers, {
101
+ nodeIdsK: add(nodeK, 1).toIdentifiers(),
102
+ });
103
+ const texWrong = getAnswer(identifiersWrong);
104
+ tryToAddWrongProp(propositions, texWrong);
105
+ }
106
+ //terror: student uses exp(a) instead of given approx value
107
+ {
108
+ function getTerrorNode(identifiers) {
109
+ const { nodeIdsA, nodeIdsK, precision } = identifiers;
110
+ const [nodeA, nodeK] = [nodeIdsA, nodeIdsK].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
111
+ return round(power(exp(nodeA), nodeK).evaluate(), precision).toTree();
112
+ }
113
+ const arrNode = [
114
+ getTerrorNode(identifiers),
115
+ round(multiply(exp(nodeA), nodeK).evaluate(), precision).toTree(),
116
+ getTerrorNode(Object.assign({}, identifiers, {
117
+ nodeIdsK: substract(nodeK, 1).toIdentifiers(),
118
+ })),
119
+ getTerrorNode(Object.assign({}, identifiers, {
120
+ nodeIdsK: add(nodeK, 1).toIdentifiers(),
121
+ })),
122
+ ];
123
+ shuffle(arrNode)
124
+ .slice(0, randint(0, 3))
125
+ .forEach((node) => {
126
+ tryToAddWrongProp(propositions, node.toTex());
127
+ });
128
+ }
129
+ return shuffleProps(propositions, n);
130
+ };
131
+ const isAnswerValid = (ans, { answer }) => {
132
+ return ans === answer;
133
+ };
134
+ const getApproxExpKaQuestion = () => {
135
+ function createRandomIdentifiers() {
136
+ const dot1Pool = [...Array(30).keys()]
137
+ .map((i) => i + 1)
138
+ .map((i) => i * 0.1);
139
+ const dot25Pool = [...Array(12).keys()]
140
+ .map((i) => i + 1)
141
+ .map((i) => i * 0.25);
142
+ const nodeA = random(random([dot1Pool, dot25Pool])).toTree();
143
+ const precision = randint(1, 6);
144
+ const expARounded = round(exp(nodeA).evaluate(), precision);
145
+ const nodeK = random([
146
+ //-1
147
+ (-1).toTree(),
148
+ //1/2
149
+ frac(1, 2),
150
+ //int
151
+ (() => randint(2, 11).toTree())(),
152
+ ]);
153
+ const identifiers = {
154
+ nodeIdsA: nodeA.toIdentifiers(),
155
+ nodeIdsK: nodeK.toIdentifiers(),
156
+ expARounded,
157
+ precision,
158
+ nodeA,
159
+ nodeK,
160
+ };
161
+ return identifiers;
162
+ }
163
+ let identifiers;
164
+ let counter = -1;
165
+ let isValid = false;
166
+ while (!isValid && counter < 100) {
167
+ counter++;
168
+ const identifiersCandidate = createRandomIdentifiers();
169
+ isValid = (() => {
170
+ const { nodeA, nodeK } = identifiersCandidate;
171
+ return multiply(nodeA, nodeK).evaluate() < 15;
172
+ })();
173
+ if (isValid) {
174
+ identifiers = identifiersCandidate;
175
+ }
176
+ }
177
+ if (!isValid) {
178
+ const identifiersDefault = {
179
+ nodeIdsA: (2).toTree().toIdentifiers(),
180
+ nodeIdsK: frac(1, 2).toIdentifiers(),
181
+ precision: 2,
182
+ expARounded: round(exp(2).evaluate(), 2),
183
+ };
184
+ identifiers = identifiersDefault;
185
+ }
186
+ return getQuestionFromIdentifiers(identifiers);
187
+ };
188
+ const getQuestionFromIdentifiers = (identifiers, opts) => {
189
+ return {
190
+ answer: getAnswer(identifiers, opts),
191
+ instruction: getInstruction(identifiers, opts),
192
+ keys: [],
193
+ answerFormat: "tex",
194
+ identifiers,
195
+ hint: getHint(identifiers, opts),
196
+ correction: getCorrection(identifiers, opts),
197
+ };
198
+ };
199
+ export const approxExpKa = {
200
+ id: "approxExpKa",
201
+ label: "Déterminer une valeur approchée de $\\exp(ka)$",
202
+ isSingleStep: true,
203
+ generator: (nb, opts) => getDistinctQuestions(() => getApproxExpKaQuestion(opts), nb),
204
+ qcmTimer: 60,
205
+ freeTimer: 60,
206
+ getPropositions,
207
+ isAnswerValid,
208
+ subject: "Mathématiques",
209
+ getInstruction,
210
+ getHint,
211
+ getCorrection,
212
+ getAnswer,
213
+ getQuestionFromIdentifiers,
214
+ hasHintAndCorrection: true,
215
+ shouldHaveCalculator: true,
216
+ };
@@ -0,0 +1,9 @@
1
+ import { Exercise } from "../../../../../exercises/exercise.js";
2
+ type Identifiers = {
3
+ a: number;
4
+ exp1Rounded: number;
5
+ precision: number;
6
+ };
7
+ export declare const approxExpN: Exercise<Identifiers>;
8
+ export {};
9
+ //# sourceMappingURL=approxExpN.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"approxExpN.d.ts","sourceRoot":"","sources":["../../../../../../src/exercises/math/functions/exponential/algebraic/approxExpN.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAaT,MAAM,6BAA6B,CAAC;AASrC,KAAK,WAAW,GAAG;IACjB,CAAC,EAAE,MAAM,CAAC;IACV,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAgJF,eAAO,MAAM,UAAU,EAAE,QAAQ,CAAC,WAAW,CAkB5C,CAAC"}
@@ -0,0 +1,142 @@
1
+ import { addValidProp, shuffleProps, tryToAddWrongProp, } from "../../../../../exercises/exercise.js";
2
+ import { getDistinctQuestions } from "../../../../../exercises/utils/getDistinctQuestions.js";
3
+ import { randint } from "../../../../../math/utils/random/randint.js";
4
+ import { round } from "../../../../../math/utils/round.js";
5
+ import { exp } from "../../../../../tree/nodes/functions/expNode.js";
6
+ import { multiply } from "../../../../../tree/nodes/operators/multiplyNode.js";
7
+ import { power } from "../../../../../tree/nodes/operators/powerNode.js";
8
+ import { shuffle } from "../../../../../utils/alea/shuffle.js";
9
+ const getInstruction = (identifiers) => {
10
+ const { a, exp1Rounded, precision } = identifiers;
11
+ return `Sachant que :
12
+
13
+ $$
14
+ \\exp(1)\\approx ${exp1Rounded.frenchify()}
15
+ $$
16
+
17
+ donner une valeur approchée de $\\exp(${a.frenchify()})$
18
+
19
+ avec $${precision}$ décimale${precision > 1 ? "s" : ""}.`;
20
+ };
21
+ const getAnswerNode = (identifiers) => {
22
+ const { a, exp1Rounded, precision } = identifiers;
23
+ return round(power(exp1Rounded, a).evaluate(), precision).toTree();
24
+ };
25
+ const getAnswer = (identifiers) => {
26
+ return getAnswerNode(identifiers).toTex();
27
+ };
28
+ const getHint = () => {
29
+ return `Utilise la propriété :
30
+
31
+ $$
32
+ e = e^${1} = \\exp(1)
33
+ $$
34
+
35
+ `;
36
+ };
37
+ const getCorrection = (identifiers) => {
38
+ const { a, exp1Rounded } = identifiers;
39
+ return `On a :
40
+
41
+ $$
42
+ \\exp(${a}) = e^${a} = {\\exp(1)}^${a}
43
+ $$
44
+
45
+ On utilise l'approximation fournie :
46
+
47
+ $$
48
+ e = \\exp(1) \\approx ${exp1Rounded.frenchify()}
49
+ $$
50
+
51
+ On a donc :
52
+
53
+ $$
54
+ \\exp(${a}) = e^${a} \\approx {${exp1Rounded.frenchify()}}^${a}
55
+ $$
56
+
57
+ $$
58
+ e^${a} \\approx ${getAnswer(identifiers)}
59
+ $$
60
+
61
+ `;
62
+ };
63
+ const getPropositions = (n, { answer, ...identifiers }) => {
64
+ const { a, exp1Rounded, precision } = identifiers;
65
+ const propositions = [];
66
+ addValidProp(propositions, answer);
67
+ //a*exp(1)
68
+ {
69
+ const nodeWrong = round(multiply(exp1Rounded, a).evaluate(), precision).toTree();
70
+ tryToAddWrongProp(propositions, nodeWrong.toTex());
71
+ }
72
+ //exp(a-1)
73
+ {
74
+ const identifiersWrong = Object.assign({}, identifiers, { a: a - 1 });
75
+ const texWrong = getAnswer(identifiersWrong);
76
+ tryToAddWrongProp(propositions, texWrong);
77
+ }
78
+ //exp(a+1)
79
+ {
80
+ const identifiersWrong = Object.assign({}, identifiers, { a: a + 1 });
81
+ const texWrong = getAnswer(identifiersWrong);
82
+ tryToAddWrongProp(propositions, texWrong);
83
+ }
84
+ //terror: student uses exp(1) instead of given approx value
85
+ {
86
+ function getTerrorNode(identifiers) {
87
+ const { a, precision } = identifiers;
88
+ return round(power(exp(1), a).evaluate(), precision).toTree();
89
+ }
90
+ const arrNode = [
91
+ getTerrorNode(identifiers),
92
+ round(multiply(exp(1), a).evaluate(), precision).toTree(),
93
+ getTerrorNode(Object.assign({}, identifiers, { a: a - 1 })),
94
+ getTerrorNode(Object.assign({}, identifiers, { a: a + 1 })),
95
+ ];
96
+ shuffle(arrNode)
97
+ .slice(0, randint(0, 3))
98
+ .forEach((node) => {
99
+ tryToAddWrongProp(propositions, node.toTex());
100
+ });
101
+ }
102
+ return shuffleProps(propositions, n);
103
+ };
104
+ const isAnswerValid = (ans, { answer }) => {
105
+ return ans === answer;
106
+ };
107
+ const getApproxExpNQuestion = () => {
108
+ const a = randint(2, 15);
109
+ const precision = randint(1, 6);
110
+ const exp1Rounded = round(exp(1).evaluate(), precision);
111
+ const identifiers = { a, exp1Rounded, precision };
112
+ return getQuestionFromIdentifiers(identifiers);
113
+ };
114
+ const getQuestionFromIdentifiers = (identifiers, opts) => {
115
+ return {
116
+ answer: getAnswer(identifiers, opts),
117
+ instruction: getInstruction(identifiers, opts),
118
+ keys: [],
119
+ answerFormat: "tex",
120
+ identifiers,
121
+ hint: getHint(identifiers, opts),
122
+ correction: getCorrection(identifiers, opts),
123
+ };
124
+ };
125
+ export const approxExpN = {
126
+ id: "approxExpN",
127
+ label: "Déterminer une valeur approchée de $\\exp(n)$",
128
+ isSingleStep: true,
129
+ generator: (nb, opts) => getDistinctQuestions(() => getApproxExpNQuestion(opts), nb),
130
+ qcmTimer: 60,
131
+ freeTimer: 60,
132
+ getPropositions,
133
+ isAnswerValid,
134
+ subject: "Mathématiques",
135
+ getInstruction,
136
+ getHint,
137
+ getCorrection,
138
+ getAnswer,
139
+ getQuestionFromIdentifiers,
140
+ hasHintAndCorrection: true,
141
+ shouldHaveCalculator: true,
142
+ };