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,230 @@
1
+ import { addValidProp, shuffleProps, propWhile, tryToAddWrongProp, } from "../../../../exercises/exercise.js";
2
+ import { getDistinctQuestions } from "../../../../exercises/utils/getDistinctQuestions.js";
3
+ import { LineConstructor } from "../../../../math/geometry/line.js";
4
+ import { PointConstructor, } from "../../../../math/geometry/point.js";
5
+ import { Vector, VectorConstructor } from "../../../../math/geometry/vector.js";
6
+ import { randint } from "../../../../math/utils/random/randint.js";
7
+ import { opposite } from "../../../../tree/nodes/functions/oppositeNode.js";
8
+ import { reifyAlgebraic, } from "../../../../tree/nodes/nodeConstructor.js";
9
+ import { add } from "../../../../tree/nodes/operators/addNode.js";
10
+ import { multiply } from "../../../../tree/nodes/operators/multiplyNode.js";
11
+ import { substract } from "../../../../tree/nodes/operators/substractNode.js";
12
+ import { parseAlgebraic } from "../../../../tree/parsers/latexParser.js";
13
+ import { handleVEAError } from "../../../../utils/errors/handleVEAError.js";
14
+ const getPropositions = (n, { answer, pointIds, aIds, bIds }) => {
15
+ const propositions = [];
16
+ addValidProp(propositions, answer);
17
+ const point = PointConstructor.fromIdentifiers(pointIds);
18
+ const a = reifyAlgebraic(aIds);
19
+ const b = reifyAlgebraic(bIds);
20
+ const normal = new Vector("n", opposite(b), a).simplify();
21
+ const goodLine = LineConstructor.fromPointAndNormalVector(point, normal);
22
+ propWhile(propositions, n, () => {
23
+ const fakePoint = PointConstructor.random("A");
24
+ const fakeVec = VectorConstructor.random("u");
25
+ const line = LineConstructor.fromPointAndNormalVector(fakePoint, fakeVec);
26
+ if (line.isCoincident(goodLine))
27
+ return;
28
+ tryToAddWrongProp(propositions, line.getCartesianEquation().toTex());
29
+ });
30
+ return shuffleProps(propositions, n);
31
+ };
32
+ const getAnswer = (identifiers) => {
33
+ const { aIds, bIds, pointIds } = identifiers;
34
+ const a = reifyAlgebraic(aIds);
35
+ const b = reifyAlgebraic(bIds);
36
+ const point = PointConstructor.fromIdentifiers(pointIds);
37
+ const normal = new Vector("n", opposite(b), a).simplify();
38
+ const eqNoC = add(multiply(normal.x, "x"), multiply(normal.y, "y")).simplify({
39
+ towardsDistribute: true,
40
+ forbidFactorize: true,
41
+ });
42
+ const c = opposite(eqNoC.toDetailedEvaluation({
43
+ x: point.x,
44
+ y: point.y,
45
+ })).simplify();
46
+ return `${add(eqNoC.simplify({
47
+ towardsDistribute: true,
48
+ forbidFactorize: true,
49
+ }), c).toTex()} = 0`;
50
+ };
51
+ const getInstruction = (identifiers) => {
52
+ const { aIds, bIds, cIds, pointIds } = identifiers;
53
+ const a = reifyAlgebraic(aIds);
54
+ const b = reifyAlgebraic(bIds);
55
+ const c = reifyAlgebraic(cIds);
56
+ const point = PointConstructor.fromIdentifiers(pointIds);
57
+ return `Soit $d$ une droite passant par le point $${point.toTexWithCoords()}$ et qui est perpendiculaire à la droite $\\Delta$ dont une équation cartésienne est :
58
+
59
+ $$
60
+ \\Delta : ${add(add(multiply(a, "x"), multiply(b, "y")), c)
61
+ .simplify({
62
+ towardsDistribute: true,
63
+ forbidFactorize: true,
64
+ })
65
+ .toTex()} = 0
66
+ $$
67
+
68
+ Déterminer une équation cartésienne de la droite $d$.`;
69
+ };
70
+ const getHint = () => {
71
+ const dir = new Vector("u", opposite("b"), "a".toTree());
72
+ const normal = new Vector("n", "a".toTree(), "b".toTree());
73
+ return `Si $d$ est perpendiculaire à $\\Delta$, les vecteurs directeurs de $\\Delta$ sont des vecteurs normaux de $d$.
74
+
75
+ On rappelle que si une droite $d$ a pour équation cartésienne :
76
+
77
+ $$
78
+ ax+by+c = 0
79
+ $$
80
+
81
+ alors $${dir.toTexWithBinomCoords()}$ est un vecteur directeur de $d$, et $${normal.toTexWithBinomCoords()}$ est un vecteur normal de $d$.`;
82
+ };
83
+ const getCorrection = (identifiers) => {
84
+ const { aIds, bIds, cIds, pointIds } = identifiers;
85
+ const a = reifyAlgebraic(aIds);
86
+ const b = reifyAlgebraic(bIds);
87
+ const c = reifyAlgebraic(cIds);
88
+ const point = PointConstructor.fromIdentifiers(pointIds);
89
+ const normal = new Vector("n", opposite(b), a).simplify();
90
+ const eqNoC = add(multiply(normal.x, "x"), multiply(normal.y, "y")).simplify({
91
+ towardsDistribute: true,
92
+ forbidFactorize: true,
93
+ });
94
+ return `Puisque $d$ est perpendiculaire à $\\Delta$, les vecteurs directeurs de $\\Delta$ sont des vecteurs normaux de $d$.
95
+
96
+ Or, comme une équation cartésienne de $\\Delta$ est :
97
+
98
+ $$
99
+ \\Delta : ${add(add(multiply(a, "x"), multiply(b, "y")), c)
100
+ .simplify({
101
+ towardsDistribute: true,
102
+ forbidFactorize: true,
103
+ })
104
+ .toTex()} = 0
105
+ $$
106
+
107
+ alors un vecteur directeur de $\\Delta$ est $${normal.toTexWithBinomCoords()}$.
108
+
109
+ Donc, une équation cartésienne de $d$ est de la forme :
110
+
111
+ $$
112
+ ${eqNoC.toTex()}+c = 0
113
+ $$
114
+
115
+ Pour déterminer $c$, on utilise le fait que $d$ passe par le point $
116
+ ${point.toTexWithCoords()}$. On a donc :
117
+
118
+ $$
119
+ ${eqNoC
120
+ .toDetailedEvaluation({
121
+ x: point.x,
122
+ y: point.y,
123
+ })
124
+ .toTex()} + c = 0
125
+ $$
126
+
127
+ d'où
128
+
129
+ $$
130
+ c = ${opposite(eqNoC.toDetailedEvaluation({
131
+ x: point.x,
132
+ y: point.y,
133
+ }))
134
+ .simplify()
135
+ .toTex()}
136
+ $$
137
+
138
+ Ainsi, une équation cartésienne de $d$ est :
139
+
140
+ $$
141
+ ${getAnswer(identifiers)}
142
+ $$
143
+ `;
144
+ };
145
+ const getKeys = () => {
146
+ return ["x", "y", "equal"];
147
+ };
148
+ const isAnswerValid = (ans, { answer: _answer, pointIds, aIds, bIds }) => {
149
+ try {
150
+ const splitted = ans.split("=");
151
+ if (splitted.length !== 2)
152
+ return false;
153
+ const left = parseAlgebraic(splitted[0]);
154
+ const right = parseAlgebraic(splitted[1]);
155
+ const studentEq = substract(left, right);
156
+ const point = PointConstructor.fromIdentifiers(pointIds);
157
+ const a = reifyAlgebraic(aIds);
158
+ const b = reifyAlgebraic(bIds);
159
+ const normal = new Vector("n", opposite(b), a).simplify();
160
+ //le point est-il sur la droite ?
161
+ if (Math.abs(studentEq
162
+ .toDetailedEvaluation({
163
+ x: point.x,
164
+ y: point.y,
165
+ })
166
+ .evaluate()) > 0.0001)
167
+ return false;
168
+ //le vecteur est-il normal ?
169
+ const studentC = studentEq.toDetailedEvaluation({
170
+ x: (0).toTree(),
171
+ y: (0).toTree(),
172
+ });
173
+ const studentAXPlusBY = substract(studentEq, studentC);
174
+ const studentA = studentAXPlusBY.toDetailedEvaluation({
175
+ x: (1).toTree(),
176
+ y: (0).toTree(),
177
+ });
178
+ const studentB = studentAXPlusBY.toDetailedEvaluation({
179
+ x: (0).toTree(),
180
+ y: (1).toTree(),
181
+ });
182
+ const studentVecNormal = new Vector("m", studentA, studentB);
183
+ return studentVecNormal.isColinear(normal);
184
+ }
185
+ catch (err) {
186
+ return handleVEAError(err);
187
+ }
188
+ };
189
+ const getCartesianEquationOfLineFromPerpendicularLineQuestion = () => {
190
+ const point = PointConstructor.random("A");
191
+ const a = randint(-10, 10);
192
+ const b = randint(-10, 10, a === 0 ? [0] : undefined);
193
+ const c = randint(-10, 10);
194
+ const identifiers = {
195
+ aIds: a.toTree().toIdentifiers(),
196
+ bIds: b.toTree().toIdentifiers(),
197
+ cIds: c.toTree().toIdentifiers(),
198
+ pointIds: point.toIdentifiers(),
199
+ };
200
+ return getQuestionFromIdentifiers(identifiers);
201
+ };
202
+ const getQuestionFromIdentifiers = (identifiers) => {
203
+ return {
204
+ answer: getAnswer(identifiers),
205
+ instruction: getInstruction(identifiers),
206
+ keys: getKeys(identifiers),
207
+ answerFormat: "tex",
208
+ identifiers,
209
+ hint: getHint(identifiers),
210
+ correction: getCorrection(identifiers),
211
+ };
212
+ };
213
+ export const cartesianEquationOfLineFromPerpendicularLine = {
214
+ id: "cartesianEquationOfLineFromPerpendicularLine",
215
+ connector: "\\iff",
216
+ label: "Déterminer une équation cartésienne d'une droite perpendiculaire à une droite d'équation cartésienne donnée passant par un point donné.",
217
+ isSingleStep: true,
218
+ generator: (nb, opts) => getDistinctQuestions(() => getCartesianEquationOfLineFromPerpendicularLineQuestion(opts), nb),
219
+ qcmTimer: 60,
220
+ freeTimer: 60,
221
+ getPropositions,
222
+ isAnswerValid,
223
+ subject: "Mathématiques",
224
+ getInstruction,
225
+ getHint,
226
+ getCorrection,
227
+ getAnswer,
228
+ getQuestionFromIdentifiers,
229
+ hasHintAndCorrection: true,
230
+ };
@@ -0,0 +1,10 @@
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
+ pointIds: PointIdentifiers;
6
+ vecIds: VectorIdentifiers;
7
+ };
8
+ export declare const cartesianEquationOfLineFromPointAndNormalVector: Exercise<Identifiers>;
9
+ export {};
10
+ //# sourceMappingURL=cartesianEquationOfLineFromPointAndNormalVector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cartesianEquationOfLineFromPointAndNormalVector.d.ts","sourceRoot":"","sources":["../../../../../src/exercises/math/geometry/cartesian/cartesianEquationOfLineFromPointAndNormalVector.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAeT,MAAM,6BAA6B,CAAC;AAGrC,OAAO,EAEL,gBAAgB,EACjB,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAGL,iBAAiB,EAClB,MAAM,+BAA+B,CAAC;AAUvC,KAAK,WAAW,GAAG;IACjB,QAAQ,EAAE,gBAAgB,CAAC;IAC3B,MAAM,EAAE,iBAAiB,CAAC;CAC3B,CAAC;AAqKF,eAAO,MAAM,+CAA+C,EAAE,QAAQ,CAAC,WAAW,CAuB/E,CAAC"}
@@ -0,0 +1,167 @@
1
+ import { addValidProp, shuffleProps, propWhile, tryToAddWrongProp, } from "../../../../exercises/exercise.js";
2
+ import { getDistinctQuestions } from "../../../../exercises/utils/getDistinctQuestions.js";
3
+ import { LineConstructor } from "../../../../math/geometry/line.js";
4
+ import { PointConstructor, } from "../../../../math/geometry/point.js";
5
+ import { Vector, VectorConstructor, } from "../../../../math/geometry/vector.js";
6
+ import { equal } from "../../../../tree/nodes/equations/equalNode.js";
7
+ import { opposite } from "../../../../tree/nodes/functions/oppositeNode.js";
8
+ import { add } from "../../../../tree/nodes/operators/addNode.js";
9
+ import { multiply } from "../../../../tree/nodes/operators/multiplyNode.js";
10
+ import { substract } from "../../../../tree/nodes/operators/substractNode.js";
11
+ import { parseAlgebraic } from "../../../../tree/parsers/latexParser.js";
12
+ import { handleVEAError } from "../../../../utils/errors/handleVEAError.js";
13
+ import { alignTex } from "../../../../utils/latex/alignTex.js";
14
+ const getPropositions = (n, { answer, ...identifiers }) => {
15
+ const propositions = [];
16
+ addValidProp(propositions, answer);
17
+ const { pointIds, vecIds } = identifiers;
18
+ const point = PointConstructor.fromIdentifiers(pointIds);
19
+ const vector = VectorConstructor.fromIdentifiers(vecIds);
20
+ const goodLine = LineConstructor.fromPointAndNormalVector(point, vector);
21
+ propWhile(propositions, n, () => {
22
+ const fakePoint = PointConstructor.random("A");
23
+ const fakeVec = VectorConstructor.random("u");
24
+ const line = LineConstructor.fromPointAndNormalVector(fakePoint, fakeVec);
25
+ if (line.isCoincident(goodLine))
26
+ return;
27
+ tryToAddWrongProp(propositions, line.getCartesianEquation().toTex());
28
+ });
29
+ return shuffleProps(propositions, n);
30
+ };
31
+ const getAnswer = (identifiers) => {
32
+ //M(x;y) n(a;b)
33
+ //a*x + b*y + c = 0 donc c = - a*x - b*y
34
+ const { pointIds, vecIds } = identifiers;
35
+ const point = PointConstructor.fromIdentifiers(pointIds);
36
+ const vector = VectorConstructor.fromIdentifiers(vecIds);
37
+ const c = opposite(add(multiply(vector.x, point.x), multiply(vector.y, point.y))).simplify();
38
+ return equal(add(add(multiply(vector.x, "x"), multiply(vector.y, "y")), c).simplify({
39
+ towardsDistribute: true,
40
+ forbidFactorize: true,
41
+ }), 0).toTex();
42
+ };
43
+ const getInstruction = (identifiers) => {
44
+ const { pointIds, vecIds } = identifiers;
45
+ const point = PointConstructor.fromIdentifiers(pointIds);
46
+ const vector = VectorConstructor.fromIdentifiers(vecIds);
47
+ return `Soit $d$ une droite passant par le point $${point.toTexWithCoords()}$ et dont le vecteur $${vector.toTexWithBinomCoords()}$ est un vecteur normal.
48
+
49
+ Déterminer une équation cartésienne de $d$.`;
50
+ };
51
+ const getHint = () => {
52
+ return `Puisque la droite $d$ passe par le point $A$ et puisque $\\overrightarrow{n}$ est un vecteur normal de $d$, alors un point $M(x;y)$ appartient à $d$ si et seulement si $\\overrightarrow{n}\\cdot \\overrightarrow{AM} = 0$.`;
53
+ };
54
+ const getCorrection = (identifiers) => {
55
+ const { pointIds, vecIds } = identifiers;
56
+ const point = PointConstructor.fromIdentifiers(pointIds);
57
+ const normal = VectorConstructor.fromIdentifiers(vecIds);
58
+ const AM = new Vector("AM", substract("x", point.x), substract("y", point.y)).simplify();
59
+ return `On considère un point $M(x;y)$.
60
+
61
+ Les coordonnées du vecteur $\\overrightarrow{AM}$ sont alors $${AM.toBinomCoords().toTex()}$.
62
+
63
+ Le point $M$ appartient à la droite $d$ si et seulement si :
64
+
65
+ ${alignTex([
66
+ [
67
+ "\\overrightarrow{n}\\cdot \\overrightarrow{AM}=0",
68
+ "\\iff",
69
+ `${normal.scalarProduct(AM).toTex()} = 0`,
70
+ ],
71
+ [
72
+ "",
73
+ "\\iff",
74
+ `${normal
75
+ .scalarProduct(AM)
76
+ .simplify({ forbidFactorize: true, towardsDistribute: true })
77
+ .toTex()} = 0`,
78
+ ],
79
+ ])}
80
+
81
+ Une équation cartésienne de $d$ est donc :
82
+
83
+ $$
84
+ ${getAnswer(identifiers)}
85
+ $$
86
+ `;
87
+ };
88
+ const getKeys = () => {
89
+ return ["x", "y", "equal"];
90
+ };
91
+ const isAnswerValid = (ans, { answer: _answer, pointIds, vecIds }) => {
92
+ try {
93
+ const splitted = ans.split("=");
94
+ if (splitted.length !== 2)
95
+ return false;
96
+ const left = parseAlgebraic(splitted[0]);
97
+ const right = parseAlgebraic(splitted[1]);
98
+ const studentEq = substract(left, right);
99
+ const point = PointConstructor.fromIdentifiers(pointIds);
100
+ const normal = VectorConstructor.fromIdentifiers(vecIds);
101
+ //le point est-il sur la droite ?
102
+ if (Math.abs(studentEq
103
+ .toDetailedEvaluation({
104
+ x: point.x,
105
+ y: point.y,
106
+ })
107
+ .evaluate()) > 0.0001)
108
+ return false;
109
+ //le vecteur est-il normal ?
110
+ const studentC = studentEq.toDetailedEvaluation({
111
+ x: (0).toTree(),
112
+ y: (0).toTree(),
113
+ });
114
+ const studentAXPlusBY = substract(studentEq, studentC);
115
+ const studentA = studentAXPlusBY.toDetailedEvaluation({
116
+ x: (1).toTree(),
117
+ y: (0).toTree(),
118
+ });
119
+ const studentB = studentAXPlusBY.toDetailedEvaluation({
120
+ x: (0).toTree(),
121
+ y: (1).toTree(),
122
+ });
123
+ const studentVecNormal = new Vector("m", studentA, studentB);
124
+ return studentVecNormal.isColinear(normal);
125
+ }
126
+ catch (err) {
127
+ return handleVEAError(err);
128
+ }
129
+ };
130
+ const getCartesianEquationOfLineFromPointAndNormalVectorQuestion = () => {
131
+ const point = PointConstructor.random("A");
132
+ const vec = VectorConstructor.random("n");
133
+ const identifiers = {
134
+ pointIds: point.toIdentifiers(),
135
+ vecIds: vec.toIdentifiers(),
136
+ };
137
+ return getQuestionFromIdentifiers(identifiers);
138
+ };
139
+ const getQuestionFromIdentifiers = (identifiers) => {
140
+ return {
141
+ answer: getAnswer(identifiers),
142
+ instruction: getInstruction(identifiers),
143
+ keys: getKeys(identifiers),
144
+ answerFormat: "tex",
145
+ identifiers,
146
+ hint: getHint(identifiers),
147
+ correction: getCorrection(identifiers),
148
+ };
149
+ };
150
+ export const cartesianEquationOfLineFromPointAndNormalVector = {
151
+ id: "cartesianEquationOfLineFromPointAndNormalVector",
152
+ connector: "\\iff",
153
+ label: "Déterminer une équation cartésienne d'une droite à partir d'un point et d'un vecteur normal",
154
+ isSingleStep: true,
155
+ generator: (nb, opts) => getDistinctQuestions(() => getCartesianEquationOfLineFromPointAndNormalVectorQuestion(opts), nb),
156
+ qcmTimer: 60,
157
+ freeTimer: 60,
158
+ getPropositions,
159
+ isAnswerValid,
160
+ subject: "Mathématiques",
161
+ getInstruction,
162
+ getHint,
163
+ getCorrection,
164
+ getAnswer,
165
+ getQuestionFromIdentifiers,
166
+ hasHintAndCorrection: true,
167
+ };
@@ -14,4 +14,7 @@ export * from "./placeAbscissOnSemiLine.js";
14
14
  export * from "./placeAbscissOnSemiLineV2.js";
