math-exercises 3.0.158 → 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 (218) hide show
  1. package/lib/exercises/math/calculLitteral/equation/exp/expOfFEqualsExpOfGEquation.js +7 -6
  2. package/lib/exercises/math/calculLitteral/equation/exp/expOfTrinomEquals1Equation.d.ts.map +1 -1
  3. package/lib/exercises/math/calculLitteral/equation/exp/expOfTrinomEquals1Equation.js +88 -9
  4. package/lib/exercises/math/calculLitteral/equation/factorizeEquation.d.ts.map +1 -1
  5. package/lib/exercises/math/calculLitteral/equation/factorizeEquation.js +8 -2
  6. package/lib/exercises/math/calculLitteral/equation/index.d.ts +1 -0
  7. package/lib/exercises/math/calculLitteral/equation/index.d.ts.map +1 -1
  8. package/lib/exercises/math/calculLitteral/equation/index.js +1 -0
  9. package/lib/exercises/math/calculLitteral/equation/multiplicationEquation.d.ts.map +1 -1
  10. package/lib/exercises/math/calculLitteral/equation/multiplicationEquation.js +27 -2
  11. package/lib/exercises/math/calculLitteral/equation/solveByFactorizingWithIdRmq3.d.ts.map +1 -1
  12. package/lib/exercises/math/calculLitteral/equation/solveByFactorizingWithIdRmq3.js +0 -1
  13. package/lib/exercises/math/calculLitteral/equation/square/equationSquareWithSteps.d.ts.map +1 -1
  14. package/lib/exercises/math/calculLitteral/equation/square/equationSquareWithSteps.js +0 -1
  15. package/lib/exercises/math/calculLitteral/inequations/exp/expOfFEqualsExpOfGInequation.d.ts.map +1 -1
  16. package/lib/exercises/math/calculLitteral/inequations/exp/expOfFEqualsExpOfGInequation.js +11 -4
  17. package/lib/exercises/math/calculLitteral/inequations/firstDegreeInequationsType3.d.ts.map +1 -1
  18. package/lib/exercises/math/calculLitteral/inequations/firstDegreeInequationsType3.js +11 -5
  19. package/lib/exercises/math/calculLitteral/inequations/index.d.ts +1 -0
  20. package/lib/exercises/math/calculLitteral/inequations/index.d.ts.map +1 -1
  21. package/lib/exercises/math/calculLitteral/inequations/index.js +1 -0
  22. package/lib/exercises/math/derivation/derivative/exp/expDerivativeFour.d.ts.map +1 -1
  23. package/lib/exercises/math/derivation/derivative/exp/expDerivativeFour.js +91 -21
  24. package/lib/exercises/math/derivation/derivative/exp/expDerivativeOne.d.ts.map +1 -1
  25. package/lib/exercises/math/derivation/derivative/exp/expDerivativeOne.js +63 -43
  26. package/lib/exercises/math/derivation/derivative/exp/expDerivativeThree.d.ts.map +1 -1
  27. package/lib/exercises/math/derivation/derivative/exp/expDerivativeThree.js +72 -49
  28. package/lib/exercises/math/derivation/derivative/exp/expDerivativeTwo.d.ts.map +1 -1
  29. package/lib/exercises/math/derivation/derivative/exp/expDerivativeTwo.js +19 -19
  30. package/lib/exercises/math/derivation/derivative/exp/expOverExpDerivative.d.ts.map +1 -1
  31. package/lib/exercises/math/derivation/derivative/exp/expOverExpDerivative.js +26 -14
  32. package/lib/exercises/math/derivation/derivative/exp/index.d.ts +1 -0
  33. package/lib/exercises/math/derivation/derivative/exp/index.d.ts.map +1 -1
  34. package/lib/exercises/math/derivation/derivative/exp/index.js +1 -0
  35. package/lib/exercises/math/derivation/variations/index.d.ts +1 -0
  36. package/lib/exercises/math/derivation/variations/index.d.ts.map +1 -1
  37. package/lib/exercises/math/derivation/variations/index.js +1 -0
  38. package/lib/exercises/math/derivation/variations/readExtremaAbscissFromDerivativeCurve.d.ts +7 -0
  39. package/lib/exercises/math/derivation/variations/readExtremaAbscissFromDerivativeCurve.d.ts.map +1 -0
  40. package/lib/exercises/math/derivation/variations/readExtremaAbscissFromDerivativeCurve.js +174 -0
  41. package/lib/exercises/math/functions/exponential/algebraic/approxExpAPlusB.d.ts.map +1 -1
  42. package/lib/exercises/math/functions/exponential/algebraic/approxExpAPlusB.js +30 -3
  43. package/lib/exercises/math/functions/exponential/algebraic/approxExpKa.d.ts.map +1 -1
  44. package/lib/exercises/math/functions/exponential/algebraic/approxExpKa.js +12 -7
  45. package/lib/exercises/math/functions/exponential/algebraic/approxExpN.js +1 -1
  46. package/lib/exercises/math/functions/exponential/algebraic/rewriteExpUsingExpA.js +2 -2
  47. package/lib/exercises/math/functions/exponential/definition/approxExpAPlusH.d.ts.map +1 -1
  48. package/lib/exercises/math/functions/exponential/definition/approxExpAPlusH.js +33 -44
  49. package/lib/exercises/math/functions/exponential/definition/expAntecedentFromGraph.d.ts.map +1 -1
  50. package/lib/exercises/math/functions/exponential/definition/expAntecedentFromGraph.js +80 -8
  51. package/lib/exercises/math/functions/exponential/definition/expImageFromGraph.d.ts.map +1 -1
  52. package/lib/exercises/math/functions/exponential/definition/expImageFromGraph.js +80 -25
  53. package/lib/exercises/math/functions/exponential/definition/isPlausibleExpFromGraph.d.ts.map +1 -1
  54. package/lib/exercises/math/functions/exponential/definition/isPlausibleExpFromGraph.js +6 -15
  55. package/lib/exercises/math/functions/exponential/expFactorization.d.ts.map +1 -1
  56. package/lib/exercises/math/functions/exponential/expFactorization.js +54 -42
  57. package/lib/exercises/math/functions/exponential/index.d.ts +2 -0
  58. package/lib/exercises/math/functions/exponential/index.d.ts.map +1 -1
  59. package/lib/exercises/math/functions/exponential/index.js +2 -0
  60. package/lib/exercises/math/functions/trinoms/equation/secondDegreeInequation.js +3 -0
  61. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusB.d.ts.map +1 -1
  62. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusB.js +18 -23
  63. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusBOverCEXPlusD.d.ts.map +1 -1
  64. package/lib/exercises/math/functions/variations/exp/varOfAEXPlusBOverCEXPlusD.js +24 -26
  65. package/lib/exercises/math/functions/variations/index.d.ts +1 -0
  66. package/lib/exercises/math/functions/variations/index.d.ts.map +1 -1
  67. package/lib/exercises/math/functions/variations/index.js +1 -0
  68. package/lib/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPerpendicularLine.d.ts +12 -0
  69. package/lib/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPerpendicularLine.d.ts.map +1 -0
  70. package/lib/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPerpendicularLine.js +230 -0
  71. package/lib/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPointAndNormalVector.d.ts +10 -0
  72. package/lib/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPointAndNormalVector.d.ts.map +1 -0
  73. package/lib/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPointAndNormalVector.js +167 -0
  74. package/lib/exercises/math/geometry/cartesian/index.d.ts +3 -0
  75. package/lib/exercises/math/geometry/cartesian/index.d.ts.map +1 -1
  76. package/lib/exercises/math/geometry/cartesian/index.js +3 -0
  77. package/lib/exercises/math/geometry/cartesian/normalVectorFromCartesianLineEquation.d.ts +10 -0
  78. package/lib/exercises/math/geometry/cartesian/normalVectorFromCartesianLineEquation.d.ts.map +1 -0
  79. package/lib/exercises/math/geometry/cartesian/normalVectorFromCartesianLineEquation.js +131 -0
  80. package/lib/exercises/math/geometry/circles/index.d.ts +2 -0
  81. package/lib/exercises/math/geometry/circles/index.d.ts.map +1 -0
  82. package/lib/exercises/math/geometry/circles/index.js +1 -0
  83. package/lib/exercises/math/geometry/circles/isPointOnCircleFromCartesianEquation.d.ts +11 -0
  84. package/lib/exercises/math/geometry/circles/isPointOnCircleFromCartesianEquation.d.ts.map +1 -0
  85. package/lib/exercises/math/geometry/circles/isPointOnCircleFromCartesianEquation.js +131 -0
  86. package/lib/exercises/math/geometry/euclidian/pinSegmentFromRotation.d.ts.map +1 -1
  87. package/lib/exercises/math/geometry/euclidian/pinSegmentFromRotation.js +0 -2
  88. package/lib/exercises/math/geometry/index.d.ts +1 -0
  89. package/lib/exercises/math/geometry/index.d.ts.map +1 -1
  90. package/lib/exercises/math/geometry/index.js +1 -0
  91. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/index.d.ts +4 -0
  92. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/index.d.ts.map +1 -0
  93. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/index.js +3 -0
  94. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiAngle.d.ts +9 -0
  95. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiAngle.d.ts.map +1 -0
  96. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiAngle.js +247 -0
  97. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiBH.d.ts +13 -0
  98. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiBH.d.ts.map +1 -0
  99. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiBH.js +452 -0
  100. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiSideLength.d.ts +9 -0
  101. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiSideLength.d.ts.map +1 -0
  102. package/lib/exercises/math/geometry/vectors/scalarProduct/alKashi/scalarProductAlKashiSideLength.js +253 -0
  103. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/index.d.ts +4 -0
  104. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/index.d.ts.map +1 -0
  105. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/index.js +3 -0
  106. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductIdentities.d.ts +10 -0
  107. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductIdentities.d.ts.map +1 -0
  108. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductIdentities.js +174 -0
  109. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductInOrthonormalBasisIJ.d.ts +9 -0
  110. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductInOrthonormalBasisIJ.d.ts.map +1 -0
  111. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductInOrthonormalBasisIJ.js +231 -0
  112. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductLamdbaULambdaV.d.ts +14 -0
  113. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductLamdbaULambdaV.d.ts.map +1 -0
  114. package/lib/exercises/math/geometry/vectors/scalarProduct/alg/scalarProductLamdbaULambdaV.js +292 -0
  115. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/index.d.ts +6 -0
  116. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/index.d.ts.map +1 -0
  117. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/index.js +5 -0
  118. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsOrthogonalVecsBasisIJ.d.ts +9 -0
  119. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsOrthogonalVecsBasisIJ.d.ts.map +1 -0
  120. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsOrthogonalVecsBasisIJ.js +202 -0
  121. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsOrthogonalVecsUsingCoords.d.ts +9 -0
  122. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsOrthogonalVecsUsingCoords.d.ts.map +1 -0
  123. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsOrthogonalVecsUsingCoords.js +127 -0
  124. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsPointOnCircle.d.ts +12 -0
  125. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsPointOnCircle.d.ts.map +1 -0
  126. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsPointOnCircle.js +167 -0
  127. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsPointOnPerpendicularBisector.d.ts +12 -0
  128. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsPointOnPerpendicularBisector.d.ts.map +1 -0
  129. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsPointOnPerpendicularBisector.js +180 -0
  130. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsRightTriangleUsingPointCoords.d.ts +12 -0
  131. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsRightTriangleUsingPointCoords.d.ts.map +1 -0
  132. package/lib/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsRightTriangleUsingPointCoords.js +235 -0
  133. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductComputeBH.d.ts +12 -0
  134. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductComputeBH.d.ts.map +1 -0
  135. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductComputeBH.js +423 -0
  136. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductOfVectsOnGrid1.d.ts +17 -0
  137. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductOfVectsOnGrid1.d.ts.map +1 -0
  138. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductOfVectsOnGrid1.js +347 -0
  139. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductParallelogramDiagonalPlus.d.ts +8 -0
  140. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductParallelogramDiagonalPlus.d.ts.map +1 -0
  141. package/lib/exercises/math/geometry/vectors/scalarProduct/scalarProductParallelogramDiagonalPlus.js +301 -0
  142. package/lib/exercises/math/probaStat/randomVariable/findValueForFairRandomVariable.d.ts +9 -0
  143. package/lib/exercises/math/probaStat/randomVariable/findValueForFairRandomVariable.d.ts.map +1 -0
  144. package/lib/exercises/math/probaStat/randomVariable/findValueForFairRandomVariable.js +141 -0
  145. package/lib/exercises/math/probaStat/randomVariable/findValueToMatchRandomVariableAverage.d.ts +10 -0
  146. package/lib/exercises/math/probaStat/randomVariable/findValueToMatchRandomVariableAverage.d.ts.map +1 -0
  147. package/lib/exercises/math/probaStat/randomVariable/findValueToMatchRandomVariableAverage.js +174 -0
  148. package/lib/exercises/math/probaStat/randomVariable/index.d.ts +1 -0
  149. package/lib/exercises/math/probaStat/randomVariable/index.d.ts.map +1 -1
  150. package/lib/exercises/math/probaStat/randomVariable/index.js +2 -0
  151. package/lib/exercises/math/sequences/generation/index.d.ts +2 -0
  152. package/lib/exercises/math/sequences/generation/index.d.ts.map +1 -0
  153. package/lib/exercises/math/sequences/generation/index.js +1 -0
  154. package/lib/exercises/math/sequences/generation/recognizeRecurrenceOrExplicit.d.ts +8 -0
  155. package/lib/exercises/math/sequences/generation/recognizeRecurrenceOrExplicit.d.ts.map +1 -0
  156. package/lib/exercises/math/sequences/generation/recognizeRecurrenceOrExplicit.js +63 -0
  157. package/lib/exercises/math/sequences/graph/index.d.ts +2 -0
  158. package/lib/exercises/math/sequences/graph/index.d.ts.map +1 -0
  159. package/lib/exercises/math/sequences/graph/index.js +1 -0
  160. package/lib/exercises/math/sequences/graph/placeFirstSequencePoints.d.ts +11 -0
  161. package/lib/exercises/math/sequences/graph/placeFirstSequencePoints.d.ts.map +1 -0
  162. package/lib/exercises/math/sequences/graph/placeFirstSequencePoints.js +113 -0
  163. package/lib/exercises/math/sequences/index.d.ts +2 -0
  164. package/lib/exercises/math/sequences/index.d.ts.map +1 -1
  165. package/lib/exercises/math/sequences/index.js +2 -0
  166. package/lib/exercises/math/sequences/notation/identifyRankInSequenceTermsList.d.ts +12 -0
  167. package/lib/exercises/math/sequences/notation/identifyRankInSequenceTermsList.d.ts.map +1 -0
  168. package/lib/exercises/math/sequences/notation/identifyRankInSequenceTermsList.js +114 -0
  169. package/lib/exercises/math/sequences/notation/identifySequenceTermInList.d.ts +12 -0
  170. package/lib/exercises/math/sequences/notation/identifySequenceTermInList.d.ts.map +1 -0
  171. package/lib/exercises/math/sequences/notation/identifySequenceTermInList.js +111 -0
  172. package/lib/exercises/math/sequences/notation/index.d.ts +3 -0
  173. package/lib/exercises/math/sequences/notation/index.d.ts.map +1 -0
  174. package/lib/exercises/math/sequences/notation/index.js +2 -0
  175. package/lib/exercises/math/spaceGeometry/basis/findSpacePointOnRectangularPrism.d.ts.map +1 -1
  176. package/lib/exercises/math/spaceGeometry/basis/findSpacePointOnRectangularPrism.js +0 -1
  177. package/lib/exercises/math/spaceGeometry/sphere/sphereLatLonReading.2d.d.ts.map +1 -1
  178. package/lib/exercises/math/spaceGeometry/sphere/sphereLatLonReading.2d.js +0 -2
  179. package/lib/exercises/vea/cartesianLineVEA.d.ts +2 -0
  180. package/lib/exercises/vea/cartesianLineVEA.d.ts.map +1 -0
  181. package/lib/exercises/vea/cartesianLineVEA.js +1 -0
  182. package/lib/index.d.ts +123 -0
  183. package/lib/index.d.ts.map +1 -1
  184. package/lib/math/geometry/line.d.ts +2 -0
  185. package/lib/math/geometry/line.d.ts.map +1 -1
  186. package/lib/math/geometry/line.js +7 -0
  187. package/lib/math/geometry/point.d.ts +1 -0
  188. package/lib/math/geometry/point.d.ts.map +1 -1
  189. package/lib/math/geometry/point.js +5 -0
  190. package/lib/math/geometry/polygons/relationPP.d.ts +8 -0
  191. package/lib/math/geometry/polygons/relationPP.d.ts.map +1 -0
  192. package/lib/math/geometry/polygons/relationPP.js +41 -0
  193. package/lib/math/polynomials/trinom.d.ts +1 -1
  194. package/lib/math/polynomials/trinom.d.ts.map +1 -1
  195. package/lib/math/polynomials/trinom.js +15 -6
  196. package/lib/math/utils/arithmetic/primeFactors.js +1 -1
  197. package/lib/math/utils/geometry/randomVecs2.d.ts +6 -0
  198. package/lib/math/utils/geometry/randomVecs2.d.ts.map +1 -0
  199. package/lib/math/utils/geometry/randomVecs2.js +34 -0
  200. package/lib/tests/questionTest.d.ts.map +1 -1
  201. package/lib/tests/questionTest.js +2 -2
  202. package/lib/tree/nodes/equations/equationSolutionNode.d.ts +1 -0
  203. package/lib/tree/nodes/equations/equationSolutionNode.d.ts.map +1 -1
  204. package/lib/tree/nodes/equations/equationSolutionNode.js +3 -0
  205. package/lib/tree/nodes/functions/expNode.d.ts +1 -1
  206. package/lib/tree/nodes/functions/expNode.d.ts.map +1 -1
  207. package/lib/tree/nodes/inequations/inequationSolutionNode.d.ts +1 -0
  208. package/lib/tree/nodes/inequations/inequationSolutionNode.d.ts.map +1 -1
  209. package/lib/tree/nodes/inequations/inequationSolutionNode.js +3 -0
  210. package/lib/tree/nodes/operators/fractionNode.d.ts +1 -1
  211. package/lib/tree/nodes/operators/fractionNode.d.ts.map +1 -1
  212. package/lib/tree/nodes/operators/fractionNode.js +6 -4
  213. package/lib/tree/nodes/sets/intervalNode.d.ts +6 -0
  214. package/lib/tree/nodes/sets/intervalNode.d.ts.map +1 -1
  215. package/lib/tree/nodes/sets/namedIntervalNode.d.ts +31 -0
  216. package/lib/tree/nodes/sets/namedIntervalNode.d.ts.map +1 -0
  217. package/lib/tree/nodes/sets/namedIntervalNode.js +77 -0
  218. package/package.json +1 -1
