math-exercises 3.0.157 → 3.0.158

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 (260) 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 +444 -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 +292 -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/inequations/exp/expOfFEqualsExpOfGInequation.d.ts +18 -0
  16. package/lib/exercises/math/calculLitteral/inequations/exp/expOfFEqualsExpOfGInequation.d.ts.map +1 -0
  17. package/lib/exercises/math/calculLitteral/inequations/exp/expOfFEqualsExpOfGInequation.js +437 -0
  18. package/lib/exercises/math/calculLitteral/inequations/exp/index.d.ts +2 -0
  19. package/lib/exercises/math/calculLitteral/inequations/exp/index.d.ts.map +1 -0
  20. package/lib/exercises/math/calculLitteral/inequations/exp/index.js +1 -0
  21. package/lib/exercises/math/derivation/derivative/exp/expDerivativeOne.d.ts.map +1 -1
  22. package/lib/exercises/math/derivation/derivative/exp/expDerivativeOne.js +29 -0
  23. package/lib/exercises/math/derivation/derivative/exp/expDerivativeThree.d.ts.map +1 -1
  24. package/lib/exercises/math/derivation/derivative/exp/expDerivativeThree.js +35 -2
  25. package/lib/exercises/math/derivation/derivative/exp/expDerivativeTwo.d.ts.map +1 -1
  26. package/lib/exercises/math/derivation/derivative/exp/expDerivativeTwo.js +19 -0
  27. package/lib/exercises/math/derivation/derivative/exp/expOverExpDerivative.d.ts +10 -0
  28. package/lib/exercises/math/derivation/derivative/exp/expOverExpDerivative.d.ts.map +1 -0
  29. package/lib/exercises/math/derivation/derivative/exp/expOverExpDerivative.js +282 -0
  30. package/lib/exercises/math/derivation/derivative/inverseFunctionDerivative.d.ts.map +1 -1
  31. package/lib/exercises/math/derivation/derivative/inverseFunctionDerivative.js +30 -2
  32. package/lib/exercises/math/derivation/derivative/productDerivative.d.ts.map +1 -1
  33. package/lib/exercises/math/derivation/derivative/productDerivative.js +68 -1
  34. package/lib/exercises/math/derivation/derivative/quotientDerivative.d.ts.map +1 -1
  35. package/lib/exercises/math/derivation/derivative/quotientDerivative.js +40 -4
  36. package/lib/exercises/math/derivation/derivative/sqrt/sqrtCompositionDerivation.d.ts.map +1 -1
  37. package/lib/exercises/math/derivation/derivative/sqrt/sqrtCompositionDerivation.js +30 -3
  38. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeAlgebraicExpression.d.ts +12 -0
  39. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeAlgebraicExpression.d.ts.map +1 -0
  40. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeAlgebraicExpression.js +127 -0
  41. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeFromAlgebraic.d.ts +13 -0
  42. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeFromAlgebraic.d.ts.map +1 -0
  43. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeFromAlgebraic.js +161 -0
  44. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeFromImages.d.ts +11 -0
  45. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeFromImages.d.ts.map +1 -0
  46. package/lib/exercises/math/derivation/derivativeNumber/averageRateOfChangeFromImages.js +116 -0
  47. package/lib/exercises/math/derivation/derivativeNumber/derivativeNumberCalcul.d.ts +8 -0
  48. package/lib/exercises/math/derivation/derivativeNumber/derivativeNumberCalcul.d.ts.map +1 -0
  49. package/lib/exercises/math/derivation/derivativeNumber/derivativeNumberCalcul.js +142 -0
  50. package/lib/exercises/math/derivation/derivativeNumber/index.d.ts +4 -0
  51. package/lib/exercises/math/derivation/derivativeNumber/index.d.ts.map +1 -0
  52. package/lib/exercises/math/derivation/derivativeNumber/index.js +4 -0
  53. package/lib/exercises/math/derivation/index.d.ts +1 -1
  54. package/lib/exercises/math/derivation/index.js +1 -1
  55. package/lib/exercises/math/functions/exponential/algebraic/approxExpAPlusB.d.ts +13 -0
  56. package/lib/exercises/math/functions/exponential/algebraic/approxExpAPlusB.d.ts.map +1 -0
  57. package/lib/exercises/math/functions/exponential/algebraic/approxExpAPlusB.js +278 -0
  58. package/lib/exercises/math/functions/exponential/algebraic/approxExpKa.d.ts +11 -0
  59. package/lib/exercises/math/functions/exponential/algebraic/approxExpKa.d.ts.map +1 -0
  60. package/lib/exercises/math/functions/exponential/algebraic/approxExpKa.js +211 -0
  61. package/lib/exercises/math/functions/exponential/algebraic/approxExpN.d.ts +9 -0
  62. package/lib/exercises/math/functions/exponential/algebraic/approxExpN.d.ts.map +1 -0
  63. package/lib/exercises/math/functions/exponential/algebraic/approxExpN.js +142 -0
  64. package/lib/exercises/math/functions/exponential/algebraic/index.d.ts +5 -0
  65. package/lib/exercises/math/functions/exponential/algebraic/index.d.ts.map +1 -0
  66. package/lib/exercises/math/functions/exponential/algebraic/index.js +4 -0
  67. package/lib/exercises/math/functions/exponential/algebraic/rewriteExpUsingExpA.d.ts +14 -0
  68. package/lib/exercises/math/functions/exponential/algebraic/rewriteExpUsingExpA.d.ts.map +1 -0
  69. package/lib/exercises/math/functions/exponential/algebraic/rewriteExpUsingExpA.js +337 -0
  70. package/lib/exercises/math/functions/exponential/definition/approxExpAPlusH.d.ts +11 -0
  71. package/lib/exercises/math/functions/exponential/definition/approxExpAPlusH.d.ts.map +1 -0
  72. package/lib/exercises/math/functions/exponential/definition/approxExpAPlusH.js +234 -0
  73. package/lib/exercises/math/functions/exponential/definition/expAntecedentFromGraph.d.ts +9 -0
  74. package/lib/exercises/math/functions/exponential/definition/expAntecedentFromGraph.d.ts.map +1 -0
  75. package/lib/exercises/math/functions/exponential/definition/expAntecedentFromGraph.js +190 -0
  76. package/lib/exercises/math/functions/exponential/definition/expImageFromGraph.d.ts +9 -0
  77. package/lib/exercises/math/functions/exponential/definition/expImageFromGraph.d.ts.map +1 -0
  78. package/lib/exercises/math/functions/exponential/definition/expImageFromGraph.js +190 -0
  79. package/lib/exercises/math/functions/exponential/definition/index.d.ts +5 -0
  80. package/lib/exercises/math/functions/exponential/definition/index.d.ts.map +1 -0
  81. package/lib/exercises/math/functions/exponential/definition/index.js +4 -0
  82. package/lib/exercises/math/functions/exponential/definition/isPlausibleExpFromGraph.d.ts +13 -0
  83. package/lib/exercises/math/functions/exponential/definition/isPlausibleExpFromGraph.d.ts.map +1 -0
  84. package/lib/exercises/math/functions/exponential/definition/isPlausibleExpFromGraph.js +375 -0
  85. package/lib/exercises/math/functions/trinoms/devForm/coefficientsIdentification.d.ts.map +1 -1
  86. package/lib/exercises/math/functions/trinoms/devForm/coefficientsIdentification.js +30 -3
  87. package/lib/exercises/math/functions/trinoms/equation/deltaTrinom.d.ts.map +1 -1
  88. package/lib/exercises/math/functions/trinoms/equation/deltaTrinom.js +35 -1
  89. package/lib/exercises/math/functions/trinoms/parabole/paraboleExpressionReading.d.ts.map +1 -1
  90. package/lib/exercises/math/functions/trinoms/parabole/paraboleExpressionReading.js +1 -1
  91. package/lib/exercises/math/functions/trinoms/summitAndCanonical/alphaBetaInCanonicalForm.d.ts.map +1 -1
  92. package/lib/exercises/math/functions/trinoms/summitAndCanonical/alphaBetaInCanonicalForm.js +23 -1
  93. package/lib/exercises/math/functions/trinoms/summitAndCanonical/extremumFromCanonicalForm.d.ts.map +1 -1
  94. package/lib/exercises/math/functions/trinoms/summitAndCanonical/extremumFromCanonicalForm.js +29 -0
  95. package/lib/exercises/math/functions/variations/exp/index.d.ts +3 -0
  96. package/lib/exercises/math/functions/variations/exp/index.d.ts.map +1 -0
  97. package/lib/exercises/math/functions/variations/exp/index.js +2 -0
  98. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusB.d.ts +9 -0
  99. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusB.d.ts.map +1 -0
  100. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusB.js +101 -0
  101. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusBOverCEXPlusD.d.ts +11 -0
  102. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusBOverCEXPlusD.d.ts.map +1 -0
  103. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusBOverCEXPlusD.js +192 -0
  104. package/lib/exercises/math/geometry/euclidian/pinPointFromAxialOrCentralSymmetry.js +2 -2
  105. package/lib/exercises/math/geometry/thales/thales.js +1 -1
  106. package/lib/exercises/math/geometry/thales/thalesCalcul.js +1 -1
  107. package/lib/exercises/math/geometry/vectors/colinearity/determinant.js +1 -1
  108. package/lib/exercises/math/geometry/vectors/scalarProduct/angleFromScalarProduct.js +1 -1
  109. package/lib/exercises/math/geometry/vectors/scalarProduct/findCoordinatesToOrthogonalize.d.ts.map +1 -1
  110. package/lib/exercises/math/geometry/vectors/scalarProduct/findCoordinatesToOrthogonalize.js +33 -7
  111. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductViaCoords.js +1 -1
  112. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductViaCos.d.ts.map +1 -1
  113. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductViaCos.js +38 -1
  114. package/lib/exercises/math/probaStat/conditionalProbability.d.ts +4 -1
  115. package/lib/exercises/math/probaStat/conditionalProbability.d.ts.map +1 -1
  116. package/lib/exercises/math/probaStat/conditionalProbability.js +38 -5
  117. package/lib/exercises/math/probaStat/independancy/independancy.d.ts +9 -0
  118. package/lib/exercises/math/probaStat/independancy/independancy.d.ts.map +1 -0
  119. package/lib/exercises/math/probaStat/independancy/independancy.js +114 -0
  120. package/lib/exercises/math/probaStat/independancy/independancyFindCap.d.ts +9 -0
  121. package/lib/exercises/math/probaStat/independancy/independancyFindCap.d.ts.map +1 -0
  122. package/lib/exercises/math/probaStat/independancy/independancyFindCap.js +101 -0
  123. package/lib/exercises/math/probaStat/independancy/independancyFindCup.d.ts +9 -0
  124. package/lib/exercises/math/probaStat/independancy/independancyFindCup.d.ts.map +1 -0
  125. package/lib/exercises/math/probaStat/independancy/independancyFindCup.js +118 -0
  126. package/lib/exercises/math/probaStat/independancy/index.d.ts +5 -0
  127. package/lib/exercises/math/probaStat/independancy/index.d.ts.map +1 -0
  128. package/lib/exercises/math/probaStat/independancy/index.js +4 -0
  129. package/lib/exercises/math/probaStat/independancy/isIndependantFromDefinition.d.ts +10 -0
  130. package/lib/exercises/math/probaStat/independancy/isIndependantFromDefinition.d.ts.map +1 -0
  131. package/lib/exercises/math/probaStat/independancy/isIndependantFromDefinition.js +106 -0
  132. package/lib/exercises/math/probaStat/index.d.ts +1 -1
  133. package/lib/exercises/math/probaStat/index.d.ts.map +1 -1
  134. package/lib/exercises/math/probaStat/index.js +1 -1
  135. package/lib/exercises/math/probaStat/randomVariable/randomVariableStandardDeviation.js +1 -1
  136. package/lib/exercises/math/probaStat/twoStepExperiments/headsOrTailsTwiceOutcomes.d.ts.map +1 -1
  137. package/lib/exercises/math/probaStat/twoStepExperiments/headsOrTailsTwiceOutcomes.js +7 -0
  138. package/lib/exercises/math/probaStat/twoStepExperiments/headsOrTailsTwiceProbas.d.ts.map +1 -1
  139. package/lib/exercises/math/probaStat/twoStepExperiments/headsOrTailsTwiceProbas.js +7 -0
  140. package/lib/exercises/math/probaStat/twoStepExperiments/numberPoolTwiceProbas.d.ts.map +1 -1
  141. package/lib/exercises/math/probaStat/twoStepExperiments/numberPoolTwiceProbas.js +7 -0
  142. package/lib/exercises/math/probaStat/twoStepExperiments/twoStepExperimentProbas.d.ts.map +1 -1
  143. package/lib/exercises/math/probaStat/twoStepExperiments/twoStepExperimentProbas.js +7 -0
  144. package/lib/exercises/math/sequences/arithmetic/arithmeticFindExplicitFormulaFirstTermRandom.d.ts +9 -0
  145. package/lib/exercises/math/sequences/arithmetic/arithmeticFindExplicitFormulaFirstTermRandom.d.ts.map +1 -0
  146. package/lib/exercises/math/sequences/arithmetic/arithmeticFindExplicitFormulaFirstTermRandom.js +118 -0
  147. package/lib/exercises/math/sequences/arithmetic/arithmeticFindRandomTermFromTwoTerms.d.ts.map +1 -1
  148. package/lib/exercises/math/sequences/arithmetic/arithmeticFindRandomTermFromTwoTerms.js +55 -6
  149. package/lib/exercises/math/sequences/arithmetic/arithmeticFindReasonRandomRange.d.ts.map +1 -1
  150. package/lib/exercises/math/sequences/arithmetic/arithmeticFindReasonRandomRange.js +42 -1
  151. package/lib/exercises/math/sequences/arithmetic/arithmeticFirstTermsSum.d.ts +4 -1
  152. package/lib/exercises/math/sequences/arithmetic/arithmeticFirstTermsSum.d.ts.map +1 -1
  153. package/lib/exercises/math/sequences/arithmetic/arithmeticFirstTermsSum.js +57 -7
  154. package/lib/exercises/math/sequences/arithmetic/arithmeticRecurrenceFormulaUsage.d.ts.map +1 -1
  155. package/lib/exercises/math/sequences/arithmetic/arithmeticRecurrenceFormulaUsage.js +24 -2
  156. package/lib/exercises/math/sequences/arithmetic/arithmeticThresholdFind.d.ts.map +1 -1
  157. package/lib/exercises/math/sequences/arithmetic/arithmeticThresholdFind.js +31 -8
  158. package/lib/exercises/math/sequences/arithmetic/index.d.ts +1 -1
  159. package/lib/exercises/math/sequences/arithmetic/index.d.ts.map +1 -1
  160. package/lib/exercises/math/sequences/arithmetic/index.js +1 -1
  161. package/lib/exercises/math/sequences/arithmetic/recognizeArithmeticFromGraph.d.ts.map +1 -1
  162. package/lib/exercises/math/sequences/arithmetic/recognizeArithmeticFromGraph.js +11 -1
  163. package/lib/exercises/math/sequences/geometric/geometricFindExplicitFormulaFirstRankOne.js +5 -5
  164. package/lib/exercises/math/sequences/geometric/geometricFindExplicitFormulaFirstTermRandom.d.ts.map +1 -1
  165. package/lib/exercises/math/sequences/geometric/geometricFindExplicitFormulaFirstTermRandom.js +3 -1
  166. package/lib/exercises/math/sequences/geometric/geometricFindReason.d.ts.map +1 -1
  167. package/lib/exercises/math/sequences/geometric/geometricFindReason.js +41 -2
  168. package/lib/exercises/math/sequences/geometric/geometricRecurrenceFormulaUsage.d.ts.map +1 -1
  169. package/lib/exercises/math/sequences/geometric/geometricRecurrenceFormulaUsage.js +28 -2
  170. package/lib/exercises/math/sequences/sequenceEvaluation.d.ts.map +1 -1
  171. package/lib/exercises/math/sequences/sequenceEvaluation.js +22 -2
  172. package/lib/exercises/math/trigonometry/circle/areReelsOnTheSameTrigoCirclePoint.d.ts +9 -0
  173. package/lib/exercises/math/trigonometry/circle/areReelsOnTheSameTrigoCirclePoint.d.ts.map +1 -0
  174. package/lib/exercises/math/trigonometry/circle/areReelsOnTheSameTrigoCirclePoint.js +107 -0
  175. package/lib/exercises/math/trigonometry/circle/associatePoint.d.ts +10 -0
  176. package/lib/exercises/math/trigonometry/circle/associatePoint.d.ts.map +1 -0
  177. package/lib/exercises/math/trigonometry/circle/associatePoint.js +86 -0
  178. package/lib/exercises/math/trigonometry/circle/associateReelToTrigoCirclePoint.d.ts +10 -0
  179. package/lib/exercises/math/trigonometry/circle/associateReelToTrigoCirclePoint.d.ts.map +1 -0
  180. package/lib/exercises/math/trigonometry/circle/associateReelToTrigoCirclePoint.js +205 -0
  181. package/lib/exercises/math/trigonometry/circle/findAngleFromCosAndSin.d.ts +7 -0
  182. package/lib/exercises/math/trigonometry/circle/findAngleFromCosAndSin.d.ts.map +1 -0
  183. package/lib/exercises/math/trigonometry/circle/findAngleFromCosAndSin.js +121 -0
  184. package/lib/exercises/math/trigonometry/circle/index.d.ts +7 -0
  185. package/lib/exercises/math/trigonometry/circle/index.d.ts.map +1 -0
  186. package/lib/exercises/math/trigonometry/circle/index.js +7 -0
  187. package/lib/exercises/math/trigonometry/circle/mainAngleMeasure.d.ts +10 -0
  188. package/lib/exercises/math/trigonometry/circle/mainAngleMeasure.d.ts.map +1 -0
  189. package/lib/exercises/math/trigonometry/circle/mainAngleMeasure.js +100 -0
  190. package/lib/exercises/math/trigonometry/circle/mainRemarkableValues.d.ts +8 -0
  191. package/lib/exercises/math/trigonometry/circle/mainRemarkableValues.d.ts.map +1 -0
  192. package/lib/exercises/math/trigonometry/circle/mainRemarkableValues.js +97 -0
  193. package/lib/exercises/math/trigonometry/circle/remarkableValues.d.ts +10 -0
  194. package/lib/exercises/math/trigonometry/circle/remarkableValues.d.ts.map +1 -0
  195. package/lib/exercises/math/trigonometry/circle/remarkableValues.js +112 -0
  196. package/lib/exercises/math/trigonometry/functions/basicEquationCos.d.ts +7 -0
  197. package/lib/exercises/math/trigonometry/functions/basicEquationCos.d.ts.map +1 -0
  198. package/lib/exercises/math/trigonometry/functions/basicEquationCos.js +92 -0
  199. package/lib/exercises/math/trigonometry/functions/basicEquationSin.d.ts +7 -0
  200. package/lib/exercises/math/trigonometry/functions/basicEquationSin.d.ts.map +1 -0
  201. package/lib/exercises/math/trigonometry/functions/basicEquationSin.js +104 -0
  202. package/lib/exercises/math/trigonometry/functions/basicTrigoSystemEquation.d.ts +7 -0
  203. package/lib/exercises/math/trigonometry/functions/basicTrigoSystemEquation.d.ts.map +1 -0
  204. package/lib/exercises/math/trigonometry/functions/basicTrigoSystemEquation.js +83 -0
  205. package/lib/exercises/math/trigonometry/functions/equationCosOnRandomInterval.d.ts +8 -0
  206. package/lib/exercises/math/trigonometry/functions/equationCosOnRandomInterval.d.ts.map +1 -0
  207. package/lib/exercises/math/trigonometry/functions/equationCosOnRandomInterval.js +111 -0
  208. package/lib/exercises/math/trigonometry/functions/equationSinOnRandomInterval.d.ts +8 -0
  209. package/lib/exercises/math/trigonometry/functions/equationSinOnRandomInterval.d.ts.map +1 -0
  210. package/lib/exercises/math/trigonometry/functions/equationSinOnRandomInterval.js +101 -0
  211. package/lib/exercises/math/trigonometry/functions/index.d.ts +6 -0
  212. package/lib/exercises/math/trigonometry/functions/index.d.ts.map +1 -0
  213. package/lib/exercises/math/trigonometry/functions/index.js +6 -0
  214. package/lib/exercises/math/trigonometry/functions/trigoAssociateAngle.d.ts +9 -0
  215. package/lib/exercises/math/trigonometry/functions/trigoAssociateAngle.d.ts.map +1 -0
  216. package/lib/exercises/math/trigonometry/functions/trigoAssociateAngle.js +151 -0
  217. package/lib/exercises/math/trigonometry/index.d.ts +3 -14
  218. package/lib/exercises/math/trigonometry/index.d.ts.map +1 -1
  219. package/lib/exercises/math/trigonometry/index.js +3 -14
  220. package/lib/exercises/math/trigonometry/triangle/index.d.ts +7 -0
  221. package/lib/exercises/math/trigonometry/triangle/index.d.ts.map +1 -0
  222. package/lib/exercises/math/trigonometry/triangle/index.js +6 -0
  223. package/lib/exercises/math/trigonometry/triangle/trigonometry.d.ts +10 -0
  224. package/lib/exercises/math/trigonometry/triangle/trigonometry.d.ts.map +1 -0
  225. package/lib/exercises/math/trigonometry/triangle/trigonometry.js +207 -0
  226. package/lib/exercises/math/trigonometry/triangle/trigonometryAngleCalcul.d.ts +10 -0
  227. package/lib/exercises/math/trigonometry/triangle/trigonometryAngleCalcul.d.ts.map +1 -0
  228. package/lib/exercises/math/trigonometry/triangle/trigonometryAngleCalcul.js +174 -0
  229. package/lib/exercises/math/trigonometry/triangle/trigonometrySideCalcul.d.ts +11 -0
  230. package/lib/exercises/math/trigonometry/triangle/trigonometrySideCalcul.d.ts.map +1 -0
  231. package/lib/exercises/math/trigonometry/triangle/trigonometrySideCalcul.js +224 -0
  232. package/lib/exercises/math/trigonometry/triangle/trigonometrySideName.d.ts +13 -0
  233. package/lib/exercises/math/trigonometry/triangle/trigonometrySideName.d.ts.map +1 -0
  234. package/lib/exercises/math/trigonometry/triangle/trigonometrySideName.js +189 -0
  235. package/lib/exercises/math/trigonometry/triangle/trigonometrySohcahtoaCalcul.d.ts +13 -0
  236. package/lib/exercises/math/trigonometry/triangle/trigonometrySohcahtoaCalcul.d.ts.map +1 -0
  237. package/lib/exercises/math/trigonometry/triangle/trigonometrySohcahtoaCalcul.js +290 -0
  238. package/lib/exercises/math/trigonometry/triangle/trigonometrySohcahtoaUse.d.ts +18 -0
  239. package/lib/exercises/math/trigonometry/triangle/trigonometrySohcahtoaUse.d.ts.map +1 -0
  240. package/lib/exercises/math/trigonometry/triangle/trigonometrySohcahtoaUse.js +386 -0
  241. package/lib/exercises/pc/mathExosInPC.d.ts +2 -2
  242. package/lib/exercises/pc/mathExosInPC.d.ts.map +1 -1
  243. package/lib/exercises/pc/mathExosInPC.js +2 -2
  244. package/lib/index.d.ts +63 -27
  245. package/lib/index.d.ts.map +1 -1
  246. package/lib/math/geometry/segment.d.ts +1 -1
  247. package/lib/math/geometry/vector.d.ts +2 -1
  248. package/lib/math/geometry/vector.d.ts.map +1 -1
  249. package/lib/math/geometry/vector.js +1 -1
  250. package/lib/math/numbers/reals/real.d.ts.map +1 -1
  251. package/lib/math/numbers/reals/real.js +2 -0
  252. package/lib/playground.d.ts.map +1 -1
  253. package/lib/playground.js +3 -1
  254. package/lib/tree/nodes/algebraicNode.d.ts +1 -0
  255. package/lib/tree/nodes/algebraicNode.d.ts.map +1 -1
  256. package/lib/tree/nodes/functions/sqrtNode.d.ts +2 -1
  257. package/lib/tree/nodes/functions/sqrtNode.d.ts.map +1 -1
  258. package/lib/tree/nodes/functions/sqrtNode.js +17 -6
  259. package/lib/tree/nodes/operators/multiplyNode.js +1 -1
  260. package/package.json +1 -1