15
15
  export * from "./cartesianFromVectorAndPoint.js";
16
16
  export * from "./cartesianFromTwoPoints.js";
17
+ export * from "./normalVectorFromCartesianLineEquation.js";
18
+ export * from "./cartesianEquationOfLineFromPointAndNormalVector.js";
19
+ export * from "./cartesianEquationOfLineFromPerpendicularLine.js";
17
20
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/exercises/math/geometry/cartesian/index.ts"],"names":[],"mappings":"AAAA,cAAc,+BAA+B,CAAC;AAC9C,cAAc,eAAe,CAAC;AAC9B,cAAc,8BAA8B,CAAC;AAC7C,cAAc,uBAAuB,CAAC;AACtC,cAAc,sBAAsB,CAAC;AACrC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,qBAAqB,CAAC;AACpC,cAAc,kBAAkB,CAAC;AACjC,cAAc,oCAAoC,CAAC;AAEnD,cAAc,wBAAwB,CAAC;AACvC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,kCAAkC,CAAC;AACjD,cAAc,6BAA6B,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/exercises/math/geometry/cartesian/index.ts"],"names":[],"mappings":"AAAA,cAAc,+BAA+B,CAAC;AAC9C,cAAc,eAAe,CAAC;AAC9B,cAAc,8BAA8B,CAAC;AAC7C,cAAc,uBAAuB,CAAC;AACtC,cAAc,sBAAsB,CAAC;AACrC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,qBAAqB,CAAC;AACpC,cAAc,kBAAkB,CAAC;AACjC,cAAc,oCAAoC,CAAC;AAEnD,cAAc,wBAAwB,CAAC;AACvC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,kCAAkC,CAAC;AACjD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,4CAA4C,CAAC;AAC3D,cAAc,sDAAsD,CAAC;AACrE,cAAc,mDAAmD,CAAC"}
@@ -15,3 +15,6 @@ export * from "./placeAbscissOnSemiLine.js";
15
15
  export * from "./placeAbscissOnSemiLineV2.js";
