math-exercises 1.2.8 → 1.2.11

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 (216) hide show
  1. package/lib/exercises/calcul/addAndSub.js +40 -0
  2. package/lib/exercises/calcul/fractions/fractionAndIntegerDivision.js +35 -0
  3. package/lib/exercises/calcul/fractions/fractionAndIntegerProduct.js +31 -0
  4. package/lib/exercises/calcul/fractions/fractionAndIntegerSum.js +32 -0
  5. package/lib/exercises/calcul/fractions/fractionsDivision.js +29 -0
  6. package/lib/exercises/calcul/fractions/fractionsProduct.js +29 -0
  7. package/lib/exercises/calcul/fractions/fractionsSum.js +29 -0
  8. package/lib/exercises/calcul/fractions/simplifyFraction.js +25 -0
  9. package/lib/exercises/calcul/operations/operationsPriorities.js +88 -0
  10. package/lib/exercises/calcul/operations/operationsPrioritiesWithoutRelative.js +111 -0
  11. package/{src → lib}/exercises/calcul/operationsPriorities.js +88 -89
  12. package/{src → lib}/exercises/calcul/rounding/rounding.js +86 -87
  13. package/{src → lib}/exercises/calculLitteral/distributivity/allIdentities.js +27 -27
  14. package/lib/exercises/calculLitteral/distributivity/doubleDistributivity.js +31 -0
  15. package/lib/exercises/calculLitteral/distributivity/firstIdentity.js +32 -0
  16. package/lib/exercises/calculLitteral/distributivity/secondIdentity.js +33 -0
  17. package/lib/exercises/calculLitteral/distributivity/simpleDistributivity.js +33 -0
  18. package/lib/exercises/calculLitteral/distributivity/thirdIdentity.js +32 -0
  19. package/lib/exercises/calculLitteral/equation/equationType1Exercise.js +38 -0
  20. package/lib/exercises/calculLitteral/equation/equationType2Exercise.js +41 -0
  21. package/lib/exercises/calculLitteral/equation/equationType3Exercise.js +42 -0
  22. package/lib/exercises/calculLitteral/equation/equationType4Exercise.js +44 -0
  23. package/lib/exercises/calculLitteral/factorisation/factoType1Exercise.js +39 -0
  24. package/{src → lib}/exercises/exercise.js +7 -7
  25. package/lib/exercises/exercises.js +95 -0
  26. package/lib/exercises/geometry/cartesian/midpoint.js +29 -0
  27. package/lib/exercises/geometry/vectors/scalarProductViaCoords.js +29 -0
  28. package/lib/exercises/geometry/vectors/scalarProductViaNorms.js +27 -0
  29. package/lib/exercises/powers/powersDivision.js +45 -0
  30. package/lib/exercises/powers/powersOfTenToDecimal.js +33 -0
  31. package/lib/exercises/powers/powersPower.js +44 -0
  32. package/lib/exercises/powers/powersProduct.js +45 -0
  33. package/lib/exercises/powers/scientificToDecimal.js +38 -0
  34. package/{src → lib}/exercises/squareRoots/simpifySquareRoot.js +28 -28
  35. package/lib/exercises/utils/getDistinctQuestions.js +16 -0
  36. package/lib/geometry/point.js +27 -0
  37. package/lib/geometry/vector.js +31 -0
  38. package/lib/index.js +10 -0
  39. package/lib/mathutils/arithmetic/coprimesOf.js +13 -0
  40. package/lib/mathutils/arithmetic/dividersOf.js +12 -0
  41. package/{src → lib}/mathutils/arithmetic/gcd.js +7 -7
  42. package/{src → lib}/mathutils/arithmetic/isSquare.js +7 -7
  43. package/{src → lib}/mathutils/arithmetic/lcd.js +12 -12
  44. package/lib/mathutils/arithmetic/nonCoprimesOf.js +13 -0
  45. package/lib/mathutils/arithmetic/nonDividersOf.js +14 -0
  46. package/{src → lib}/mathutils/arithmetic/primeFactors.js +22 -22
  47. package/lib/mathutils/decimals/decimalPartLengthOf.js +14 -0
  48. package/lib/mathutils/random/randTupleInt.js +30 -0
  49. package/{src → lib}/mathutils/random/randint.js +18 -18
  50. package/{src → lib}/mathutils/round.js +8 -8
  51. package/{src → lib}/numbers/decimals/decimal.js +140 -144
  52. package/{src → lib}/numbers/epsilon.js +10 -10
  53. package/{src → lib}/numbers/integer/integer.js +68 -72
  54. package/{src → lib}/numbers/integer/power.js +52 -53
  55. package/{src → lib}/numbers/nombre.js +10 -10
  56. package/lib/numbers/rationals/rational.js +113 -0
  57. package/lib/numbers/reals/real.js +16 -0
  58. package/lib/numbers/reals/squareRoot.js +63 -0
  59. package/lib/polynomials/affine.js +42 -0
  60. package/lib/polynomials/polynomial.js +125 -0
  61. package/lib/sets/discreteSet.js +28 -0
  62. package/{src/sets/emptySet.ts → lib/sets/emptySet.js} +6 -6
  63. package/{src → lib}/sets/intervals/intervals.js +108 -113
  64. package/lib/sets/intervals/union.js +1 -0
  65. package/lib/sets/mathSet.js +10 -0
  66. package/lib/sets/mathSetInterface.js +2 -0
  67. package/{src → lib}/tree/nodes/functions/functionNode.js +18 -19
  68. package/lib/tree/nodes/functions/oppositeNode.js +13 -0
  69. package/lib/tree/nodes/functions/sqrtNode.js +15 -0
  70. package/{src → lib}/tree/nodes/node.js +10 -10
  71. package/lib/tree/nodes/numbers/numberNode.js +18 -0
  72. package/lib/tree/nodes/operators/addNode.js +15 -0
  73. package/lib/tree/nodes/operators/divideNode.js +17 -0
  74. package/lib/tree/nodes/operators/equalNode.js +13 -0
  75. package/lib/tree/nodes/operators/fractionNode.js +17 -0
  76. package/lib/tree/nodes/operators/multiplyNode.js +13 -0
  77. package/{src → lib}/tree/nodes/operators/operatorNode.js +35 -37
  78. package/lib/tree/nodes/operators/powerNode.js +13 -0
  79. package/lib/tree/nodes/operators/substractNode.js +13 -0
  80. package/lib/tree/nodes/variables/variableNode.js +16 -0
  81. package/{src → lib}/tree/parsers/derivateParser.js +60 -60
  82. package/{src → lib}/tree/parsers/latexParser.js +117 -117
  83. package/lib/utils/arrayEqual.js +13 -0
  84. package/{src → lib}/utils/coin.js +7 -7
  85. package/{src → lib}/utils/random.js +7 -7
  86. package/lib/utils/shuffle.js +15 -0
  87. package/package.json +35 -28
  88. package/nodemon.json +0 -5
  89. package/src/exercises/calcul/addAndSub.js +0 -40
  90. package/src/exercises/calcul/addAndSub.ts +0 -39
  91. package/src/exercises/calcul/fractions/fractionAndIntegerDivision.js +0 -35
  92. package/src/exercises/calcul/fractions/fractionAndIntegerDivision.ts +0 -36
  93. package/src/exercises/calcul/fractions/fractionAndIntegerProduct.js +0 -31
  94. package/src/exercises/calcul/fractions/fractionAndIntegerProduct.ts +0 -32
  95. package/src/exercises/calcul/fractions/fractionAndIntegerSum.js +0 -32
  96. package/src/exercises/calcul/fractions/fractionAndIntegerSum.ts +0 -31
  97. package/src/exercises/calcul/fractions/fractionsDivision.js +0 -29
  98. package/src/exercises/calcul/fractions/fractionsDivision.ts +0 -30
  99. package/src/exercises/calcul/fractions/fractionsProduct.js +0 -29
  100. package/src/exercises/calcul/fractions/fractionsProduct.ts +0 -29
  101. package/src/exercises/calcul/fractions/fractionsSum.js +0 -29
  102. package/src/exercises/calcul/fractions/fractionsSum.ts +0 -28
  103. package/src/exercises/calcul/fractions/simplifyFraction.js +0 -25
  104. package/src/exercises/calcul/fractions/simplifyFraction.ts +0 -24
  105. package/src/exercises/calcul/operationsPriorities.ts +0 -115
  106. package/src/exercises/calcul/rounding/rounding.ts +0 -87
  107. package/src/exercises/calculLitteral/distributivity/allIdentities.ts +0 -26
  108. package/src/exercises/calculLitteral/distributivity/doubleDistributivity.js +0 -31
  109. package/src/exercises/calculLitteral/distributivity/doubleDistributivity.ts +0 -33
  110. package/src/exercises/calculLitteral/distributivity/firstIdentity.js +0 -32
  111. package/src/exercises/calculLitteral/distributivity/firstIdentity.ts +0 -33
  112. package/src/exercises/calculLitteral/distributivity/secondIdentity.js +0 -33
  113. package/src/exercises/calculLitteral/distributivity/secondIdentity.ts +0 -35
  114. package/src/exercises/calculLitteral/distributivity/simpleDistributivity.js +0 -33
  115. package/src/exercises/calculLitteral/distributivity/simpleDistributivity.ts +0 -33
  116. package/src/exercises/calculLitteral/distributivity/thirdIdentity.js +0 -32
  117. package/src/exercises/calculLitteral/distributivity/thirdIdentity.ts +0 -34
  118. package/src/exercises/calculLitteral/equation/equationType1Exercise.js +0 -38
  119. package/src/exercises/calculLitteral/equation/equationType1Exercise.ts +0 -38
  120. package/src/exercises/calculLitteral/equation/equationType2Exercise.js +0 -41
  121. package/src/exercises/calculLitteral/equation/equationType2Exercise.ts +0 -41
  122. package/src/exercises/calculLitteral/equation/equationType3Exercise.js +0 -42
  123. package/src/exercises/calculLitteral/equation/equationType3Exercise.ts +0 -43
  124. package/src/exercises/calculLitteral/equation/equationType4Exercise.js +0 -44
  125. package/src/exercises/calculLitteral/equation/equationType4Exercise.ts +0 -46
  126. package/src/exercises/calculLitteral/factorisation/factoType1Exercise.js +0 -39
  127. package/src/exercises/calculLitteral/factorisation/factoType1Exercise.ts +0 -54
  128. package/src/exercises/exercise.ts +0 -22
  129. package/src/exercises/exercises.js +0 -85
  130. package/src/exercises/exercises.ts +0 -94
  131. package/src/exercises/powers/powersDivision.js +0 -46
  132. package/src/exercises/powers/powersDivision.ts +0 -51
  133. package/src/exercises/powers/powersOfTenToDecimal.js +0 -33
  134. package/src/exercises/powers/powersOfTenToDecimal.ts +0 -37
  135. package/src/exercises/powers/powersPower.js +0 -45
  136. package/src/exercises/powers/powersPower.ts +0 -55
  137. package/src/exercises/powers/powersProduct.js +0 -46
  138. package/src/exercises/powers/powersProduct.ts +0 -51
  139. package/src/exercises/powers/scientificToDecimal.js +0 -38
  140. package/src/exercises/powers/scientificToDecimal.ts +0 -44
  141. package/src/exercises/squareRoots/simpifySquareRoot.ts +0 -27
  142. package/src/exercises/utils/getDistinctQuestions.js +0 -18
  143. package/src/exercises/utils/getDistinctQuestions.ts +0 -14
  144. package/src/index.js +0 -5
  145. package/src/index.ts +0 -13
  146. package/src/mathutils/arithmetic/coprimesOf.js +0 -13
  147. package/src/mathutils/arithmetic/coprimesOf.ts +0 -9
  148. package/src/mathutils/arithmetic/dividersOf.ts +0 -7
  149. package/src/mathutils/arithmetic/gcd.ts +0 -3
  150. package/src/mathutils/arithmetic/isSquare.ts +0 -3
  151. package/src/mathutils/arithmetic/lcd.ts +0 -7
  152. package/src/mathutils/arithmetic/nonCoprimesOf.ts +0 -9
  153. package/src/mathutils/arithmetic/nonDividersOf.ts +0 -12
  154. package/src/mathutils/arithmetic/primeFactors.ts +0 -18
  155. package/src/mathutils/decimals/decimalPartLengthOf.ts +0 -10
  156. package/src/mathutils/random/randint.ts +0 -12
  157. package/src/mathutils/round.ts +0 -5
  158. package/src/numbers/decimals/decimal.ts +0 -140
  159. package/src/numbers/epsilon.ts +0 -7
  160. package/src/numbers/integer/integer.ts +0 -72
  161. package/src/numbers/integer/power.ts +0 -49
  162. package/src/numbers/nombre.ts +0 -15
  163. package/src/numbers/number.js +0 -8
  164. package/src/numbers/rationals/rational.js +0 -128
  165. package/src/numbers/rationals/rational.ts +0 -122
  166. package/src/numbers/reals/real.js +0 -17
  167. package/src/numbers/reals/real.ts +0 -17
  168. package/src/numbers/reals/squareRoot.js +0 -85
  169. package/src/numbers/reals/squareRoot.ts +0 -70
  170. package/src/polynomials/affine.js +0 -71
  171. package/src/polynomials/affine.ts +0 -60
  172. package/src/polynomials/polynomial.js +0 -128
  173. package/src/polynomials/polynomial.ts +0 -137
  174. package/src/sets/discreteSet.js +0 -30
  175. package/src/sets/discreteSet.ts +0 -30
  176. package/src/sets/intervals/intervals.ts +0 -122
  177. package/src/sets/intervals/union.ts +0 -0
  178. package/src/sets/mathSet.js +0 -11
  179. package/src/sets/mathSet.ts +0 -12
  180. package/src/sets/mathSetInterface.js +0 -2
  181. package/src/sets/mathSetInterface.ts +0 -10
  182. package/src/tree/latexParser/latexParse.js +0 -117
  183. package/src/tree/nodes/functions/functionNode.ts +0 -18
  184. package/src/tree/nodes/functions/oppositeNode.js +0 -30
  185. package/src/tree/nodes/functions/oppositeNode.ts +0 -12
  186. package/src/tree/nodes/functions/sqrtNode.js +0 -33
  187. package/src/tree/nodes/functions/sqrtNode.ts +0 -12
  188. package/src/tree/nodes/node.ts +0 -12
  189. package/src/tree/nodes/numbers/numberNode.js +0 -16
  190. package/src/tree/nodes/numbers/numberNode.ts +0 -16
  191. package/src/tree/nodes/operators/addNode.js +0 -33
  192. package/src/tree/nodes/operators/addNode.ts +0 -13
  193. package/src/tree/nodes/operators/divideNode.js +0 -34
  194. package/src/tree/nodes/operators/divideNode.ts +0 -16
  195. package/src/tree/nodes/operators/equalNode.js +0 -30
  196. package/src/tree/nodes/operators/equalNode.ts +0 -11
  197. package/src/tree/nodes/operators/fractionNode.js +0 -34
  198. package/src/tree/nodes/operators/fractionNode.ts +0 -16
  199. package/src/tree/nodes/operators/multiplyNode.js +0 -30
  200. package/src/tree/nodes/operators/multiplyNode.ts +0 -12
  201. package/src/tree/nodes/operators/operatorNode.ts +0 -36
  202. package/src/tree/nodes/operators/oppositeNode.js +0 -18
  203. package/src/tree/nodes/operators/powerNode.js +0 -30
  204. package/src/tree/nodes/operators/powerNode.ts +0 -12
  205. package/src/tree/nodes/operators/substractNode.js +0 -30
  206. package/src/tree/nodes/operators/substractNode.ts +0 -11
  207. package/src/tree/nodes/variables/variableNode.js +0 -17
  208. package/src/tree/nodes/variables/variableNode.ts +0 -15
  209. package/src/tree/parsers/derivateParser.ts +0 -66
  210. package/src/tree/parsers/latexParser.ts +0 -122
  211. package/src/utils/coin.ts +0 -3
  212. package/src/utils/random.ts +0 -3
  213. package/src/utils/randomIn.js +0 -7
  214. package/src/utils/shuffle.js +0 -24
  215. package/src/utils/shuffle.ts +0 -11
  216. package/tsconfig.json +0 -110
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getEquationType2ExerciseQuestion = exports.equationType2Exercise = void 0;
4
+ const integer_1 = require("../../../numbers/integer/integer");
5
+ const rational_1 = require("../../../numbers/rationals/rational");
6
+ const affine_1 = require("../../../polynomials/affine");
7
+ const discreteSet_1 = require("../../../sets/discreteSet");
8
+ const intervals_1 = require("../../../sets/intervals/intervals");
9
+ const latexParser_1 = require("../../../tree/parsers/latexParser");
10
+ const equalNode_1 = require("../../../tree/nodes/operators/equalNode");
11
+ const variableNode_1 = require("../../../tree/nodes/variables/variableNode");
12
+ const getDistinctQuestions_1 = require("../../utils/getDistinctQuestions");
13
+ /**
14
+ * type ax=b
15
+ */
16
+ exports.equationType2Exercise = {
17
+ id: "equa2",
18
+ connector: "\\iff",
19
+ instruction: "Résoudre : ",
20
+ label: "Equations $ax=b$",
21
+ levels: ["4", "3", "2"],
22
+ section: "Calcul littéral",
23
+ isSingleStep: true,
24
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getEquationType2ExerciseQuestion, nb),
25
+ };
26
+ function getEquationType2ExerciseQuestion() {
27
+ const interval = new intervals_1.Interval("[[-10; 10]]");
28
+ const intervalStar = new intervals_1.Interval("[[-10; 10]]").difference(new discreteSet_1.DiscreteSet([new integer_1.Integer(0)]));
29
+ const b = interval.getRandomElement();
30
+ const a = intervalStar.getRandomElement();
31
+ const solution = new rational_1.Rational(b.value, a.value).simplify();
32
+ const affine = new affine_1.Affine(a.value, 0).toTree();
33
+ const tree = new equalNode_1.EqualNode(affine, b.toTree());
34
+ const answer = new equalNode_1.EqualNode(new variableNode_1.VariableNode("x"), solution.toTree());
35
+ const question = {
36
+ startStatement: (0, latexParser_1.latexParser)(tree),
37
+ answer: (0, latexParser_1.latexParser)(answer),
38
+ };
39
+ return question;
40
+ }
41
+ exports.getEquationType2ExerciseQuestion = getEquationType2ExerciseQuestion;
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getEquationType3ExerciseQuestion = exports.equationType3Exercise = void 0;
4
+ const integer_1 = require("../../../numbers/integer/integer");
5
+ const rational_1 = require("../../../numbers/rationals/rational");
6
+ const affine_1 = require("../../../polynomials/affine");
7
+ const discreteSet_1 = require("../../../sets/discreteSet");
8
+ const intervals_1 = require("../../../sets/intervals/intervals");
9
+ const latexParser_1 = require("../../../tree/parsers/latexParser");
10
+ const equalNode_1 = require("../../../tree/nodes/operators/equalNode");
11
+ const variableNode_1 = require("../../../tree/nodes/variables/variableNode");
12
+ const getDistinctQuestions_1 = require("../../utils/getDistinctQuestions");
13
+ /**
14
+ * type ax+b=c
15
+ */
16
+ exports.equationType3Exercise = {
17
+ id: "equa3",
18
+ connector: "\\iff",
19
+ instruction: "Résoudre : ",
20
+ label: "Equations $ax+b=c$",
21
+ levels: ["4", "3", "2"],
22
+ section: "Calcul littéral",
23
+ isSingleStep: false,
24
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getEquationType3ExerciseQuestion, nb),
25
+ };
26
+ function getEquationType3ExerciseQuestion() {
27
+ const interval = new intervals_1.Interval("[[-10; 10]]");
28
+ const intervalStar = new intervals_1.Interval("[[-10; 10]]").difference(new discreteSet_1.DiscreteSet([new integer_1.Integer(0)]));
29
+ const b = intervalStar.getRandomElement();
30
+ const a = intervalStar.getRandomElement();
31
+ const c = interval.getRandomElement();
32
+ const affine = new affine_1.Affine(a.value, b.value).toTree();
33
+ const solution = new rational_1.Rational(c.value - b.value, a.value).simplify();
34
+ const statementTree = new equalNode_1.EqualNode(affine, c.toTree());
35
+ const answerTree = new equalNode_1.EqualNode(new variableNode_1.VariableNode("x"), solution.toTree());
36
+ const question = {
37
+ startStatement: (0, latexParser_1.latexParser)(statementTree),
38
+ answer: (0, latexParser_1.latexParser)(answerTree),
39
+ };
40
+ return question;
41
+ }
42
+ exports.getEquationType3ExerciseQuestion = getEquationType3ExerciseQuestion;
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getEquationType4ExerciseQuestion = exports.equationType4Exercise = void 0;
4
+ const integer_1 = require("../../../numbers/integer/integer");
5
+ const rational_1 = require("../../../numbers/rationals/rational");
6
+ const affine_1 = require("../../../polynomials/affine");
7
+ const discreteSet_1 = require("../../../sets/discreteSet");
8
+ const intervals_1 = require("../../../sets/intervals/intervals");
9
+ const latexParser_1 = require("../../../tree/parsers/latexParser");
10
+ const equalNode_1 = require("../../../tree/nodes/operators/equalNode");
11
+ const variableNode_1 = require("../../../tree/nodes/variables/variableNode");
12
+ const getDistinctQuestions_1 = require("../../utils/getDistinctQuestions");
13
+ /**
14
+ * type ax+b=cx+d
15
+ */
16
+ exports.equationType4Exercise = {
17
+ id: "equa4",
18
+ connector: "\\iff",
19
+ instruction: "Résoudre : ",
20
+ label: "Equations $ax+b=cx+d$",
21
+ levels: ["4", "3", "2"],
22
+ section: "Calcul littéral",
23
+ isSingleStep: false,
24
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getEquationType4ExerciseQuestion, nb),
25
+ };
26
+ function getEquationType4ExerciseQuestion() {
27
+ const interval = new intervals_1.Interval("[[-10; 10]]");
28
+ const intervalStar = new intervals_1.Interval("[[-10; 10]]").difference(new discreteSet_1.DiscreteSet([new integer_1.Integer(0)]));
29
+ const a = intervalStar.getRandomElement();
30
+ const b = interval.getRandomElement();
31
+ const intervalC = new intervals_1.Interval("[[-10; 10]]").difference(new discreteSet_1.DiscreteSet([new integer_1.Integer(0), new integer_1.Integer(a.value)]));
32
+ const c = intervalC.getRandomElement();
33
+ const d = interval.getRandomElement();
34
+ const affines = [new affine_1.Affine(a.value, b.value), new affine_1.Affine(c.value, d.value)];
35
+ const solution = new rational_1.Rational(d.value - b.value, a.value - c.value).simplify();
36
+ const statementTree = new equalNode_1.EqualNode(affines[0].toTree(), affines[1].toTree());
37
+ const answerTree = new equalNode_1.EqualNode(new variableNode_1.VariableNode("x"), solution.toTree());
38
+ const question = {
39
+ startStatement: (0, latexParser_1.latexParser)(statementTree),
40
+ answer: (0, latexParser_1.latexParser)(answerTree),
41
+ };
42
+ return question;
43
+ }
44
+ exports.getEquationType4ExerciseQuestion = getEquationType4ExerciseQuestion;
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getFactoType1Question = exports.factoType1Exercise = void 0;
4
+ const affine_1 = require("../../../polynomials/affine");
5
+ const latexParser_1 = require("../../../tree/parsers/latexParser");
6
+ const addNode_1 = require("../../../tree/nodes/operators/addNode");
7
+ const multiplyNode_1 = require("../../../tree/nodes/operators/multiplyNode");
8
+ const substractNode_1 = require("../../../tree/nodes/operators/substractNode");
9
+ const random_1 = require("../../../utils/random");
10
+ const shuffle_1 = require("../../../utils/shuffle");
11
+ const getDistinctQuestions_1 = require("../../utils/getDistinctQuestions");
12
+ /**
13
+ * type (ax+b)(cx+d) ± (ax+b)(ex+f)
14
+ */
15
+ exports.factoType1Exercise = {
16
+ id: "facto1",
17
+ connector: "=",
18
+ instruction: "Factoriser :",
19
+ isSingleStep: false,
20
+ label: "Factorisation du type $(ax+b)(cx+d) \\pm (ax+b)(ex+f)$",
21
+ levels: ["3", "2"],
22
+ section: "Calcul littéral",
23
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getFactoType1Question, nb),
24
+ };
25
+ function getFactoType1Question() {
26
+ const affines = affine_1.AffineConstructor.differentRandoms(3);
27
+ const permut = [(0, shuffle_1.shuffle)([affines[0], affines[1]]), (0, shuffle_1.shuffle)([affines[0], affines[2]])];
28
+ const operation = (0, random_1.random)(["add", "substract"]);
29
+ const statementTree = operation === "add"
30
+ ? new addNode_1.AddNode(new multiplyNode_1.MultiplyNode(permut[0][0].toTree(), permut[0][1].toTree()), new multiplyNode_1.MultiplyNode(permut[1][0].toTree(), permut[1][1].toTree()))
31
+ : new substractNode_1.SubstractNode(new multiplyNode_1.MultiplyNode(permut[0][0].toTree(), permut[0][1].toTree()), new multiplyNode_1.MultiplyNode(permut[1][0].toTree(), permut[1][1].toTree()));
32
+ const answerTree = new multiplyNode_1.MultiplyNode(affines[0].toTree(), affines[1].add(operation === "add" ? affines[2] : affines[2].opposite()).toTree());
33
+ const question = {
34
+ startStatement: (0, latexParser_1.latexParser)(statementTree),
35
+ answer: (0, latexParser_1.latexParser)(answerTree),
36
+ };
37
+ return question;
38
+ }
39
+ exports.getFactoType1Question = getFactoType1Question;
@@ -1,7 +1,7 @@
1
- "use strict";
2
- // export enum Connector {
3
- // equal = "=",
4
- // equiv = "\\iff",
5
- // implies = "\\Rightarrow",
6
- // }
7
- exports.__esModule = true;
1
+ "use strict";
2
+ // export enum Connector {
3
+ // equal = "=",
4
+ // equiv = "\\iff",
5
+ // implies = "\\Rightarrow",
6
+ // }
7
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,95 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.exercises = exports.data = void 0;
4
+ const addAndSub_1 = require("./calcul/addAndSub");
5
+ const fractionAndIntegerDivision_1 = require("./calcul/fractions/fractionAndIntegerDivision");
6
+ const fractionAndIntegerProduct_1 = require("./calcul/fractions/fractionAndIntegerProduct");
7
+ const fractionAndIntegerSum_1 = require("./calcul/fractions/fractionAndIntegerSum");
8
+ const fractionsDivision_1 = require("./calcul/fractions/fractionsDivision");
9
+ const fractionsProduct_1 = require("./calcul/fractions/fractionsProduct");
10
+ const fractionsSum_1 = require("./calcul/fractions/fractionsSum");
11
+ const simplifyFraction_1 = require("./calcul/fractions/simplifyFraction");
12
+ const operationsPriorities_1 = require("./calcul/operations/operationsPriorities");
13
+ const rounding_1 = require("./calcul/rounding/rounding");
14
+ const allIdentities_1 = require("./calculLitteral/distributivity/allIdentities");
15
+ const doubleDistributivity_1 = require("./calculLitteral/distributivity/doubleDistributivity");
16
+ const firstIdentity_1 = require("./calculLitteral/distributivity/firstIdentity");
17
+ const secondIdentity_1 = require("./calculLitteral/distributivity/secondIdentity");
18
+ const simpleDistributivity_1 = require("./calculLitteral/distributivity/simpleDistributivity");
19
+ const thirdIdentity_1 = require("./calculLitteral/distributivity/thirdIdentity");
20
+ const equationType1Exercise_1 = require("./calculLitteral/equation/equationType1Exercise");
21
+ const equationType2Exercise_1 = require("./calculLitteral/equation/equationType2Exercise");
22
+ const equationType3Exercise_1 = require("./calculLitteral/equation/equationType3Exercise");
23
+ const equationType4Exercise_1 = require("./calculLitteral/equation/equationType4Exercise");
24
+ const factoType1Exercise_1 = require("./calculLitteral/factorisation/factoType1Exercise");
25
+ const midpoint_1 = require("./geometry/cartesian/midpoint");
26
+ const scalarProductViaCoords_1 = require("./geometry/vectors/scalarProductViaCoords");
27
+ const powersDivision_1 = require("./powers/powersDivision");
28
+ const powersOfTenToDecimal_1 = require("./powers/powersOfTenToDecimal");
29
+ const powersPower_1 = require("./powers/powersPower");
30
+ const powersProduct_1 = require("./powers/powersProduct");
31
+ const scientificToDecimal_1 = require("./powers/scientificToDecimal");
32
+ const simpifySquareRoot_1 = require("./squareRoots/simpifySquareRoot");
33
+ exports.data = [{}];
34
+ exports.exercises = [
35
+ /**
36
+ * calcul litteral
37
+ */
38
+ factoType1Exercise_1.factoType1Exercise,
39
+ simpleDistributivity_1.simpleDistributivity,
40
+ doubleDistributivity_1.doubleDistributivity,
41
+ firstIdentity_1.firstIdentity,
42
+ secondIdentity_1.secondIdentity,
43
+ thirdIdentity_1.thirdIdentity,
44
+ allIdentities_1.allIdentities,
45
+ equationType1Exercise_1.equationType1Exercise,
46
+ equationType2Exercise_1.equationType2Exercise,
47
+ equationType3Exercise_1.equationType3Exercise,
48
+ equationType4Exercise_1.equationType4Exercise,
49
+ /**
50
+ * square roots
51
+ */
52
+ simpifySquareRoot_1.simplifySquareRoot,
53
+ /**
54
+ * fractions
55
+ */
56
+ fractionAndIntegerDivision_1.fractionAndIntegerDivision,
57
+ fractionAndIntegerProduct_1.fractionAndIntegerProduct,
58
+ fractionAndIntegerSum_1.fractionAndIntegerSum,
59
+ fractionsDivision_1.fractionsDivision,
60
+ fractionsProduct_1.fractionsProduct,
61
+ fractionsSum_1.fractionsSum,
62
+ simplifyFraction_1.simplifyFraction,
63
+ /**
64
+ * calcul
65
+ */
66
+ operationsPriorities_1.operationsPriorities,
67
+ addAndSub_1.addAndSubExercise,
68
+ /**
69
+ * rounding
70
+ */
71
+ rounding_1.roundToCentieme,
72
+ rounding_1.roundToDixieme,
73
+ rounding_1.roundToMillieme,
74
+ rounding_1.roundToUnit,
75
+ rounding_1.allRoundings,
76
+ /**
77
+ * geometry
78
+ */
79
+ midpoint_1.midpoint,
80
+ /**
81
+ * vectors
82
+ */
83
+ scalarProductViaCoords_1.scalarProductViaCoords,
84
+ /**
85
+ * puissances
86
+ */
87
+ powersDivision_1.powersDivision,
88
+ powersPower_1.powersPower,
89
+ powersProduct_1.powersProduct,
90
+ powersDivision_1.powersOfTenDivision,
91
+ powersPower_1.powersOfTenPower,
92
+ powersProduct_1.powersOfTenProduct,
93
+ scientificToDecimal_1.scientificToDecimal,
94
+ powersOfTenToDecimal_1.powersOfTenToDecimal,
95
+ ];
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getMidpointQuestion = exports.midpoint = void 0;
4
+ const point_1 = require("../../../geometry/point");
5
+ const randTupleInt_1 = require("../../../mathutils/random/randTupleInt");
6
+ const numberNode_1 = require("../../../tree/nodes/numbers/numberNode");
7
+ const getDistinctQuestions_1 = require("../../utils/getDistinctQuestions");
8
+ exports.midpoint = {
9
+ id: 'midpoint',
10
+ connector: '=',
11
+ instruction: '',
12
+ label: 'Coordonnées du milieu',
13
+ levels: ['3', '2', '1'],
14
+ isSingleStep: false,
15
+ section: 'Géométrie cartésienne',
16
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getMidpointQuestion, nb),
17
+ };
18
+ function getMidpointQuestion() {
19
+ const [coords1, coords2] = (0, randTupleInt_1.distinctRandTupleInt)(2, 2, { from: -9, to: 10 });
20
+ const A = new point_1.Point('A', new numberNode_1.NumberNode(coords1[0]), new numberNode_1.NumberNode(coords1[1]));
21
+ const B = new point_1.Point('B', new numberNode_1.NumberNode(coords2[0]), new numberNode_1.NumberNode(coords2[1]));
22
+ const question = {
23
+ instruction: `Soit $${A.toTexWithCoords()}$ et $${B.toTexWithCoords()}$. Quelles sont les coordonnées du milieu $I$ de $[AB]$ ?`,
24
+ startStatement: "I",
25
+ answer: A.midpoint(B).toTexWithCoords(),
26
+ };
27
+ return question;
28
+ }
29
+ exports.getMidpointQuestion = getMidpointQuestion;
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getScalarProductViaCoordsQuestion = exports.scalarProductViaCoords = void 0;
4
+ const vector_1 = require("../../../geometry/vector");
5
+ const randTupleInt_1 = require("../../../mathutils/random/randTupleInt");
6
+ const numberNode_1 = require("../../../tree/nodes/numbers/numberNode");
7
+ const latexParser_1 = require("../../../tree/parsers/latexParser");
8
+ const getDistinctQuestions_1 = require("../../utils/getDistinctQuestions");
9
+ exports.scalarProductViaCoords = {
10
+ id: 'scalarProductViaCoords',
11
+ connector: "=",
12
+ instruction: "",
13
+ isSingleStep: false,
14
+ label: "Calculer un produit scalaire à l'aide des coordonnées",
15
+ levels: ["1, 0"],
16
+ section: "vectors",
17
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getScalarProductViaCoordsQuestion, nb)
18
+ };
19
+ function getScalarProductViaCoordsQuestion() {
20
+ const [coords1, coords2] = (0, randTupleInt_1.distinctRandTupleInt)(2, 2, { from: -9, to: 10 });
21
+ const u = new vector_1.Vector("u", new numberNode_1.NumberNode(coords1[0]), new numberNode_1.NumberNode(coords1[1]));
22
+ const v = new vector_1.Vector("v", new numberNode_1.NumberNode(coords2[0]), new numberNode_1.NumberNode(coords2[1]));
23
+ return {
24
+ instruction: `Soit ${u.toTexWithCoords()} et ${v.toTexWithCoords()}. Calculer ${u.toTex()}\\cdot ${v.toTex()}.`,
25
+ startStatement: `${u.toTex()}\\cdot ${v.toTex()}`,
26
+ answer: (0, latexParser_1.latexParser)(u.scalarProduct(v)),
27
+ };
28
+ }
29
+ exports.getScalarProductViaCoordsQuestion = getScalarProductViaCoordsQuestion;
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ // import { Vector } from "../../../geometry/vector";
3
+ // import { distinctRandTupleInt } from "../../../mathutils/random/randTupleInt";
4
+ // import { NumberNode } from "../../../tree/nodes/numbers/numberNode";
5
+ // import { latexParser } from "../../../tree/parsers/latexParser";
6
+ // import { Exercise, Question } from "../../exercise";
7
+ // import { getDistinctQuestions } from "../../utils/getDistinctQuestions";
8
+ // export const scalarProductViaNorms : Exercise = {
9
+ // id: 'scalarProductViaNorms',
10
+ // connector: "=",
11
+ // instruction: "",
12
+ // isSingleStep: false,
13
+ // label: "Calculer un produit scalaire à l'aide des normes.",
14
+ // levels: ["1, 0"],
15
+ // section: "vectors",
16
+ // generator: (nb: number) => getDistinctQuestions(getScalarProductViaNormsQuestion, nb)
17
+ // }
18
+ // export function getScalarProductViaNormsQuestion(): Question {
19
+ // const [coords1, coords2] = distinctRandTupleInt(2, 2, {from: -9, to: 10})
20
+ // const u = new Vector("u", new NumberNode(coords1[0]), new NumberNode(coords1[1]))
21
+ // const v = new Vector("v", new NumberNode(coords2[0]), new NumberNode(coords2[1]))
22
+ // return {
23
+ // instruction: `Soit ${u.toTexWithCoords()} et ${v.toTexWithCoords()}. Calculer ${u.toTex()}\\cdot ${v.toTex()}.`,
24
+ // startStatement: `${u.toTex()}\\cdot ${v.toTex()}`,
25
+ // answer: latexParser(u.scalarProduct(v)),
26
+ // }
27
+ // }
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getPowersDivisionQuestion = exports.powersOfTenDivision = exports.powersDivision = void 0;
4
+ const randint_1 = require("../../mathutils/random/randint");
5
+ const power_1 = require("../../numbers/integer/power");
6
+ const latexParser_1 = require("../../tree/parsers/latexParser");
7
+ const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
8
+ const fractionNode_1 = require("../../tree/nodes/operators/fractionNode");
9
+ const powerNode_1 = require("../../tree/nodes/operators/powerNode");
10
+ const getDistinctQuestions_1 = require("../utils/getDistinctQuestions");
11
+ /**
12
+ * a^b/a^c
13
+ */
14
+ exports.powersDivision = {
15
+ id: "powersDivision",
16
+ connector: "=",
17
+ instruction: "Calculer :",
18
+ label: "Division de puissances",
19
+ levels: ["4", "3", "2", "1"],
20
+ section: "Puissances",
21
+ isSingleStep: true,
22
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getPowersDivisionQuestion, nb),
23
+ };
24
+ exports.powersOfTenDivision = {
25
+ id: "powersOfTenDivision",
26
+ connector: "=",
27
+ instruction: "Calculer :",
28
+ label: "Division de puissances de 10",
29
+ levels: ["4", "3", "2", "1"],
30
+ section: "Puissances",
31
+ isSingleStep: true,
32
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(() => getPowersDivisionQuestion(true), nb),
33
+ };
34
+ function getPowersDivisionQuestion(useOnlyPowersOfTen = false) {
35
+ const a = useOnlyPowersOfTen ? 10 : (0, randint_1.randint)(-11, 11, [0]);
36
+ const [b, c] = [1, 2].map((el) => (0, randint_1.randint)(-11, 11));
37
+ const statement = new fractionNode_1.FractionNode(new powerNode_1.PowerNode(new numberNode_1.NumberNode(a), new numberNode_1.NumberNode(b)), new powerNode_1.PowerNode(new numberNode_1.NumberNode(a), new numberNode_1.NumberNode(c)));
38
+ const answerTree = new power_1.Power(a, b - c).simplify();
39
+ const question = {
40
+ startStatement: (0, latexParser_1.latexParser)(statement),
41
+ answer: (0, latexParser_1.latexParser)(answerTree),
42
+ };
43
+ return question;
44
+ }
45
+ exports.getPowersDivisionQuestion = getPowersDivisionQuestion;
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getPowersOfTenDivisionQuestion = exports.powersOfTenToDecimal = void 0;
4
+ const randint_1 = require("../../mathutils/random/randint");
5
+ const power_1 = require("../../numbers/integer/power");
6
+ const latexParser_1 = require("../../tree/parsers/latexParser");
7
+ const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
8
+ const powerNode_1 = require("../../tree/nodes/operators/powerNode");
9
+ const getDistinctQuestions_1 = require("../utils/getDistinctQuestions");
10
+ /**
11
+ * 10^(-x) into 0,0...1
12
+ */
13
+ exports.powersOfTenToDecimal = {
14
+ id: "powersOfTenToDecimal",
15
+ connector: "=",
16
+ instruction: "Donner l'écriture décimale de :",
17
+ label: "Ecriture décimale d'une puissance de 10",
18
+ levels: ["5", "4", "3", "2"],
19
+ section: "Puissances",
20
+ isSingleStep: true,
21
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getPowersOfTenDivisionQuestion, nb),
22
+ };
23
+ function getPowersOfTenDivisionQuestion() {
24
+ const randPower = (0, randint_1.randint)(-6, 8);
25
+ const statement = new powerNode_1.PowerNode(new numberNode_1.NumberNode(10), new numberNode_1.NumberNode(randPower));
26
+ const answerTree = new power_1.Power(10, randPower).toDecimalWriting().toTree();
27
+ const question = {
28
+ startStatement: (0, latexParser_1.latexParser)(statement),
29
+ answer: (0, latexParser_1.latexParser)(answerTree),
30
+ };
31
+ return question;
32
+ }
33
+ exports.getPowersOfTenDivisionQuestion = getPowersOfTenDivisionQuestion;
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getPowersPowerQuestion = exports.powersPower = exports.powersOfTenPower = void 0;
4
+ const randint_1 = require("../../mathutils/random/randint");
5
+ const power_1 = require("../../numbers/integer/power");
6
+ const latexParser_1 = require("../../tree/parsers/latexParser");
7
+ const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
8
+ const powerNode_1 = require("../../tree/nodes/operators/powerNode");
9
+ const getDistinctQuestions_1 = require("../utils/getDistinctQuestions");
10
+ /**
11
+ * (a^b)^c
12
+ */
13
+ exports.powersOfTenPower = {
14
+ id: "powersOfTenPower",
15
+ connector: "=",
16
+ instruction: "Calculer :",
17
+ label: "Puissance d'une puissance de 10 ",
18
+ levels: ["4", "3", "2", "1"],
19
+ section: "Puissances",
20
+ isSingleStep: true,
21
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(() => getPowersPowerQuestion(true), nb),
22
+ };
23
+ exports.powersPower = {
24
+ id: "powersPower",
25
+ connector: "=",
26
+ instruction: "Calculer :",
27
+ label: "Puissance d'une puissance",
28
+ levels: ["4", "3", "2", "1"],
29
+ section: "Puissances",
30
+ isSingleStep: true,
31
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getPowersPowerQuestion, nb),
32
+ };
33
+ function getPowersPowerQuestion(useOnlyPowersOfTen = false) {
34
+ const a = useOnlyPowersOfTen ? 10 : (0, randint_1.randint)(-11, 11);
35
+ const [b, c] = [1, 2].map((el) => (0, randint_1.randint)(-11, 11));
36
+ const statement = new powerNode_1.PowerNode(new powerNode_1.PowerNode(new numberNode_1.NumberNode(a), new numberNode_1.NumberNode(b)), new numberNode_1.NumberNode(c));
37
+ let answerTree = new power_1.Power(a, b * c).simplify();
38
+ const question = {
39
+ startStatement: (0, latexParser_1.latexParser)(statement),
40
+ answer: (0, latexParser_1.latexParser)(answerTree),
41
+ };
42
+ return question;
43
+ }
44
+ exports.getPowersPowerQuestion = getPowersPowerQuestion;
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getPowersProductQuestion = exports.powersProduct = exports.powersOfTenProduct = void 0;
4
+ const randint_1 = require("../../mathutils/random/randint");
5
+ const power_1 = require("../../numbers/integer/power");
6
+ const latexParser_1 = require("../../tree/parsers/latexParser");
7
+ const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
8
+ const multiplyNode_1 = require("../../tree/nodes/operators/multiplyNode");
9
+ const powerNode_1 = require("../../tree/nodes/operators/powerNode");
10
+ const getDistinctQuestions_1 = require("../utils/getDistinctQuestions");
11
+ /**
12
+ * a^b*a^c
13
+ */
14
+ exports.powersOfTenProduct = {
15
+ id: "powersOfTenProduct",
16
+ connector: "=",
17
+ instruction: "Calculer :",
18
+ label: "Multiplication de puissances de 10",
19
+ levels: ["4", "3", "2", "1"],
20
+ section: "Puissances",
21
+ isSingleStep: true,
22
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(() => getPowersProductQuestion(true), nb),
23
+ };
24
+ exports.powersProduct = {
25
+ id: "powersProduct",
26
+ connector: "=",
27
+ instruction: "Calculer :",
28
+ label: "Multiplication de puissances",
29
+ levels: ["4", "3", "2", "1"],
30
+ section: "Puissances",
31
+ isSingleStep: true,
32
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getPowersProductQuestion, nb),
33
+ };
34
+ function getPowersProductQuestion(useOnlyPowersOfTen = false) {
35
+ const a = useOnlyPowersOfTen ? 10 : (0, randint_1.randint)(-11, 11);
36
+ const [b, c] = [1, 2].map((el) => (0, randint_1.randint)(-11, 11));
37
+ const statement = new multiplyNode_1.MultiplyNode(new powerNode_1.PowerNode(new numberNode_1.NumberNode(a), new numberNode_1.NumberNode(b)), new powerNode_1.PowerNode(new numberNode_1.NumberNode(a), new numberNode_1.NumberNode(c)));
38
+ const answerTree = new power_1.Power(a, b + c).simplify();
39
+ const question = {
40
+ startStatement: (0, latexParser_1.latexParser)(statement),
41
+ answer: (0, latexParser_1.latexParser)(answerTree),
42
+ };
43
+ return question;
44
+ }
45
+ exports.getPowersProductQuestion = getPowersProductQuestion;
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getScientificToDecimalQuestion = exports.scientificToDecimal = void 0;
4
+ const randint_1 = require("../../mathutils/random/randint");
5
+ const decimal_1 = require("../../numbers/decimals/decimal");
6
+ const integer_1 = require("../../numbers/integer/integer");
7
+ const latexParser_1 = require("../../tree/parsers/latexParser");
8
+ const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
9
+ const multiplyNode_1 = require("../../tree/nodes/operators/multiplyNode");
10
+ const powerNode_1 = require("../../tree/nodes/operators/powerNode");
11
+ const getDistinctQuestions_1 = require("../utils/getDistinctQuestions");
12
+ /**
13
+ * a*10^x vers décimal
14
+ * */
15
+ exports.scientificToDecimal = {
16
+ id: "scientificToDecimal",
17
+ connector: "=",
18
+ instruction: "Donner l'écriture décimale de :",
19
+ label: "Ecriture décimale de $a\\times 10^x$",
20
+ levels: ["5", "4", "3", "2"],
21
+ section: "Puissances",
22
+ isSingleStep: true,
23
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getScientificToDecimalQuestion, nb),
24
+ };
25
+ function getScientificToDecimalQuestion() {
26
+ const randPower = (0, randint_1.randint)(-6, 8);
27
+ const int = integer_1.IntegerConstructor.random((0, randint_1.randint)(1, 4));
28
+ const fracPart = decimal_1.DecimalConstructor.randomFracPart((0, randint_1.randint)(0, 4));
29
+ const randDecimal = decimal_1.DecimalConstructor.fromParts(int + "", fracPart);
30
+ const statement = new multiplyNode_1.MultiplyNode(new numberNode_1.NumberNode(randDecimal.value), new powerNode_1.PowerNode(new numberNode_1.NumberNode(10), new numberNode_1.NumberNode(randPower)));
31
+ const answerTree = randDecimal.multiplyByPowerOfTen(randPower).toTree();
32
+ const question = {
33
+ startStatement: (0, latexParser_1.latexParser)(statement),
34
+ answer: (0, latexParser_1.latexParser)(answerTree),
35
+ };
36
+ return question;
37
+ }
38
+ exports.getScientificToDecimalQuestion = getScientificToDecimalQuestion;
@@ -1,28 +1,28 @@
1
- "use strict";
2
- exports.__esModule = true;
3
- exports.getSimplifySquareRoot = exports.simplifySquareRoot = void 0;
4
- var squareRoot_1 = require("../../numbers/reals/squareRoot");
5
- var latexParser_1 = require("../../tree/parsers/latexParser");
6
- var getDistinctQuestions_1 = require("../utils/getDistinctQuestions");
7
- exports.simplifySquareRoot = {
8
- id: "simplifySqrt",
9
- connector: "=",
10
- instruction: "Simplifier :",
11
- label: "Simplification de racines carrées",
12
- levels: ["3", "2", "1"],
13
- isSingleStep: false,
14
- section: "Racines carrées",
15
- generator: function (nb) { return (0, getDistinctQuestions_1.getDistinctQuestions)(getSimplifySquareRoot, nb); }
16
- };
17
- function getSimplifySquareRoot() {
18
- var squareRoot = squareRoot_1.SquareRootConstructor.randomSimplifiable({
19
- allowPerfectSquare: false,
20
- maxSquare: 11
21
- });
22
- var question = {
23
- startStatement: (0, latexParser_1.latexParser)(squareRoot.toTree()),
24
- answer: (0, latexParser_1.latexParser)(squareRoot.simplify().toTree())
25
- };
26
- return question;
27
- }
28
- exports.getSimplifySquareRoot = getSimplifySquareRoot;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getSimplifySquareRoot = exports.simplifySquareRoot = void 0;
4
+ const squareRoot_1 = require("../../numbers/reals/squareRoot");
5
+ const latexParser_1 = require("../../tree/parsers/latexParser");
6
+ const getDistinctQuestions_1 = require("../utils/getDistinctQuestions");
7
+ exports.simplifySquareRoot = {
8
+ id: "simplifySqrt",
9
+ connector: "=",
10
+ instruction: "Simplifier :",
11
+ label: "Simplification de racines carrées",
12
+ levels: ["3", "2", "1"],
13
+ isSingleStep: false,
14
+ section: "Racines carrées",
15
+ generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getSimplifySquareRoot, nb),
16
+ };
17
+ function getSimplifySquareRoot() {
18
+ const squareRoot = squareRoot_1.SquareRootConstructor.randomSimplifiable({
19
+ allowPerfectSquare: false,
20
+ maxSquare: 11,
21
+ });
22
+ const question = {
23
+ startStatement: (0, latexParser_1.latexParser)(squareRoot.toTree()),
24
+ answer: (0, latexParser_1.latexParser)(squareRoot.simplify().toTree()),
25
+ };
26
+ return question;
27
+ }
28
+ exports.getSimplifySquareRoot = getSimplifySquareRoot;