@@ -0,0 +1,278 @@
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
+ return shuffleProps(propositions, n);
192
+ };
193
+ const isAnswerValid = (ans, { answer }) => {
194
+ return ans === answer;
195
+ };
196
+ const getApproxExpAPlusBQuestion = () => {
197
+ function createRandomIdentifiers() {
198
+ const precision = randint(1, 6);
199
+ const nodeA = randfloat(0, 3, 2, [0]).toTree();
200
+ const expARounded = round(exp(nodeA).evaluate(), precision);
201
+ const nodeB = random([
202
+ //-1
203
+ (-1).toTree(),
204
+ //1/2
205
+ frac(1, 2),
206
+ //int
207
+ (() => randint(2, 11).toTree())(),
208
+ ]);
209
+ const expBRounded = round(exp(nodeB).evaluate(), precision);
210
+ const nodeAOpB = parseAlgebraic(coinFlip() ? "a+b" : "a-b");
211
+ const identifiers = {
212
+ nodeIdsA: nodeA.toIdentifiers(),
213
+ nodeIdsB: nodeB.toIdentifiers(),
214
+ nodeIdsAOpB: nodeAOpB.toIdentifiers(),
215
+ expARounded,
216
+ expBRounded,
217
+ precision,
218
+ nodeA,
219
+ nodeB,
220
+ };
221
+ return identifiers;
222
+ }
223
+ let identifiers;
224
+ let counter = -1;
225
+ let isValid = false;
226
+ while (!isValid && counter < 100) {
227
+ counter++;
228
+ const identifiersCandidate = createRandomIdentifiers();
229
+ isValid = (() => {
230
+ const { nodeA, nodeB } = identifiersCandidate;
231
+ return multiply(nodeA, nodeB).evaluate() < 15;
232
+ })();
233
+ if (isValid) {
234
+ identifiers = identifiersCandidate;
235
+ }
236
+ }
237
+ if (!isValid) {
238
+ const identifiersDefault = {
239
+ nodeIdsA: (2).toTree().toIdentifiers(),
240
+ nodeIdsB: frac(1, 3).toIdentifiers(),
241
+ nodeIdsAOpB: parseAlgebraic("a+b").toIdentifiers(),
242
+ precision: 2,
243
+ expARounded: round(exp(2).evaluate(), 2),
244
+ expBRounded: round(exp(frac(1, 3)).evaluate(), 2),
245
+ };
246
+ identifiers = identifiersDefault;
247
+ }
248
+ return getQuestionFromIdentifiers(identifiers);
249
+ };
250
+ const getQuestionFromIdentifiers = (identifiers, opts) => {
251
+ return {
252
+ answer: getAnswer(identifiers, opts),
253
+ instruction: getInstruction(identifiers, opts),
254
+ keys: [],
255
+ answerFormat: "tex",
256
+ identifiers,
257
+ hint: getHint(identifiers, opts),
258
+ correction: getCorrection(identifiers, opts),
259
+ };
260
+ };
261
+ export const approxExpAPlusB = {
262
+ id: "approxExpAPlusB",
263
+ label: "Déterminer une valeur approchée de $\\exp(a+b)$ ou de $\\exp(a-b)$",
264
+ isSingleStep: true,
265
+ generator: (nb, opts) => getDistinctQuestions(() => getApproxExpAPlusBQuestion(opts), nb),
266
+ qcmTimer: 60,
267
+ freeTimer: 60,
268
+ getPropositions,
269
+ isAnswerValid,
270
+ subject: "Mathématiques",
271
+ getInstruction,
272
+ getHint,
273
+ getCorrection,
274
+ getAnswer,
275
+ getQuestionFromIdentifiers,
276
+ hasHintAndCorrection: true,
277
+ shouldHaveCalculator: true,
278
+ };
@@ -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;AAOrC,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;AA+OF,eAAO,MAAM,WAAW,EAAE,QAAQ,CAAC,WAAW,CAkB7C,CAAC"}
@@ -0,0 +1,211 @@
1
+ import { addValidProp, shuffleProps, tryToAddWrongProp, } from "../../../../../exercises/exercise.js";
2
+ import { getDistinctQuestions } from "../../../../../exercises/utils/getDistinctQuestions.js";
3
+ import { randfloat } from "../../../../../math/utils/random/randfloat.js";
4
+ import { randint } from "../../../../../math/utils/random/randint.js";
5
+ import { round } from "../../../../../math/utils/round.js";
6
+ import { exp } from "../../../../../tree/nodes/functions/expNode.js";
7
+ import { NodeConstructor, } from "../../../../../tree/nodes/nodeConstructor.js";
8
+ import { add } from "../../../../../tree/nodes/operators/addNode.js";
9
+ import { frac } from "../../../../../tree/nodes/operators/fractionNode.js";
10
+ import { multiply } from "../../../../../tree/nodes/operators/multiplyNode.js";
11
+ import { power } from "../../../../../tree/nodes/operators/powerNode.js";
12
+ import { substract } from "../../../../../tree/nodes/operators/substractNode.js";
13
+ import { random } from "../../../../../utils/alea/random.js";
14
+ import { shuffle } from "../../../../../utils/alea/shuffle.js";
15
+ const getInstruction = (identifiers) => {
16
+ const { nodeIdsA, nodeIdsK, expARounded, precision } = identifiers;
17
+ const [nodeA, nodeK] = [nodeIdsA, nodeIdsK].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
18
+ const [texA, _] = [nodeA, nodeK].map((node) => node.toTex());
19
+ const nodeKA = multiply(nodeK, nodeA).simplify({ fractionsToDecimal: true });
20
+ const texKA = nodeKA.toTex();
21
+ return `Sachant que :
22
+
23
+ $$
24
+ \\exp(${texA})\\approx${expARounded.frenchify()}
25
+ $$
26
+
27
+ donner une valeur approchée de $\\exp(${texKA})$
28
+
29
+ avec $${precision}$ décimale${precision > 1 ? "s" : ""}.`;
30
+ };
31
+ const getAnswerNode = (identifiers) => {
32
+ const { nodeIdsK, expARounded, precision } = identifiers;
33
+ const [nodeK] = [nodeIdsK].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
34
+ return round(power(expARounded, nodeK).evaluate(), precision).toTree();
35
+ };
36
+ const getAnswer = (identifiers) => {
37
+ return getAnswerNode(identifiers).toTex();
38
+ };
39
+ const getHint = (identifiers) => {
40
+ const { nodeIdsA, nodeIdsK } = identifiers;
41
+ const [nodeA, nodeK] = [nodeIdsA, nodeIdsK].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
42
+ const [texA, texK] = [nodeA, nodeK].map((node) => node.toTex());
43
+ return `Utilise la propriété :
44
+
45
+ $$
46
+ \\exp(${texA} \\times ${texK}) = {\\exp(${texA})}^{${texK}}
47
+ $$
48
+
49
+ `;
50
+ };
51
+ const getCorrection = (identifiers) => {
52
+ const { nodeIdsA, nodeIdsK, expARounded } = identifiers;
53
+ const [nodeA, nodeK] = [nodeIdsA, nodeIdsK].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
54
+ const [texA, texK] = [nodeA, nodeK].map((node) => node.toTex());
55
+ const nodeKA = multiply(nodeK, nodeA).simplify();
56
+ const texKA = nodeKA.toTex();
57
+ return `On a :
58
+
59
+ $$
60
+ \\exp(${texKA}) = \\exp(${texA} \\times ${texK}) = {\\exp(${texA})}^{${texK}}
61
+ $$
62
+
63
+ On utilise l'approximation fournie :
64
+
65
+ $$
66
+ \\exp(${texA}) \\approx ${expARounded.frenchify()}
67
+ $$
68
+
69
+ On a donc :
70
+
71
+ $$
72
+ \\exp(${texKA}) = (e^{${texA}})^{${texK}} \\approx ({${expARounded.frenchify()}})^{${texK}}
73
+ $$
74
+
75
+ $$
76
+ \\exp(${texKA}) \\approx ${getAnswer(identifiers)}
77
+ $$
78
+
79
+ `;
80
+ };
81
+ const getPropositions = (n, { answer, ...identifiers }) => {
82
+ const { nodeIdsA, nodeIdsK, expARounded, precision } = identifiers;
83
+ const [nodeA, nodeK] = [nodeIdsA, nodeIdsK].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
84
+ const propositions = [];
85
+ addValidProp(propositions, answer);
86
+ //k*exp(a)
87
+ {
88
+ const nodeWrong = round(multiply(expARounded, nodeK).evaluate(), precision).toTree();
89
+ tryToAddWrongProp(propositions, nodeWrong.toTex());
90
+ }
91
+ //exp(a)^{k-1}
92
+ {
93
+ const identifiersWrong = Object.assign({}, identifiers, {
94
+ nodeIdsK: substract(nodeK, 1).toIdentifiers(),
95
+ });
96
+ const texWrong = getAnswer(identifiersWrong);
97
+ tryToAddWrongProp(propositions, texWrong);
98
+ }
99
+ //exp(a)^{k+1}
100
+ {
101
+ const identifiersWrong = Object.assign({}, identifiers, {
102
+ nodeIdsK: add(nodeK, 1).toIdentifiers(),
103
+ });
104
+ const texWrong = getAnswer(identifiersWrong);
105
+ tryToAddWrongProp(propositions, texWrong);
106
+ }
107
+ //terror: student uses exp(a) instead of given approx value
108
+ {
109
+ function getTerrorNode(identifiers) {
110
+ const { nodeIdsA, nodeIdsK, precision } = identifiers;
111
+ const [nodeA, nodeK] = [nodeIdsA, nodeIdsK].map((nodeIds) => NodeConstructor.fromIdentifiers(nodeIds));
112
+ return round(power(exp(nodeA), nodeK).evaluate(), precision).toTree();
113
+ }
114
+ const arrNode = [
115
+ getTerrorNode(identifiers),
116
+ round(multiply(exp(nodeA), nodeK).evaluate(), precision).toTree(),
117
+ getTerrorNode(Object.assign({}, identifiers, {
118
+ nodeIdsK: substract(nodeK, 1).toIdentifiers(),
119
+ })),
120
+ getTerrorNode(Object.assign({}, identifiers, {
121
+ nodeIdsK: add(nodeK, 1).toIdentifiers(),
122
+ })),
123
+ ];
124
+ shuffle(arrNode)
125
+ .slice(0, randint(0, 3))
126
+ .forEach((node) => {
127
+ tryToAddWrongProp(propositions, node.toTex());
128
+ });
129
+ }
130
+ return shuffleProps(propositions, n);
131
+ };
132
+ const isAnswerValid = (ans, { answer }) => {
133
+ return ans === answer;
134
+ };
135
+ const getApproxExpKaQuestion = () => {
136
+ function createRandomIdentifiers() {
137
+ const nodeA = randfloat(0, 3, 2, [0]).toTree();
138
+ const precision = randint(1, 6);
139
+ const expARounded = round(exp(nodeA).evaluate(), precision);
140
+ const nodeK = random([
141
+ //-1
142
+ (-1).toTree(),
143
+ //1/2
144
+ frac(1, 2),
145
+ //int
146
+ (() => randint(2, 11).toTree())(),
147
+ ]);
148
+ const identifiers = {
149
+ nodeIdsA: nodeA.toIdentifiers(),
150
+ nodeIdsK: nodeK.toIdentifiers(),
151
+ expARounded,
152
+ precision,
153
+ nodeA,
154
+ nodeK,
155
+ };
156
+ return identifiers;
157
+ }
158
+ let identifiers;
159
+ let counter = -1;
160
+ let isValid = false;
161
+ while (!isValid && counter < 100) {
162
+ counter++;
163
+ const identifiersCandidate = createRandomIdentifiers();
164
+ isValid = (() => {
165
+ const { nodeA, nodeK } = identifiersCandidate;
166
+ return multiply(nodeA, nodeK).evaluate() < 15;
167
+ })();
168
+ if (isValid) {
169
+ identifiers = identifiersCandidate;
170
+ }
171
+ }
172
+ if (!isValid) {
173
+ const identifiersDefault = {
174
+ nodeIdsA: (2).toTree().toIdentifiers(),
175
+ nodeIdsK: frac(1, 2).toIdentifiers(),
176
+ precision: 2,
177
+ expARounded: round(exp(2).evaluate(), 2),
178
+ };
179
+ identifiers = identifiersDefault;
180
+ }
181
+ return getQuestionFromIdentifiers(identifiers);
182
+ };
183
+ const getQuestionFromIdentifiers = (identifiers, opts) => {
184
+ return {
185
+ answer: getAnswer(identifiers, opts),
186
+ instruction: getInstruction(identifiers, opts),
187
+ keys: [],
188
+ answerFormat: "tex",
189
+ identifiers,
190
+ hint: getHint(identifiers, opts),
191
+ correction: getCorrection(identifiers, opts),
192
+ };
193
+ };
194
+ export const approxExpKa = {
195
+ id: "approxExpKa",
196
+ label: "Déterminer une valeur approchée de $\\exp(ka)$",
197
+ isSingleStep: true,
198
+ generator: (nb, opts) => getDistinctQuestions(() => getApproxExpKaQuestion(opts), nb),
199
+ qcmTimer: 60,
200
+ freeTimer: 60,
201
+ getPropositions,
202
+ isAnswerValid,
203
+ subject: "Mathématiques",
204
+ getInstruction,
205
+ getHint,
206
+ getCorrection,
207
+ getAnswer,
208
+ getQuestionFromIdentifiers,
209
+ hasHintAndCorrection: true,
210
+ shouldHaveCalculator: true,
211
+ };
@@ -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
+ };
@@ -0,0 +1,5 @@
1
+ export * from "./approxExpN.js";
2
+ export * from "./approxExpKa.js";
3
+ export * from "./approxExpAPlusB.js";
4
+ export * from "./rewriteExpUsingExpA.js";
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/exercises/math/functions/exponential/algebraic/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC;AACrC,cAAc,0BAA0B,CAAC"}
@@ -0,0 +1,4 @@
1
+ export * from "./approxExpN.js";
2
+ export * from "./approxExpKa.js";
3
+ export * from "./approxExpAPlusB.js";
4
+ export * from "./rewriteExpUsingExpA.js";
@@ -0,0 +1,14 @@
1
+ import { Exercise } from "../../../../../exercises/exercise.js";
2
+ import { NodeIdentifiers } from "../../../../../tree/nodes/nodeConstructor.js";
3
+ type Identifiers = {
4
+ nodeIdsA: NodeIdentifiers;
5
+ nodeIdsB: NodeIdentifiers;
6
+ nodeIdsAOpB: NodeIdentifiers;
7
+ rand: number;
8
+ };
9
+ type Options = {
10
+ isUseExpNotation: boolean;
11
+ };
12
+ export declare const rewriteExpUsingExpA: Exercise<Identifiers, Options>;
13
+ export {};
14
+ //# sourceMappingURL=rewriteExpUsingExpA.d.ts.map