16
16
  export * from "./cartesianFromVectorAndPoint.js";
17
17
  export * from "./cartesianFromTwoPoints.js";
18
+ export * from "./normalVectorFromCartesianLineEquation.js";
19
+ export * from "./cartesianEquationOfLineFromPointAndNormalVector.js";
20
+ export * from "./cartesianEquationOfLineFromPerpendicularLine.js";
@@ -0,0 +1,10 @@
1
+ import { Exercise } from "../../../../exercises/exercise.js";
2
+ import { NodeIdentifiers } from "../../../../tree/nodes/nodeConstructor.js";
3
+ type Identifiers = {
4
+ aIds: NodeIdentifiers;
5
+ bIds: NodeIdentifiers;
6
+ cIds: NodeIdentifiers;
7
+ };
8
+ export declare const normalVectorFromCartesianLineEquation: Exercise<Identifiers>;
9
+ export {};
10
+ //# sourceMappingURL=normalVectorFromCartesianLineEquation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"normalVectorFromCartesianLineEquation.d.ts","sourceRoot":"","sources":["../../../../../src/exercises/math/geometry/cartesian/normalVectorFromCartesianLineEquation.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAeT,MAAM,6BAA6B,CAAC;AAMrC,OAAO,EACL,eAAe,EAEhB,MAAM,qCAAqC,CAAC;AAQ7C,KAAK,WAAW,GAAG;IACjB,IAAI,EAAE,eAAe,CAAC;IACtB,IAAI,EAAE,eAAe,CAAC;IACtB,IAAI,EAAE,eAAe,CAAC;CACvB,CAAC;AA6HF,eAAO,MAAM,qCAAqC,EAAE,QAAQ,CAAC,WAAW,CAsBvE,CAAC"}
@@ -0,0 +1,131 @@
1
+ import { addValidProp, shuffleProps, propWhile, tryToAddWrongProp, } from "../../../../exercises/exercise.js";
2
+ import { getDistinctQuestions } from "../../../../exercises/utils/getDistinctQuestions.js";
3
+ import { Vector, VectorConstructor } from "../../../../math/geometry/vector.js";
4
+ import { randint } from "../../../../math/utils/random/randint.js";
5
+ import { equal } from "../../../../tree/nodes/equations/equalNode.js";
6
+ import { opposite } from "../../../../tree/nodes/functions/oppositeNode.js";
7
+ import { reifyAlgebraic, } from "../../../../tree/nodes/nodeConstructor.js";
8
+ import { add } from "../../../../tree/nodes/operators/addNode.js";
9
+ import { isBinomialCoefficientNode } from "../../../../tree/nodes/operators/binomialCoefficientNode.js";
10
+ import { multiply } from "../../../../tree/nodes/operators/multiplyNode.js";
11
+ import { parseAlgebraic } from "../../../../tree/parsers/latexParser.js";
12
+ import { vectorParser } from "../../../../tree/parsers/vectorParser.js";
13
+ import { handleVEAError } from "../../../../utils/errors/handleVEAError.js";
14
+ const getPropositions = (n, { answer, aIds, bIds }) => {
15
+ const propositions = [];
16
+ addValidProp(propositions, answer);
17
+ const a = reifyAlgebraic(aIds);
18
+ const b = reifyAlgebraic(bIds);
19
+ const solVec = new Vector("n", a, b);
20
+ const dirVec = new Vector("d", opposite(b), a).simplify();
21
+ if (!dirVec.isColinear(solVec))
22
+ tryToAddWrongProp(propositions, dirVec.toBinomCoords().toTex());
23
+ const fakeVec = new Vector("d", b, a).simplify();
24
+ if (!fakeVec.isColinear(solVec))
25
+ tryToAddWrongProp(propositions, fakeVec.toBinomCoords().toTex());
26
+ propWhile(propositions, n, () => {
27
+ const rand = VectorConstructor.random("a");
28
+ if (!rand.isColinear(solVec))
29
+ tryToAddWrongProp(propositions, rand.toBinomCoords().toTex());
30
+ });
31
+ return shuffleProps(propositions, n);
32
+ };
33
+ const getAnswer = (identifiers) => {
34
+ const { aIds, bIds } = identifiers;
35
+ const a = reifyAlgebraic(aIds);
36
+ const b = reifyAlgebraic(bIds);
37
+ const vec = new Vector("n", a, b);
38
+ return vec.toBinomCoords().toTex();
39
+ };
40
+ const getInstruction = (identifiers) => {
41
+ const { aIds, bIds, cIds } = identifiers;
42
+ const a = reifyAlgebraic(aIds);
43
+ const b = reifyAlgebraic(bIds);
44
+ const c = reifyAlgebraic(cIds);
45
+ const eq = equal(add(add(multiply(a, "x"), multiply(b, "y")), c), 0).simplify({ towardsDistribute: true, forbidFactorize: true });
46
+ return `Déterminer les coordonnées d'un vecteur normal à la droite $d$ d'équation cartésienne :
47
+
48
+ $$
49
+ d: ${eq.toTex()}
50
+ $$`;
51
+ };
52
+ const getHint = () => {
53
+ const vec = new Vector("n", "a".toTree(), "b".toTree());
54
+ return `Une droite $d$ a pour équation cartésienne $ax+by+c = 0$ si et seulement si $${vec.toTexWithBinomCoords()}$ est un vecteur normal à $d$.`;
55
+ };
56
+ const getCorrection = (identifiers) => {
57
+ const { aIds, bIds, cIds } = identifiers;
58
+ const a = reifyAlgebraic(aIds);
59
+ const b = reifyAlgebraic(bIds);
60
+ const c = reifyAlgebraic(cIds);
61
+ const vec = new Vector("n", "a".toTree(), "b".toTree());
62
+ return `Une droite $d$ a pour équation cartésienne $ax+by+c = 0$ si et seulement si $${vec.toTexWithBinomCoords()}$ est un vecteur normal à $d$.
63
+
64
+ Ici, on identifie les coefficients : $a = ${a.toTex()}$, $b = ${b.toTex()}$ et $c = ${c.toTex()}$.
65
+
66
+ On en conclut qu'un vecteur normal à $d$ est $\\overrightarrow{n}$ de coordonnées $${getAnswer(identifiers)}$.`;
67
+ };
68
+ const getKeys = () => {
69
+ return ["binom", "semicolon"];
70
+ };
71
+ const isAnswerValid = (ans, { answer: _answer, aIds, bIds }) => {
72
+ try {
73
+ const solVector = new Vector("n", reifyAlgebraic(aIds), reifyAlgebraic(bIds));
74
+ if (ans.includes("binom")) {
75
+ const parsed = parseAlgebraic(ans);
76
+ if (!isBinomialCoefficientNode(parsed))
77
+ return false;
78
+ const vec = new Vector("u", parsed.leftChild, parsed.rightChild);
79
+ return solVector.isColinear(vec);
80
+ }
81
+ else {
82
+ const vec = vectorParser(ans);
83
+ if (!vec)
84
+ return false;
85
+ return solVector.isColinear(vec);
86
+ }
87
+ }
88
+ catch (err) {
89
+ return handleVEAError(err);
90
+ }
91
+ };
92
+ const getNormalVectorFromCartesianLineEquationQuestion = () => {
93
+ const a = randint(-10, 10);
94
+ const b = randint(-10, 10, a === 0 ? [0] : undefined);
95
+ const c = randint(-10, 10);
96
+ const identifiers = {
97
+ aIds: a.toTree().toIdentifiers(),
98
+ bIds: b.toTree().toIdentifiers(),
99
+ cIds: c.toTree().toIdentifiers(),
100
+ };
101
+ return getQuestionFromIdentifiers(identifiers);
102
+ };
103
+ const getQuestionFromIdentifiers = (identifiers) => {
104
+ return {
105
+ answer: getAnswer(identifiers),
106
+ instruction: getInstruction(identifiers),
107
+ keys: getKeys(identifiers),
108
+ answerFormat: "tex",
109
+ identifiers,
110
+ hint: getHint(identifiers),
111
+ correction: getCorrection(identifiers),
112
+ };
113
+ };
114
+ export const normalVectorFromCartesianLineEquation = {
115
+ id: "normalVectorFromCartesianLineEquation",
116
+ connector: "=",
117
+ label: "Déterminer les coordonnées d'un vecteur normal à partir d'une équation cartésienne d'une droite",
118
+ isSingleStep: true,
119
+ generator: (nb, opts) => getDistinctQuestions(() => getNormalVectorFromCartesianLineEquationQuestion(opts), nb),
120
+ qcmTimer: 60,
121
+ freeTimer: 60,
122
+ getPropositions,
123
+ isAnswerValid,
124
+ subject: "Mathématiques",
125
+ getInstruction,
126
+ getHint,
127
+ getCorrection,
128
+ getAnswer,
129
+ getQuestionFromIdentifiers,
130
+ hasHintAndCorrection: true,
131
+ };
@@ -0,0 +1,2 @@
1
+ export * from "./isPointOnCircleFromCartesianEquation.js";
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/exercises/math/geometry/circles/index.ts"],"names":[],"mappings":"AAAA,cAAc,2CAA2C,CAAC"}
@@ -0,0 +1 @@
1
+ export * from "./isPointOnCircleFromCartesianEquation.js";
@@ -0,0 +1,11 @@
1
+ import { Exercise } from "../../../../exercises/exercise.js";
2
+ import { PointIdentifiers } from "../../../../math/geometry/point.js";
3
+ import { NodeIdentifiers } from "../../../../tree/nodes/nodeConstructor.js";
4
+ type Identifiers = {
5
+ pointIds: PointIdentifiers;
6
+ radiusIds: NodeIdentifiers;
7
+ centreIds: PointIdentifiers;
8
+ };
9
+ export declare const isPointOnCircleFromCartesianEquation: Exercise<Identifiers>;
10
+ export {};
11
+ //# sourceMappingURL=isPointOnCircleFromCartesianEquation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isPointOnCircleFromCartesianEquation.d.ts","sourceRoot":"","sources":["../../../../../src/exercises/math/geometry/circles/isPointOnCircleFromCartesianEquation.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAYT,MAAM,6BAA6B,CAAC;AAErC,OAAO,EAEL,gBAAgB,EACjB,MAAM,8BAA8B,CAAC;AAGtC,OAAO,EACL,eAAe,EAEhB,MAAM,qCAAqC,CAAC;AAU7C,KAAK,WAAW,GAAG;IACjB,QAAQ,EAAE,gBAAgB,CAAC;IAC3B,SAAS,EAAE,eAAe,CAAC;IAC3B,SAAS,EAAE,gBAAgB,CAAC;CAC7B,CAAC;AA8HF,eAAO,MAAM,oCAAoC,EAAE,QAAQ,CAAC,WAAW,CAqBtE,CAAC"}