@@ -0,0 +1,180 @@
1
+ import { addValidProp, tryToAddWrongProp, } from "../../../../../../exercises/exercise.js";
2
+ import { getDistinctQuestions } from "../../../../../../exercises/utils/getDistinctQuestions.js";
3
+ import { Point, PointConstructor, } from "../../../../../../math/geometry/point.js";
4
+ import { Vector, VectorConstructor, } from "../../../../../../math/geometry/vector.js";
5
+ import { randomVecs2 } from "../../../../../../math/utils/geometry/randomVecs2.js";
6
+ import { randint } from "../../../../../../math/utils/random/randint.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 { substract } from "../../../../../../tree/nodes/operators/substractNode.js";
11
+ import { coinFlip } from "../../../../../../utils/alea/coinFlip.js";
12
+ import { shuffle } from "../../../../../../utils/alea/shuffle.js";
13
+ import { zip } from "../../../../../../utils/arrays/arrayZip.js";
14
+ import { alignTex } from "../../../../../../utils/latex/alignTex.js";
15
+ const getHydrated = (identifiers) => {
16
+ const { vecIdsU, vecIdsV, pointIds, pointNames } = identifiers;
17
+ const vecU = VectorConstructor.fromIdentifiers(vecIdsU);
18
+ const vecV = VectorConstructor.fromIdentifiers(vecIdsV);
19
+ const [nameP1, nameP2, nameP3] = pointNames;
20
+ const pointI = PointConstructor.fromIdentifiers(pointIds);
21
+ const point1 = vecU.times((-1).toTree()).getEndPoint(pointI, nameP1);
22
+ const point2 = vecU.getEndPoint(pointI, nameP2);
23
+ const point3 = vecV.getEndPoint(pointI, nameP3);
24
+ return {
25
+ vecU,
26
+ vecV,
27
+ [point1.name]: point1,
28
+ [point2.name]: point2,
29
+ [point3.name]: point3,
30
+ };
31
+ };
32
+ const getInstruction = (identifiers) => {
33
+ const { pointNames } = identifiers;
34
+ const { A, B, C } = getHydrated(identifiers);
35
+ return `Soient trois points :
36
+
37
+ ${[A, B, C].map((point) => `- $${point.toTexWithCoords()}$`).join(`
38
+
39
+ `)}
40
+
41
+ Le point $${pointNames[2]}$ appartient-il à la médiatrice du segment $[${pointNames[0]}${pointNames[1]}]$ ?`;
42
+ };
43
+ const getAnswerNode = (identifiers) => {
44
+ const { vecU, vecV } = getHydrated(identifiers);
45
+ const nodesU = [vecU.x, vecU.y];
46
+ const nodesV = [vecV.x, vecV.y];
47
+ return zip(nodesU, nodesV)
48
+ .map(([nodeUX, nodeVX]) => multiply(nodeUX, nodeVX))
49
+ .reduce((acc, nodeX) => add(acc, nodeX));
50
+ };
51
+ const getAnswer = (identifiers) => {
52
+ const answerNode = getAnswerNode(identifiers);
53
+ const isOrthogonal = answerNode.simplify().evaluate() === 0;
54
+ return ["Oui", "Non"][isOrthogonal ? 0 : 1];
55
+ };
56
+ const getHint = () => {
57
+ const [a, b] = ["a", "b"].map((letter) => `\\overrightarrow{${letter}}`);
58
+ return `Deux vecteurs $${a}$ et $${b}$ sont orthogonaux si et seulement si $${a} \\cdot ${b} = 0$.`;
59
+ };
60
+ const getCorrection = (identifiers) => {
61
+ const { pointNames, pointIds } = identifiers;
62
+ const { vecU, vecV, A, B, C } = getHydrated(identifiers);
63
+ const pointsDict = { A, B, C };
64
+ const [point1, point2, point3] = pointNames.map((pointName) => pointsDict[pointName]);
65
+ const vecOI = new Vector(`OI`, frac(add(point1.x, point2.x), 2), frac(add(point1.y, point2.y), 2));
66
+ function createVecComputation(pointStart, pointEnd) {
67
+ const nodeX = substract(pointEnd.x, pointStart.x);
68
+ const nodeY = substract(pointEnd.y, pointStart.y);
69
+ return new Vector(`${pointStart.name}${pointEnd.name}`, nodeX, nodeY);
70
+ }
71
+ const pointI = PointConstructor.fromIdentifiers(pointIds);
72
+ const vecComputation2U = createVecComputation(point1, point2);
73
+ const vecComputationV = createVecComputation(pointI, point3);
74
+ const isOrthogonal = getAnswerNode(identifiers).simplify().evaluate() === 0;
75
+ const nodeScalarProduct = vecU.scalarProduct(vecV);
76
+ return `On nomme $O$ l'origine du repère et $I$ le milieu de $[${point1.name}${point2.name}]$. On a :
77
+
78
+ ${alignTex([
79
+ [
80
+ "\\overrightarrow{OI}",
81
+ "=",
82
+ `\\frac{\\overrightarrow{O${point1.name}} + \\overrightarrow{O${point2.name}}}{2}`,
83
+ ],
84
+ ["", "=", `${vecOI.toCoords()}`],
85
+ ["", "=", `${vecOI.simplify().toCoords()}`],
86
+ ])}
87
+
88
+ On peut calculer les coordonnées des vecteurs :
89
+
90
+ ${zip([vecComputation2U, vecComputationV], [vecU.times((2).toTree()).simplify(), vecV]).map(([vecComputation, vec]) => `
91
+
92
+ ${alignTex([
93
+ [vecComputation.toTex(), "=", vecComputation.toCoords()],
94
+ ["", "=", vec.toCoords()],
95
+ ])}
96
+
97
+ `).join(`
98
+
99
+ `)}
100
+
101
+ ${alignTex([
102
+ [
103
+ `${vecComputation2U.toTex()} \\cdot ${vecComputationV.toTex()}`,
104
+ "=",
105
+ `${nodeScalarProduct.toTex()}`,
106
+ ],
107
+ ["", "=", `${nodeScalarProduct.simplify().toTex()}`],
108
+ ])}
109
+
110
+ ${(() => {
111
+ if (isOrthogonal) {
112
+ return `Les vecteurs $${vecComputation2U.toTex()}$ et $${vecComputationV.toTex()}$ sont donc orthogonaux.
113
+ Le point $${point3.name}$ appartient donc à la médiatrice de $[${point1.name}${point2.name}]$.`;
114
+ }
115
+ else {
116
+ return `Les vecteurs $${vecComputation2U.toTex()}$ et $${vecComputationV.toTex()}$ ne sont donc pas orthogonaux.
117
+ Le point $${point3.name}$ n'appartient donc pas à la médiatrice de $[${point1.name}${point2.name}]$.`;
118
+ }
119
+ })()}`;
120
+ };
121
+ const getPropositions = (_, { answer, ...identifiers }) => {
122
+ const propositions = [];
123
+ const answerFromIdentifiers = getAnswer(identifiers);
124
+ ["Oui", "Non"].forEach((strProp) => {
125
+ if (strProp === answerFromIdentifiers) {
126
+ addValidProp(propositions, strProp, "raw");
127
+ }
128
+ else {
129
+ tryToAddWrongProp(propositions, strProp, "raw");
130
+ }
131
+ });
132
+ return propositions;
133
+ };
134
+ const getScalarProductIsPointOnPerpendicularBisectorQuestion = () => {
135
+ const isOrthogonal = coinFlip();
136
+ const { vecU, vecV } = randomVecs2(isOrthogonal);
137
+ const x = Math.ceil(-Math.max(vecU.x.evaluate(), vecV.x.evaluate()) / 2) +
138
+ randint(0, 3);
139
+ const y = Math.ceil(-Math.max(vecU.y.evaluate(), vecV.y.evaluate()) / 2) +
140
+ randint(0, 3);
141
+ const pointI = new Point("I", x, y);
142
+ const pointNames = shuffle(["A", "B", "C"]);
143
+ const identifiers = {
144
+ vecIdsU: vecU.toIdentifiers(),
145
+ vecIdsV: vecV.toIdentifiers(),
146
+ pointIds: pointI.toIdentifiers(),
147
+ pointNames,
148
+ };
149
+ return getQuestionFromIdentifiers(identifiers);
150
+ };
151
+ const getQuestionFromIdentifiers = (identifiers, opts) => {
152
+ return {
153
+ answer: getAnswer(identifiers, opts),
154
+ instruction: getInstruction(identifiers, opts),
155
+ keys: [],
156
+ answerFormat: "tex",
157
+ identifiers,
158
+ hint: getHint(identifiers, opts),
159
+ correction: getCorrection(identifiers, opts),
160
+ options: opts,
161
+ };
162
+ };
163
+ export const scalarProductIsPointOnPerpendicularBisector = {
164
+ id: "scalarProductIsPointOnPerpendicularBisector",
165
+ connector: "=",
166
+ label: "Déterminer si un point appartient à la médiatrice d'un segment",
167
+ isSingleStep: true,
168
+ generator: (nb) => getDistinctQuestions(() => getScalarProductIsPointOnPerpendicularBisectorQuestion(), nb),
169
+ qcmTimer: 60,
170
+ freeTimer: 60,
171
+ getPropositions,
172
+ subject: "Mathématiques",
173
+ getInstruction,
174
+ getHint,
175
+ getCorrection,
176
+ getAnswer,
177
+ getQuestionFromIdentifiers,
178
+ hasHintAndCorrection: true,
179
+ answerType: "QCU",
180
+ };
@@ -0,0 +1,12 @@
1
+ import { Exercise } from "../../../../../../exercises/exercise.js";
2
+ import { PointIdentifiers } from "../../../../../../math/geometry/point.js";
3
+ import { VectorIdentifiers } from "../../../../../../math/geometry/vector.js";
4
+ type Identifiers = {
5
+ vecIdsU: VectorIdentifiers;
6
+ vecIdsV: VectorIdentifiers;
7
+ pointIds: PointIdentifiers;
8
+ pointNames: string[];
9
+ };
10
+ export declare const scalarProductIsRightTriangleUsingPointCoords: Exercise<Identifiers>;
11
+ export {};
12
+ //# sourceMappingURL=scalarProductIsRightTriangleUsingPointCoords.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scalarProductIsRightTriangleUsingPointCoords.d.ts","sourceRoot":"","sources":["../../../../../../../src/exercises/math/geometry/vectors/scalarProduct/orth/scalarProductIsRightTriangleUsingPointCoords.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAWT,MAAM,6BAA6B,CAAC;AAErC,OAAO,EAGL,gBAAgB,EACjB,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAGL,iBAAiB,EAClB,MAAM,+BAA+B,CAAC;AAYvC,KAAK,WAAW,GAAG;IACjB,OAAO,EAAE,iBAAiB,CAAC;IAC3B,OAAO,EAAE,iBAAiB,CAAC;IAC3B,QAAQ,EAAE,gBAAgB,CAAC;IAC3B,UAAU,EAAE,MAAM,EAAE,CAAC;CACtB,CAAC;AAiQF,eAAO,MAAM,4CAA4C,EAAE,QAAQ,CAAC,WAAW,CAuB5E,CAAC"}
@@ -0,0 +1,235 @@
1
+ import { addValidProp, tryToAddWrongProp, } from "../../../../../../exercises/exercise.js";
2
+ import { getDistinctQuestions } from "../../../../../../exercises/utils/getDistinctQuestions.js";
3
+ import { Point, PointConstructor, } from "../../../../../../math/geometry/point.js";
4
+ import { Vector, VectorConstructor, } from "../../../../../../math/geometry/vector.js";
5
+ import { randomVecs2 } from "../../../../../../math/utils/geometry/randomVecs2.js";
6
+ import { randint } from "../../../../../../math/utils/random/randint.js";
7
+ import { add } from "../../../../../../tree/nodes/operators/addNode.js";
8
+ import { multiply } from "../../../../../../tree/nodes/operators/multiplyNode.js";
9
+ import { substract } from "../../../../../../tree/nodes/operators/substractNode.js";
10
+ import { coinFlip } from "../../../../../../utils/alea/coinFlip.js";
11
+ import { shuffle } from "../../../../../../utils/alea/shuffle.js";
12
+ import { zip } from "../../../../../../utils/arrays/arrayZip.js";
13
+ import { alignTex } from "../../../../../../utils/latex/alignTex.js";
14
+ const getHydrated = (identifiers) => {
15
+ const { vecIdsU, vecIdsV, pointIds, pointNames } = identifiers;
16
+ // u = point2 - point1
17
+ const vecU = VectorConstructor.fromIdentifiers(vecIdsU);
18
+ // v = point3 - point1
19
+ const vecV = VectorConstructor.fromIdentifiers(vecIdsV);
20
+ //w = point3 - point2 = v - u
21
+ const vecW = (() => {
22
+ const vecVMinusU = vecV.substract(vecU);
23
+ return new Vector("w", vecVMinusU.x, vecVMinusU.y);
24
+ })();
25
+ const [nameP1, nameP2, nameP3] = pointNames;
26
+ const point1 = (() => {
27
+ const pointP = PointConstructor.fromIdentifiers(pointIds);
28
+ return new Point(nameP1, pointP.x, pointP.y);
29
+ })();
30
+ const point2 = vecU.getEndPoint(point1, nameP2);
31
+ const point3 = vecV.getEndPoint(point1, nameP3);
32
+ return {
33
+ vecU,
34
+ vecV,
35
+ vecW,
36
+ [point1.name]: point1,
37
+ [point2.name]: point2,
38
+ [point3.name]: point3,
39
+ };
40
+ };
41
+ const getInstruction = (identifiers) => {
42
+ const { A, B, C } = getHydrated(identifiers);
43
+ return `Soient trois points :
44
+
45
+ ${[A, B, C].map((point) => `- $${point.toTexWithCoords()}$`).join(`
46
+
47
+ `)}
48
+
49
+ Le triangle $ABC$ est-il un triangle rectangle ?`;
50
+ };
51
+ const getAnswerNode = (identifiers) => {
52
+ const { vecU, vecV } = getHydrated(identifiers);
53
+ const nodesU = [vecU.x, vecU.y];
54
+ const nodesV = [vecV.x, vecV.y];
55
+ return zip(nodesU, nodesV)
56
+ .map(([nodeUX, nodeVX]) => multiply(nodeUX, nodeVX))
57
+ .reduce((acc, nodeX) => add(acc, nodeX));
58
+ };
59
+ const getAnswer = (identifiers) => {
60
+ const answerNode = getAnswerNode(identifiers);
61
+ const isOrthogonal = answerNode.simplify().evaluate() === 0;
62
+ return ["Oui", "Non"][isOrthogonal ? 0 : 1];
63
+ };
64
+ const getHint = () => {
65
+ const [a, b] = ["a", "b"].map((letter) => `\\overrightarrow{${letter}}`);
66
+ return `Deux vecteurs $${a}$ et $${b}$ sont orthogonaux si et seulement si $${a} \\cdot ${b} = 0$.`;
67
+ };
68
+ const getCorrection = (identifiers) => {
69
+ const { pointNames } = identifiers;
70
+ const { vecU, vecV, vecW, A, B, C } = getHydrated(identifiers);
71
+ const pointsDict = { A, B, C };
72
+ function createVecComputation(pointStart, pointEnd) {
73
+ const nodeX = substract(pointEnd.x, pointStart.x);
74
+ const nodeY = substract(pointEnd.y, pointStart.y);
75
+ return new Vector(`${pointStart.name}${pointEnd.name}`, nodeX, nodeY);
76
+ }
77
+ const [point1, point2, point3] = pointNames.map((pointName) => pointsDict[pointName]);
78
+ const vecComputationU = createVecComputation(point1, point2);
79
+ const vecComputationV = createVecComputation(point1, point3);
80
+ const vecComputationW = createVecComputation(point2, point3);
81
+ const isOrthogonal = getAnswerNode(identifiers).simplify().evaluate() === 0;
82
+ return `On calcule les coordonnées des vecteurs :
83
+
84
+ ${zip([vecComputationU, vecComputationV, vecComputationW], [vecU, vecV, vecW]).map(([vecComputation, vec]) => `
85
+
86
+ ${alignTex([
87
+ [vecComputation.toTex(), "=", vecComputation.toCoords()],
88
+ ["", "=", vec.toCoords()],
89
+ ])}
90
+
91
+ `).join(`
92
+
93
+ `)}
94
+
95
+ ${(() => {
96
+ if (isOrthogonal) {
97
+ return `On remarque que :
98
+
99
+ ${alignTex([
100
+ [
101
+ `${vecComputationU.toTex()} \\cdot ${vecComputationV.toTex()}`,
102
+ "=",
103
+ `${vecU.scalarProduct(vecV).toTex()}`,
104
+ ],
105
+ ["", "=", "0"],
106
+ ])}
107
+
108
+ Les vecteurs $${vecComputationU.toTex()}$ et $${vecComputationV.toTex()}$ sont donc orthogonaux.
109
+ Le triangle $ABC$ est rectangle en $${point1.name}$.`;
110
+ }
111
+ else {
112
+ const nodeScalarProductUV = vecU.scalarProduct(vecV);
113
+ const nodeScalarProductVW = vecV.scalarProduct(vecW);
114
+ const nodeScalarProductWU = vecW.scalarProduct(vecU);
115
+ return `On calcule les produits scalaires :
116
+
117
+ ${alignTex([
118
+ [
119
+ `${vecComputationU.toTex()} \\cdot ${vecComputationV.toTex()}`,
120
+ "=",
121
+ `${nodeScalarProductUV.toTex()}`,
122
+ ],
123
+ ["", "=", `${nodeScalarProductUV.simplify().toTex()}`],
124
+ ])}
125
+
126
+ ${alignTex([
127
+ [
128
+ `${vecComputationV.toTex()} \\cdot ${vecComputationW.toTex()}`,
129
+ "=",
130
+ `${nodeScalarProductVW.toTex()}`,
131
+ ],
132
+ ["", "=", `${nodeScalarProductVW.simplify().toTex()}`],
133
+ ])}
134
+
135
+ ${alignTex([
136
+ [
137
+ `${vecComputationW.toTex()} \\cdot ${vecComputationU.toTex()}`,
138
+ "=",
139
+ `${nodeScalarProductWU.toTex()}`,
140
+ ],
141
+ ["", "=", `${nodeScalarProductWU.simplify().toTex()}`],
142
+ ])}
143
+
144
+ Tous les produits scalaires sont non-nuls.
145
+ Le triangle $ABC$ n'est pas un triangle rectangle.`;
146
+ }
147
+ })()}`;
148
+ };
149
+ const getPropositions = (_, { answer, ...identifiers }) => {
150
+ const propositions = [];
151
+ const answerFromIdentifiers = getAnswer(identifiers);
152
+ ["Oui", "Non"].forEach((strProp) => {
153
+ if (strProp === answerFromIdentifiers) {
154
+ addValidProp(propositions, strProp, "raw");
155
+ }
156
+ else {
157
+ tryToAddWrongProp(propositions, strProp, "raw");
158
+ }
159
+ });
160
+ return propositions;
161
+ };
162
+ const getScalarProductIsRightTriangleUsingPointCoordsQuestion = () => {
163
+ function createRandomVecs(isOrthogonal) {
164
+ if (isOrthogonal) {
165
+ return randomVecs2(isOrthogonal);
166
+ }
167
+ else {
168
+ //ensure there is no right angle elsewhere
169
+ let vecU;
170
+ let vecV;
171
+ let isValid = false;
172
+ let counter = -1;
173
+ while (!isValid && counter < 100) {
174
+ counter++;
175
+ const { vecU: vecUCandidate, vecV: vecVCandidate } = randomVecs2(isOrthogonal);
176
+ const vecWCandidate = vecVCandidate.substract(vecUCandidate);
177
+ isValid = vecWCandidate.scalarProduct(vecVCandidate).evaluate() !== 0;
178
+ if (isValid) {
179
+ vecU = vecUCandidate;
180
+ vecV = vecVCandidate;
181
+ }
182
+ }
183
+ if (!isValid) {
184
+ vecU = new Vector("u", (3).toTree(), (1).toTree());
185
+ vecV = new Vector("v", (2).toTree(), (-2).toTree());
186
+ }
187
+ return { vecU: vecU, vecV: vecV };
188
+ }
189
+ }
190
+ const isOrthogonal = coinFlip();
191
+ const { vecU, vecV } = createRandomVecs(isOrthogonal);
192
+ const x = Math.ceil(-Math.max(vecU.x.evaluate(), vecV.x.evaluate()) / 2) +
193
+ randint(0, 3);
194
+ const y = Math.ceil(-Math.max(vecU.y.evaluate(), vecV.y.evaluate()) / 2) +
195
+ randint(0, 3);
196
+ const pointP = new Point("P", x, y);
197
+ const pointNames = shuffle(["A", "B", "C"]);
198
+ const identifiers = {
199
+ vecIdsU: vecU.toIdentifiers(),
200
+ vecIdsV: vecV.toIdentifiers(),
201
+ pointIds: pointP.toIdentifiers(),
202
+ pointNames,
203
+ };
204
+ return getQuestionFromIdentifiers(identifiers);
205
+ };
206
+ const getQuestionFromIdentifiers = (identifiers, opts) => {
207
+ return {
208
+ answer: getAnswer(identifiers, opts),
209
+ instruction: getInstruction(identifiers, opts),
210
+ keys: [],
211
+ answerFormat: "tex",
212
+ identifiers,
213
+ hint: getHint(identifiers, opts),
214
+ correction: getCorrection(identifiers, opts),
215
+ options: opts,
216
+ };
217
+ };
218
+ export const scalarProductIsRightTriangleUsingPointCoords = {
219
+ id: "scalarProductIsRightTriangleUsingPointCoords",
220
+ connector: "=",
221
+ label: "Déterminer si un triangle est rectangle à partir des coordonnées de ses sommets",
222
+ isSingleStep: true,
223
+ generator: (nb) => getDistinctQuestions(() => getScalarProductIsRightTriangleUsingPointCoordsQuestion(), nb),
224
+ qcmTimer: 60,
225
+ freeTimer: 60,
226
+ getPropositions,
227
+ subject: "Mathématiques",
228
+ getInstruction,
229
+ getHint,
230
+ getCorrection,
231
+ getAnswer,
232
+ getQuestionFromIdentifiers,
233
+ hasHintAndCorrection: true,
234
+ answerType: "QCU",
235
+ };
@@ -0,0 +1,12 @@
1
+ import { Exercise } from "../../../../../exercises/exercise.js";
2
+ import { PointIdentifiers } from "../../../../../math/geometry/point.js";
3
+ type Identifiers = {
4
+ pointIds: PointIdentifiers[];
5
+ };
6
+ type Options = {
7
+ sectorOfPointH: string;
8
+ isPositiveCoordsOnly: boolean;
9
+ };
10
+ export declare const scalarProductComputeBH: Exercise<Identifiers, Options>;
11
+ export {};
12
+ //# sourceMappingURL=scalarProductComputeBH.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scalarProductComputeBH.d.ts","sourceRoot":"","sources":["../../../../../../src/exercises/math/geometry/vectors/scalarProduct/scalarProductComputeBH.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAoBT,MAAM,6BAA6B,CAAC;AAKrC,OAAO,EAGL,gBAAgB,EACjB,MAAM,8BAA8B,CAAC;AAoBtC,KAAK,WAAW,GAAG;IACjB,QAAQ,EAAE,gBAAgB,EAAE,CAAC;CAC9B,CAAC;AA+bF,KAAK,OAAO,GAAG;IACb,cAAc,EAAE,MAAM,CAAC;IACvB,oBAAoB,EAAE,OAAO,CAAC;CAC/B,CAAC;AA+BF,eAAO,MAAM,sBAAsB,EAAE,QAAQ,CAAC,WAAW,EAAE,OAAO,CA6BjE,CAAC"}