math-exercises 1.3.31 → 1.3.32
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.
- package/README.md +73 -73
- package/lib/exercises/calcul/addAndSub.d.ts +6 -6
- package/lib/exercises/calcul/addAndSub.js +41 -41
- package/lib/exercises/calcul/addAndSubWithoutRelatives.d.ts +6 -6
- package/lib/exercises/calcul/addAndSubWithoutRelatives.js +51 -51
- package/lib/exercises/calcul/fractions/fractionAndIntegerDivision.d.ts +3 -3
- package/lib/exercises/calcul/fractions/fractionAndIntegerDivision.js +37 -37
- package/lib/exercises/calcul/fractions/fractionAndIntegerProduct.d.ts +3 -3
- package/lib/exercises/calcul/fractions/fractionAndIntegerProduct.js +34 -34
- package/lib/exercises/calcul/fractions/fractionAndIntegerSum.d.ts +3 -3
- package/lib/exercises/calcul/fractions/fractionAndIntegerSum.js +34 -34
- package/lib/exercises/calcul/fractions/fractionToPercentToDecimal.d.ts +3 -3
- package/lib/exercises/calcul/fractions/fractionToPercentToDecimal.js +69 -69
- package/lib/exercises/calcul/fractions/fractionsDivision.d.ts +3 -3
- package/lib/exercises/calcul/fractions/fractionsDivision.js +31 -31
- package/lib/exercises/calcul/fractions/fractionsProduct.d.ts +3 -3
- package/lib/exercises/calcul/fractions/fractionsProduct.js +30 -30
- package/lib/exercises/calcul/fractions/fractionsSum.d.ts +3 -3
- package/lib/exercises/calcul/fractions/fractionsSum.js +30 -30
- package/lib/exercises/calcul/fractions/simplifyFraction.d.ts +3 -3
- package/lib/exercises/calcul/fractions/simplifyFraction.js +26 -26
- package/lib/exercises/calcul/mentalCaluls.ts/mentalAddAndSub.d.ts +3 -3
- package/lib/exercises/calcul/mentalCaluls.ts/mentalAddAndSub.js +46 -46
- package/lib/exercises/calcul/mentalCaluls.ts/mentalDivisions.d.ts +3 -3
- package/lib/exercises/calcul/mentalCaluls.ts/mentalDivisions.js +64 -64
- package/lib/exercises/calcul/mentalCaluls.ts/mentalMultiplications.d.ts +3 -3
- package/lib/exercises/calcul/mentalCaluls.ts/mentalMultiplications.js +51 -51
- package/lib/exercises/calcul/mentalCaluls.ts/mentalPercentage.d.ts +3 -3
- package/lib/exercises/calcul/mentalCaluls.ts/mentalPercentage.js +67 -67
- package/lib/exercises/calcul/operations/operationsPriorities.d.ts +10 -10
- package/lib/exercises/calcul/operations/operationsPriorities.js +100 -100
- package/lib/exercises/calcul/operations/operationsPrioritiesWithoutRelative.d.ts +10 -10
- package/lib/exercises/calcul/operations/operationsPrioritiesWithoutRelative.js +181 -181
- package/lib/exercises/calcul/operationsPriorities.js +88 -0
- package/lib/exercises/calcul/rounding/rounding.d.ts +19 -19
- package/lib/exercises/calcul/rounding/rounding.js +87 -87
- package/lib/exercises/calculLitteral/distributivity/allIdentities.d.ts +3 -3
- package/lib/exercises/calculLitteral/distributivity/allIdentities.js +27 -27
- package/lib/exercises/calculLitteral/distributivity/doubleDistributivity.d.ts +3 -3
- package/lib/exercises/calculLitteral/distributivity/doubleDistributivity.js +32 -32
- package/lib/exercises/calculLitteral/distributivity/firstIdentity.d.ts +3 -3
- package/lib/exercises/calculLitteral/distributivity/firstIdentity.js +33 -33
- package/lib/exercises/calculLitteral/distributivity/secondIdentity.d.ts +3 -3
- package/lib/exercises/calculLitteral/distributivity/secondIdentity.js +34 -34
- package/lib/exercises/calculLitteral/distributivity/simpleDistributivity.d.ts +3 -3
- package/lib/exercises/calculLitteral/distributivity/simpleDistributivity.js +34 -34
- package/lib/exercises/calculLitteral/distributivity/thirdIdentity.d.ts +3 -3
- package/lib/exercises/calculLitteral/distributivity/thirdIdentity.js +33 -33
- package/lib/exercises/calculLitteral/equation/equationSimpleSquare.d.ts +3 -3
- package/lib/exercises/calculLitteral/equation/equationSimpleSquare.js +47 -47
- package/lib/exercises/calculLitteral/equation/equationType1Exercise.d.ts +6 -6
- package/lib/exercises/calculLitteral/equation/equationType1Exercise.js +39 -39
- package/lib/exercises/calculLitteral/equation/equationType2Exercise.d.ts +6 -6
- package/lib/exercises/calculLitteral/equation/equationType2Exercise.js +42 -42
- package/lib/exercises/calculLitteral/equation/equationType3Exercise.d.ts +6 -6
- package/lib/exercises/calculLitteral/equation/equationType3Exercise.js +43 -43
- package/lib/exercises/calculLitteral/equation/equationType4Exercise.d.ts +6 -6
- package/lib/exercises/calculLitteral/equation/equationType4Exercise.js +45 -45
- package/lib/exercises/calculLitteral/equation/firstDegreeEquation.d.ts +3 -3
- package/lib/exercises/calculLitteral/equation/firstDegreeEquation.js +30 -30
- package/lib/exercises/calculLitteral/equation/firstDegreeGeneralEquation.d.ts +3 -3
- package/lib/exercises/calculLitteral/equation/firstDegreeGeneralEquation.js +32 -32
- package/lib/exercises/calculLitteral/equation/fractionEquation.d.ts +4 -0
- package/lib/exercises/calculLitteral/equation/fractionEquation.d.ts.map +1 -0
- package/lib/exercises/calculLitteral/equation/fractionEquation.js +39 -0
- package/lib/exercises/calculLitteral/equation/multiplicationEquation.d.ts +4 -0
- package/lib/exercises/calculLitteral/equation/multiplicationEquation.d.ts.map +1 -0
- package/lib/exercises/calculLitteral/equation/multiplicationEquation.js +39 -0
- package/lib/exercises/calculLitteral/factorisation/factoIdRmq1.d.ts +3 -3
- package/lib/exercises/calculLitteral/factorisation/factoIdRmq1.js +34 -34
- package/lib/exercises/calculLitteral/factorisation/factoIdRmq2.d.ts +3 -3
- package/lib/exercises/calculLitteral/factorisation/factoIdRmq2.js +35 -35
- package/lib/exercises/calculLitteral/factorisation/factoIdRmq3.d.ts +3 -3
- package/lib/exercises/calculLitteral/factorisation/factoIdRmq3.js +34 -34
- package/lib/exercises/calculLitteral/factorisation/factoType1Exercise.d.ts +6 -6
- package/lib/exercises/calculLitteral/factorisation/factoType1Exercise.js +40 -40
- package/lib/exercises/conversion/aeraConversion.d.ts +3 -3
- package/lib/exercises/conversion/aeraConversion.js +32 -32
- package/lib/exercises/conversion/capacityConversion.d.ts +3 -3
- package/lib/exercises/conversion/capacityConversion.js +30 -30
- package/lib/exercises/conversion/lengthConversion.d.ts +3 -3
- package/lib/exercises/conversion/lengthConversion.js +30 -30
- package/lib/exercises/conversion/massConversion.d.ts +3 -3
- package/lib/exercises/conversion/massConversion.js +30 -30
- package/lib/exercises/conversion/volumeCapacityConversion.d.ts +3 -3
- package/lib/exercises/conversion/volumeCapacityConversion.js +47 -47
- package/lib/exercises/conversion/volumeConversion.d.ts +3 -3
- package/lib/exercises/conversion/volumeConversion.js +32 -32
- package/lib/exercises/derivation/derivative/affineDerivative.d.ts +4 -0
- package/lib/exercises/derivation/derivative/affineDerivative.d.ts.map +1 -0
- package/lib/exercises/derivation/derivative/affineDerivative.js +27 -0
- package/lib/exercises/derivation/derivative/constanteDerivative.d.ts +3 -3
- package/lib/exercises/derivation/derivative/constanteDerivative.js +27 -27
- package/lib/exercises/derivation/derivative/firstDegreeDerivative.d.ts +3 -3
- package/lib/exercises/derivation/derivative/firstDegreeDerivative.js +29 -29
- package/lib/exercises/derivation/derivative/inverseFunctionDerivative.d.ts +3 -3
- package/lib/exercises/derivation/derivative/inverseFunctionDerivative.js +27 -27
- package/lib/exercises/derivation/derivative/powerFunctionDerivative.d.ts +3 -3
- package/lib/exercises/derivation/derivative/powerFunctionDerivative.js +35 -35
- package/lib/exercises/derivation/derivative/rootFunctionDerivative.d.ts +3 -3
- package/lib/exercises/derivation/derivative/rootFunctionDerivative.js +40 -40
- package/lib/exercises/derivation/derivative/secondDegreeDerivative.d.ts +3 -3
- package/lib/exercises/derivation/derivative/secondDegreeDerivative.js +30 -30
- package/lib/exercises/derivation/derivative/thirdDegreeDerivative.d.ts +3 -3
- package/lib/exercises/derivation/derivative/thirdDegreeDerivative.js +33 -33
- package/lib/exercises/derivation/derivative/thridDegreeDerivative.d.ts +1 -0
- package/lib/exercises/derivation/derivative/thridDegreeDerivative.d.ts.map +1 -0
- package/lib/exercises/derivation/derivative/thridDegreeDerivative.js +1 -0
- package/lib/exercises/derivation/derivative/usualderivative.d.ts +3 -3
- package/lib/exercises/derivation/derivative/usualderivative.js +36 -36
- package/lib/exercises/exercise.d.ts +21 -21
- package/lib/exercises/exercise.js +7 -7
- package/lib/exercises/exercises.d.ts +1 -1
- package/lib/exercises/exercises.d.ts.map +1 -1
- package/lib/exercises/exercises.js +224 -198
- package/lib/exercises/geometry/cartesian/derivativeNumberReading.d.ts +3 -3
- package/lib/exercises/geometry/cartesian/derivativeNumberReading.js +51 -51
- package/lib/exercises/geometry/cartesian/derivativeNumberReading2.js +91 -91
- package/lib/exercises/geometry/cartesian/leadingCoefficient.d.ts +3 -3
- package/lib/exercises/geometry/cartesian/leadingCoefficient.js +60 -60
- package/lib/exercises/geometry/cartesian/leadingCoefficientCalculV1.d.ts +4 -0
- package/lib/exercises/geometry/cartesian/leadingCoefficientCalculV1.d.ts.map +1 -0
- package/lib/exercises/geometry/cartesian/leadingCoefficientCalculV1.js +30 -0
- package/lib/exercises/geometry/cartesian/leadingCoefficientCalculV2.d.ts +4 -0
- package/lib/exercises/geometry/cartesian/leadingCoefficientCalculV2.d.ts.map +1 -0
- package/lib/exercises/geometry/cartesian/leadingCoefficientCalculV2.js +29 -0
- package/lib/exercises/geometry/cartesian/midpoint.d.ts +3 -3
- package/lib/exercises/geometry/cartesian/midpoint.js +31 -31
- package/lib/exercises/geometry/euclidean/TriangleArea.d.ts +4 -0
- package/lib/exercises/geometry/euclidean/TriangleArea.d.ts.map +1 -0
- package/lib/exercises/geometry/euclidean/TriangleArea.js +53 -0
- package/lib/exercises/geometry/euclidean/pythagore.d.ts +4 -0
- package/lib/exercises/geometry/euclidean/pythagore.d.ts.map +1 -0
- package/lib/exercises/geometry/euclidean/pythagore.js +31 -0
- package/lib/exercises/geometry/euclidean/pythagoreCalcul.d.ts +4 -0
- package/lib/exercises/geometry/euclidean/pythagoreCalcul.d.ts.map +1 -0
- package/lib/exercises/geometry/euclidean/pythagoreCalcul.js +60 -0
- package/lib/exercises/geometry/euclidean/rightTriangleArea.d.ts +4 -0
- package/lib/exercises/geometry/euclidean/rightTriangleArea.d.ts.map +1 -0
- package/lib/exercises/geometry/euclidean/rightTriangleArea.js +39 -0
- package/lib/exercises/geometry/euclidean/thales.d.ts +4 -0
- package/lib/exercises/geometry/euclidean/thales.d.ts.map +1 -0
- package/lib/exercises/geometry/euclidean/thales.js +67 -0
- package/lib/exercises/geometry/euclidean/thalesCalcul.d.ts +4 -0
- package/lib/exercises/geometry/euclidean/thalesCalcul.d.ts.map +1 -0
- package/lib/exercises/geometry/euclidean/thalesCalcul.js +104 -0
- package/lib/exercises/geometry/euclidean/trigonometry.d.ts +4 -0
- package/lib/exercises/geometry/euclidean/trigonometry.d.ts.map +1 -0
- package/lib/exercises/geometry/euclidean/trigonometry.js +55 -0
- package/lib/exercises/geometry/euclidean/trigonometryAngleCalcul.d.ts +4 -0
- package/lib/exercises/geometry/euclidean/trigonometryAngleCalcul.d.ts.map +1 -0
- package/lib/exercises/geometry/euclidean/trigonometryAngleCalcul.js +42 -0
- package/lib/exercises/geometry/euclidean/trigonometrySideCalcul.d.ts +4 -0
- package/lib/exercises/geometry/euclidean/trigonometrySideCalcul.d.ts.map +1 -0
- package/lib/exercises/geometry/euclidean/trigonometrySideCalcul.js +52 -0
- package/lib/exercises/geometry/vectors/scalarProductViaCoords.d.ts +3 -3
- package/lib/exercises/geometry/vectors/scalarProductViaCoords.js +30 -30
- package/lib/exercises/geometry/vectors/scalarProductViaNorms.js +27 -27
- package/lib/exercises/percent/applyPercent.d.ts +3 -3
- package/lib/exercises/percent/applyPercent.js +41 -41
- package/lib/exercises/percent/averageEvolutionRate.d.ts +3 -3
- package/lib/exercises/percent/averageEvolutionRate.js +30 -30
- package/lib/exercises/percent/globalPercent.d.ts +3 -3
- package/lib/exercises/percent/globalPercent.js +44 -44
- package/lib/exercises/percent/reciprocalPercentage.d.ts +3 -3
- package/lib/exercises/percent/reciprocalPercentage.js +32 -32
- package/lib/exercises/powers/powersDivision.d.ts +7 -7
- package/lib/exercises/powers/powersDivision.js +46 -46
- package/lib/exercises/powers/powersOfTenToDecimal.d.ts +6 -6
- package/lib/exercises/powers/powersOfTenToDecimal.js +34 -34
- package/lib/exercises/powers/powersPower.d.ts +7 -7
- package/lib/exercises/powers/powersPower.js +45 -45
- package/lib/exercises/powers/powersProduct.d.ts +7 -7
- package/lib/exercises/powers/powersProduct.js +46 -46
- package/lib/exercises/powers/scientificToDecimal.d.ts +6 -6
- package/lib/exercises/powers/scientificToDecimal.js +39 -39
- package/lib/exercises/proba/conditionalProbability.d.ts +3 -3
- package/lib/exercises/proba/conditionalProbability.js +74 -74
- package/lib/exercises/proba/marginalAndConditionalFrequency.d.ts +3 -3
- package/lib/exercises/proba/marginalAndConditionalFrequency.js +81 -81
- package/lib/exercises/proba/probabilityTree.d.ts +3 -3
- package/lib/exercises/proba/probabilityTree.js +105 -105
- package/lib/exercises/sequences/arithmetic/arithmeticExplicitFormulaUsage.d.ts +3 -3
- package/lib/exercises/sequences/arithmetic/arithmeticExplicitFormulaUsage.js +31 -31
- package/lib/exercises/sequences/arithmetic/arithmeticFindExplicitFormula.d.ts +3 -3
- package/lib/exercises/sequences/arithmetic/arithmeticFindExplicitFormula.js +31 -31
- package/lib/exercises/sequences/arithmetic/arithmeticFindReason.d.ts +3 -3
- package/lib/exercises/sequences/arithmetic/arithmeticFindReason.js +31 -31
- package/lib/exercises/sequences/arithmetic/arithmeticReasonUsage.d.ts +3 -3
- package/lib/exercises/sequences/arithmetic/arithmeticReasonUsage.js +30 -30
- package/lib/exercises/sequences/arithmetic/arithmeticRecurrenceFormulaUsage.d.ts +3 -3
- package/lib/exercises/sequences/arithmetic/arithmeticRecurrenceFormulaUsage.js +30 -30
- package/lib/exercises/sequences/arithmetic/arithmeticThresholdFind.d.ts +3 -3
- package/lib/exercises/sequences/arithmetic/arithmeticThresholdFind.js +40 -40
- package/lib/exercises/sequences/geometric/geometricExplicitFormulaUsage.d.ts +3 -3
- package/lib/exercises/sequences/geometric/geometricExplicitFormulaUsage.js +36 -36
- package/lib/exercises/sequences/geometric/geometricFindExplicitFormula.d.ts +3 -3
- package/lib/exercises/sequences/geometric/geometricFindExplicitFormula.js +35 -35
- package/lib/exercises/sequences/geometric/geometricFindReason.d.ts +3 -3
- package/lib/exercises/sequences/geometric/geometricFindReason.js +31 -31
- package/lib/exercises/sequences/geometric/geometricReasonUsage.d.ts +3 -3
- package/lib/exercises/sequences/geometric/geometricReasonUsage.js +30 -30
- package/lib/exercises/sequences/geometric/geometricRecurrenceFormulaUsage.d.ts +7 -7
- package/lib/exercises/sequences/geometric/geometricRecurrenceFormulaUsage.js +30 -30
- package/lib/exercises/squareRoots/simpifySquareRoot.d.ts +3 -3
- package/lib/exercises/squareRoots/simpifySquareRoot.js +29 -29
- package/lib/exercises/trigonometry/mainRemarkableValues.d.ts +3 -3
- package/lib/exercises/trigonometry/mainRemarkableValues.js +30 -30
- package/lib/exercises/trigonometry/remarkableValues.d.ts +3 -3
- package/lib/exercises/trigonometry/remarkableValues.js +30 -30
- package/lib/exercises/utils/getDistinctQuestions.d.ts +3 -3
- package/lib/exercises/utils/getDistinctQuestions.js +28 -28
- package/lib/geometry/point.js +27 -0
- package/lib/geometry/vector.js +31 -0
- package/lib/index.d.ts +2 -2
- package/lib/index.js +6 -6
- package/lib/math/geometry/droite.d.ts +19 -19
- package/lib/math/geometry/droite.d.ts.map +1 -1
- package/lib/math/geometry/droite.js +62 -61
- package/lib/math/geometry/point.d.ts +29 -25
- package/lib/math/geometry/point.d.ts.map +1 -1
- package/lib/math/geometry/point.js +55 -40
- package/lib/math/geometry/triangles.d.ts +54 -0
- package/lib/math/geometry/triangles.d.ts.map +1 -0
- package/lib/math/geometry/triangles.js +183 -0
- package/lib/math/geometry/vector.d.ts +15 -15
- package/lib/math/geometry/vector.js +31 -31
- package/lib/math/numbers/decimals/decimal.d.ts +24 -24
- package/lib/math/numbers/decimals/decimal.js +140 -140
- package/lib/math/numbers/epsilon.d.ts +1 -1
- package/lib/math/numbers/epsilon.js +10 -10
- package/lib/math/numbers/integer/integer.d.ts +14 -14
- package/lib/math/numbers/integer/integer.js +68 -68
- package/lib/math/numbers/integer/power.d.ts +13 -13
- package/lib/math/numbers/integer/power.js +52 -52
- package/lib/math/numbers/nombre.d.ts +13 -13
- package/lib/math/numbers/nombre.js +10 -10
- package/lib/math/numbers/rationals/rational.d.ts +25 -25
- package/lib/math/numbers/rationals/rational.js +113 -113
- package/lib/math/numbers/reals/real.d.ts +9 -9
- package/lib/math/numbers/reals/real.js +16 -16
- package/lib/math/numbers/reals/squareRoot.d.ts +18 -18
- package/lib/math/numbers/reals/squareRoot.js +63 -63
- package/lib/math/polynomials/affine.d.ts +15 -15
- package/lib/math/polynomials/affine.js +42 -42
- package/lib/math/polynomials/polynomial.d.ts +25 -25
- package/lib/math/polynomials/polynomial.js +131 -131
- package/lib/math/sequences/arithmeticSequence.js +1 -1
- package/lib/math/sequences/geometricSequence.d.ts +3 -3
- package/lib/math/sequences/geometricSequence.js +8 -8
- package/lib/math/sequences/sequence.d.ts +22 -22
- package/lib/math/sequences/sequence.js +21 -21
- package/lib/math/sets/discreteSet.d.ts +10 -10
- package/lib/math/sets/discreteSet.js +28 -28
- package/lib/math/sets/emptySet.js +6 -6
- package/lib/math/sets/intervals/intervals.d.ts +26 -26
- package/lib/math/sets/intervals/intervals.js +104 -104
- package/lib/math/sets/mathSet.d.ts +7 -7
- package/lib/math/sets/mathSet.js +10 -10
- package/lib/math/sets/mathSetInterface.d.ts +5 -5
- package/lib/math/sets/mathSetInterface.js +2 -2
- package/lib/math/trigonometry/remarkableValue.d.ts +10 -10
- package/lib/math/trigonometry/remarkableValue.js +29 -29
- package/lib/math/trigonometry/remarkableValues.d.ts +2 -2
- package/lib/math/trigonometry/remarkableValues.js +51 -51
- package/lib/math/utils/arithmetic/coprimesOf.d.ts +1 -1
- package/lib/math/utils/arithmetic/coprimesOf.js +13 -13
- package/lib/math/utils/arithmetic/dividersOf.d.ts +1 -1
- package/lib/math/utils/arithmetic/dividersOf.js +12 -12
- package/lib/math/utils/arithmetic/gcd.d.ts +1 -1
- package/lib/math/utils/arithmetic/gcd.js +7 -7
- package/lib/math/utils/arithmetic/isSquare.d.ts +1 -1
- package/lib/math/utils/arithmetic/isSquare.js +7 -7
- package/lib/math/utils/arithmetic/lcd.d.ts +1 -1
- package/lib/math/utils/arithmetic/lcd.js +12 -12
- package/lib/math/utils/arithmetic/nonCoprimesOf.d.ts +1 -1
- package/lib/math/utils/arithmetic/nonCoprimesOf.js +13 -13
- package/lib/math/utils/arithmetic/nonDividersOf.d.ts +1 -1
- package/lib/math/utils/arithmetic/nonDividersOf.js +14 -14
- package/lib/math/utils/arithmetic/primeFactors.d.ts +5 -5
- package/lib/math/utils/arithmetic/primeFactors.js +22 -22
- package/lib/math/utils/decimals/decimalPartLengthOf.d.ts +1 -1
- package/lib/math/utils/decimals/decimalPartLengthOf.js +14 -14
- package/lib/math/utils/random/randTupleInt.d.ts +13 -13
- package/lib/math/utils/random/randTupleInt.js +30 -30
- package/lib/math/utils/random/randint.d.ts +4 -4
- package/lib/math/utils/random/randint.js +18 -18
- package/lib/math/utils/round.d.ts +1 -1
- package/lib/math/utils/round.js +8 -8
- package/lib/mathutils/arithmetic/coprimesOf.js +13 -0
- package/lib/mathutils/arithmetic/dividersOf.js +12 -0
- package/lib/mathutils/arithmetic/gcd.js +7 -0
- package/lib/mathutils/arithmetic/isSquare.js +7 -0
- package/lib/mathutils/arithmetic/lcd.js +12 -0
- package/lib/mathutils/arithmetic/nonCoprimesOf.js +13 -0
- package/lib/mathutils/arithmetic/nonDividersOf.js +14 -0
- package/lib/mathutils/arithmetic/primeFactors.js +22 -0
- package/lib/mathutils/decimals/decimalPartLengthOf.js +14 -0
- package/lib/mathutils/random/randTupleInt.js +30 -0
- package/lib/mathutils/random/randint.js +18 -0
- package/lib/mathutils/round.js +8 -0
- package/lib/numbers/decimals/decimal.js +140 -0
- package/lib/numbers/epsilon.js +10 -0
- package/lib/numbers/integer/integer.js +68 -0
- package/lib/numbers/integer/power.js +52 -0
- package/lib/numbers/nombre.js +10 -0
- package/lib/numbers/rationals/rational.js +113 -0
- package/lib/numbers/reals/real.js +16 -0
- package/lib/numbers/reals/squareRoot.js +63 -0
- package/lib/polynomials/affine.js +42 -0
- package/lib/polynomials/polynomial.js +125 -0
- package/lib/server.d.ts +1 -1
- package/lib/server.js +53 -53
- package/lib/sets/discreteSet.js +28 -0
- package/lib/sets/emptySet.js +6 -0
- package/lib/sets/intervals/intervals.js +108 -0
- package/lib/sets/intervals/union.js +1 -0
- package/lib/sets/mathSet.js +10 -0
- package/lib/sets/mathSetInterface.js +2 -0
- package/lib/tree/nodes/functions/cosNode.d.ts +9 -9
- package/lib/tree/nodes/functions/cosNode.js +21 -21
- package/lib/tree/nodes/functions/functionNode.d.ts +14 -14
- package/lib/tree/nodes/functions/functionNode.js +20 -20
- package/lib/tree/nodes/functions/oppositeNode.d.ts +7 -7
- package/lib/tree/nodes/functions/oppositeNode.js +26 -26
- package/lib/tree/nodes/functions/sinNode.js +1 -1
- package/lib/tree/nodes/functions/sqrtNode.d.ts +8 -8
- package/lib/tree/nodes/functions/sqrtNode.js +18 -18
- package/lib/tree/nodes/node.d.ts +12 -12
- package/lib/tree/nodes/node.js +11 -11
- package/lib/tree/nodes/numbers/constantNode.d.ts +9 -9
- package/lib/tree/nodes/numbers/constantNode.js +18 -18
- package/lib/tree/nodes/numbers/numberNode.d.ts +10 -10
- package/lib/tree/nodes/numbers/numberNode.js +19 -19
- package/lib/tree/nodes/numbers/piNode.d.ts +2 -2
- package/lib/tree/nodes/numbers/piNode.js +5 -5
- package/lib/tree/nodes/operators/addNode.d.ts +7 -7
- package/lib/tree/nodes/operators/addNode.js +19 -19
- package/lib/tree/nodes/operators/divideNode.d.ts +11 -11
- package/lib/tree/nodes/operators/divideNode.js +34 -34
- package/lib/tree/nodes/operators/equalNode.d.ts +7 -7
- package/lib/tree/nodes/operators/equalNode.js +16 -16
- package/lib/tree/nodes/operators/fractionNode.d.ts +11 -11
- package/lib/tree/nodes/operators/fractionNode.js +20 -20
- package/lib/tree/nodes/operators/multiplyNode.d.ts +7 -7
- package/lib/tree/nodes/operators/multiplyNode.js +43 -43
- package/lib/tree/nodes/operators/operatorNode.d.ts +21 -21
- package/lib/tree/nodes/operators/operatorNode.js +35 -35
- package/lib/tree/nodes/operators/powerNode.d.ts +7 -7
- package/lib/tree/nodes/operators/powerNode.js +33 -33
- package/lib/tree/nodes/operators/substractNode.d.ts +7 -7
- package/lib/tree/nodes/operators/substractNode.js +24 -24
- package/lib/tree/nodes/variables/variableNode.d.ts +8 -8
- package/lib/tree/nodes/variables/variableNode.js +19 -19
- package/lib/tree/parsers/derivateParser.js +62 -62
- package/lib/tree/parsers/latexParser.js +110 -0
- package/lib/tree/parsers/simplify.d.ts +2 -2
- package/lib/tree/parsers/simplify.js +52 -52
- package/lib/utils/arrayEqual.d.ts +1 -1
- package/lib/utils/arrayEqual.js +13 -13
- package/lib/utils/coin.js +7 -0
- package/lib/utils/coinFlip.d.ts +1 -1
- package/lib/utils/coinFlip.js +7 -7
- package/lib/utils/random.d.ts +1 -1
- package/lib/utils/random.js +7 -7
- package/lib/utils/shuffle.d.ts +1 -1
- package/lib/utils/shuffle.js +15 -15
- package/package.json +50 -50
package/README.md
CHANGED
|
@@ -1,73 +1,73 @@
|
|
|
1
|
-
# math-exercises
|
|
2
|
-
|
|
3
|
-
This is a generator of Math exercises for middle school and high school.
|
|
4
|
-
|
|
5
|
-
So far, exercises are written in French, but any translation is welcome !
|
|
6
|
-
|
|
7
|
-
This library is used by [Mathlive.fr](https://www.mathlive.fr) for collaborative quizzes.
|
|
8
|
-
|
|
9
|
-
## 🚧 Work in progress !
|
|
10
|
-
|
|
11
|
-
This library is still in beta and the architecture may very well completely change in the future.
|
|
12
|
-
|
|
13
|
-
Incoming improvements :
|
|
14
|
-
|
|
15
|
-
- Random images generation using tikZ
|
|
16
|
-
|
|
17
|
-
- Steps within answers
|
|
18
|
-
|
|
19
|
-
- Coverage of all topics up to 12th grade
|
|
20
|
-
|
|
21
|
-
- Better classification of exercises
|
|
22
|
-
|
|
23
|
-
## Exercises format
|
|
24
|
-
|
|
25
|
-
Each Exercise has a `generator` that will return distinct questions for this exercise.
|
|
26
|
-
|
|
27
|
-
The Question in itself has an `instruction`, a `startStatement` and an `answer` (which are all tex strings).
|
|
28
|
-
|
|
29
|
-
You can see all the exercises implemented so far [by playing with the select input here](https://www.mathlive.fr/teacher/createActivity/quizCollab/623366c277e90f70691aee70/).
|
|
30
|
-
|
|
31
|
-
## How to use
|
|
32
|
-
|
|
33
|
-
Example with (ax+b)^2 questions :
|
|
34
|
-
|
|
35
|
-
```js
|
|
36
|
-
import { firstIdentity } from 'exercises/calculLitteral/distributivity/firstIdentity';
|
|
37
|
-
|
|
38
|
-
console.log(firstIdentity.instruction);
|
|
39
|
-
const question = firstIdentity.generator(1);
|
|
40
|
-
console.log(question.startStatement);
|
|
41
|
-
console.log(question.answer);
|
|
42
|
-
|
|
43
|
-
//output :
|
|
44
|
-
// Développer et réduire :
|
|
45
|
-
// (2x+3)^2
|
|
46
|
-
// 4x^2 + 12x + 9
|
|
47
|
-
```
|
|
48
|
-
|
|
49
|
-
Some exercises do not have instructions, because the instruction is directly in the question itself.
|
|
50
|
-
|
|
51
|
-
A list of all exercises is exported from root.
|
|
52
|
-
|
|
53
|
-
## Expression tree and latex parser
|
|
54
|
-
|
|
55
|
-
Math expressions are implemented via a tree of Nodes that you'll find inside `tree/nodes`.
|
|
56
|
-
|
|
57
|
-
Any expression can be turned into a valid latex output via the `.toTex()` method.
|
|
58
|
-
|
|
59
|
-
They also can be simplified via the `simplifyNode` method.
|
|
60
|
-
|
|
61
|
-
## Math objects
|
|
62
|
-
|
|
63
|
-
This library also aims to implement pretty much all mathematical objects and notions up to 12th grade : all types of numbers and operations on them, but also points, vectors, polynomials, sets... Thus it can also be used for basic mathematics work.
|
|
64
|
-
|
|
65
|
-
## Minimal dependencies
|
|
66
|
-
|
|
67
|
-
We're trying to keep to our dependencies to a minimum. So far we're only using mathjs as an external library, to evaluate and simplify expression trees. We would love to have our own way of simplifying expressions in the future.
|
|
68
|
-
|
|
69
|
-
## How to contribute
|
|
70
|
-
|
|
71
|
-
Any contribution is welcomed.
|
|
72
|
-
|
|
73
|
-
There are tons of exercises left to implement !
|
|
1
|
+
# math-exercises
|
|
2
|
+
|
|
3
|
+
This is a generator of Math exercises for middle school and high school.
|
|
4
|
+
|
|
5
|
+
So far, exercises are written in French, but any translation is welcome !
|
|
6
|
+
|
|
7
|
+
This library is used by [Mathlive.fr](https://www.mathlive.fr) for collaborative quizzes.
|
|
8
|
+
|
|
9
|
+
## 🚧 Work in progress !
|
|
10
|
+
|
|
11
|
+
This library is still in beta and the architecture may very well completely change in the future.
|
|
12
|
+
|
|
13
|
+
Incoming improvements :
|
|
14
|
+
|
|
15
|
+
- Random images generation using tikZ
|
|
16
|
+
|
|
17
|
+
- Steps within answers
|
|
18
|
+
|
|
19
|
+
- Coverage of all topics up to 12th grade
|
|
20
|
+
|
|
21
|
+
- Better classification of exercises
|
|
22
|
+
|
|
23
|
+
## Exercises format
|
|
24
|
+
|
|
25
|
+
Each Exercise has a `generator` that will return distinct questions for this exercise.
|
|
26
|
+
|
|
27
|
+
The Question in itself has an `instruction`, a `startStatement` and an `answer` (which are all tex strings).
|
|
28
|
+
|
|
29
|
+
You can see all the exercises implemented so far [by playing with the select input here](https://www.mathlive.fr/teacher/createActivity/quizCollab/623366c277e90f70691aee70/).
|
|
30
|
+
|
|
31
|
+
## How to use
|
|
32
|
+
|
|
33
|
+
Example with (ax+b)^2 questions :
|
|
34
|
+
|
|
35
|
+
```js
|
|
36
|
+
import { firstIdentity } from 'exercises/calculLitteral/distributivity/firstIdentity';
|
|
37
|
+
|
|
38
|
+
console.log(firstIdentity.instruction);
|
|
39
|
+
const question = firstIdentity.generator(1);
|
|
40
|
+
console.log(question.startStatement);
|
|
41
|
+
console.log(question.answer);
|
|
42
|
+
|
|
43
|
+
//output :
|
|
44
|
+
// Développer et réduire :
|
|
45
|
+
// (2x+3)^2
|
|
46
|
+
// 4x^2 + 12x + 9
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
Some exercises do not have instructions, because the instruction is directly in the question itself.
|
|
50
|
+
|
|
51
|
+
A list of all exercises is exported from root.
|
|
52
|
+
|
|
53
|
+
## Expression tree and latex parser
|
|
54
|
+
|
|
55
|
+
Math expressions are implemented via a tree of Nodes that you'll find inside `tree/nodes`.
|
|
56
|
+
|
|
57
|
+
Any expression can be turned into a valid latex output via the `.toTex()` method.
|
|
58
|
+
|
|
59
|
+
They also can be simplified via the `simplifyNode` method.
|
|
60
|
+
|
|
61
|
+
## Math objects
|
|
62
|
+
|
|
63
|
+
This library also aims to implement pretty much all mathematical objects and notions up to 12th grade : all types of numbers and operations on them, but also points, vectors, polynomials, sets... Thus it can also be used for basic mathematics work.
|
|
64
|
+
|
|
65
|
+
## Minimal dependencies
|
|
66
|
+
|
|
67
|
+
We're trying to keep to our dependencies to a minimum. So far we're only using mathjs as an external library, to evaluate and simplify expression trees. We would love to have our own way of simplifying expressions in the future.
|
|
68
|
+
|
|
69
|
+
## How to contribute
|
|
70
|
+
|
|
71
|
+
Any contribution is welcomed.
|
|
72
|
+
|
|
73
|
+
There are tons of exercises left to implement !
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { Exercise, Question } from '../exercise';
|
|
2
|
-
/**
|
|
3
|
-
* a±b±c±d
|
|
4
|
-
*/
|
|
5
|
-
export declare const addAndSubExercise: Exercise;
|
|
6
|
-
export declare function getAddAndSubQuestions(): Question;
|
|
1
|
+
import { Exercise, Question } from '../exercise';
|
|
2
|
+
/**
|
|
3
|
+
* a±b±c±d
|
|
4
|
+
*/
|
|
5
|
+
export declare const addAndSubExercise: Exercise;
|
|
6
|
+
export declare function getAddAndSubQuestions(): Question;
|
|
7
7
|
//# sourceMappingURL=addAndSub.d.ts.map
|
|
@@ -1,41 +1,41 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getAddAndSubQuestions = exports.addAndSubExercise = void 0;
|
|
4
|
-
const randint_1 = require("../../math/utils/random/randint");
|
|
5
|
-
const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
|
|
6
|
-
const addNode_1 = require("../../tree/nodes/operators/addNode");
|
|
7
|
-
const getDistinctQuestions_1 = require("../utils/getDistinctQuestions");
|
|
8
|
-
/**
|
|
9
|
-
* a±b±c±d
|
|
10
|
-
*/
|
|
11
|
-
exports.addAndSubExercise = {
|
|
12
|
-
id: 'addAndSub',
|
|
13
|
-
connector: '=',
|
|
14
|
-
instruction: 'Calculer :',
|
|
15
|
-
label: 'Additions et soustractions',
|
|
16
|
-
levels: ['6', '5'],
|
|
17
|
-
section: 'Calculs',
|
|
18
|
-
isSingleStep: true,
|
|
19
|
-
generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getAddAndSubQuestions, nb),
|
|
20
|
-
keys: [],
|
|
21
|
-
};
|
|
22
|
-
function getAddAndSubQuestions() {
|
|
23
|
-
const nbOperations = (0, randint_1.randint)(2, 4);
|
|
24
|
-
const numbers = [];
|
|
25
|
-
for (let i = 0; i < nbOperations + 1; i++) {
|
|
26
|
-
numbers.push((0, randint_1.randint)(-15, 15, [0]));
|
|
27
|
-
}
|
|
28
|
-
const allNumbersNodes = numbers.map((nb) => new numberNode_1.NumberNode(nb));
|
|
29
|
-
let statementTree = new addNode_1.AddNode(allNumbersNodes[0], allNumbersNodes[1]);
|
|
30
|
-
for (let i = 2; i < allNumbersNodes.length; i++) {
|
|
31
|
-
statementTree = new addNode_1.AddNode(statementTree, allNumbersNodes[i]);
|
|
32
|
-
}
|
|
33
|
-
const answer = numbers.reduce((a, b) => a + b) + '';
|
|
34
|
-
const question = {
|
|
35
|
-
startStatement: statementTree.toTex(),
|
|
36
|
-
answer: answer,
|
|
37
|
-
keys: [],
|
|
38
|
-
};
|
|
39
|
-
return question;
|
|
40
|
-
}
|
|
41
|
-
exports.getAddAndSubQuestions = getAddAndSubQuestions;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getAddAndSubQuestions = exports.addAndSubExercise = void 0;
|
|
4
|
+
const randint_1 = require("../../math/utils/random/randint");
|
|
5
|
+
const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
|
|
6
|
+
const addNode_1 = require("../../tree/nodes/operators/addNode");
|
|
7
|
+
const getDistinctQuestions_1 = require("../utils/getDistinctQuestions");
|
|
8
|
+
/**
|
|
9
|
+
* a±b±c±d
|
|
10
|
+
*/
|
|
11
|
+
exports.addAndSubExercise = {
|
|
12
|
+
id: 'addAndSub',
|
|
13
|
+
connector: '=',
|
|
14
|
+
instruction: 'Calculer :',
|
|
15
|
+
label: 'Additions et soustractions',
|
|
16
|
+
levels: ['6', '5'],
|
|
17
|
+
section: 'Calculs',
|
|
18
|
+
isSingleStep: true,
|
|
19
|
+
generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getAddAndSubQuestions, nb),
|
|
20
|
+
keys: [],
|
|
21
|
+
};
|
|
22
|
+
function getAddAndSubQuestions() {
|
|
23
|
+
const nbOperations = (0, randint_1.randint)(2, 4);
|
|
24
|
+
const numbers = [];
|
|
25
|
+
for (let i = 0; i < nbOperations + 1; i++) {
|
|
26
|
+
numbers.push((0, randint_1.randint)(-15, 15, [0]));
|
|
27
|
+
}
|
|
28
|
+
const allNumbersNodes = numbers.map((nb) => new numberNode_1.NumberNode(nb));
|
|
29
|
+
let statementTree = new addNode_1.AddNode(allNumbersNodes[0], allNumbersNodes[1]);
|
|
30
|
+
for (let i = 2; i < allNumbersNodes.length; i++) {
|
|
31
|
+
statementTree = new addNode_1.AddNode(statementTree, allNumbersNodes[i]);
|
|
32
|
+
}
|
|
33
|
+
const answer = numbers.reduce((a, b) => a + b) + '';
|
|
34
|
+
const question = {
|
|
35
|
+
startStatement: statementTree.toTex(),
|
|
36
|
+
answer: answer,
|
|
37
|
+
keys: [],
|
|
38
|
+
};
|
|
39
|
+
return question;
|
|
40
|
+
}
|
|
41
|
+
exports.getAddAndSubQuestions = getAddAndSubQuestions;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { Exercise, Question } from '../exercise';
|
|
2
|
-
/**
|
|
3
|
-
* a±b±c±d
|
|
4
|
-
*/
|
|
5
|
-
export declare const addAndSubWithoutRelatives: Exercise;
|
|
6
|
-
export declare function getAddAndSubWithoutRelatives(): Question;
|
|
1
|
+
import { Exercise, Question } from '../exercise';
|
|
2
|
+
/**
|
|
3
|
+
* a±b±c±d
|
|
4
|
+
*/
|
|
5
|
+
export declare const addAndSubWithoutRelatives: Exercise;
|
|
6
|
+
export declare function getAddAndSubWithoutRelatives(): Question;
|
|
7
7
|
//# sourceMappingURL=addAndSubWithoutRelatives.d.ts.map
|
|
@@ -1,51 +1,51 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getAddAndSubWithoutRelatives = exports.addAndSubWithoutRelatives = void 0;
|
|
4
|
-
const randint_1 = require("../../math/utils/random/randint");
|
|
5
|
-
const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
|
|
6
|
-
const addNode_1 = require("../../tree/nodes/operators/addNode");
|
|
7
|
-
const getDistinctQuestions_1 = require("../utils/getDistinctQuestions");
|
|
8
|
-
/**
|
|
9
|
-
* a±b±c±d
|
|
10
|
-
*/
|
|
11
|
-
exports.addAndSubWithoutRelatives = {
|
|
12
|
-
id: 'addAndSubWithoutRelatives',
|
|
13
|
-
connector: '=',
|
|
14
|
-
instruction: 'Calculer :',
|
|
15
|
-
label: 'Additions et soustractions sans les nombres relatifs',
|
|
16
|
-
levels: ['6', '5'],
|
|
17
|
-
section: 'Calculs',
|
|
18
|
-
isSingleStep: true,
|
|
19
|
-
generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getAddAndSubWithoutRelatives, nb),
|
|
20
|
-
keys: [],
|
|
21
|
-
};
|
|
22
|
-
function getAddAndSubWithoutRelatives() {
|
|
23
|
-
let answer = -1;
|
|
24
|
-
let statementTree;
|
|
25
|
-
while (answer < 0) {
|
|
26
|
-
const nbOperations = (0, randint_1.randint)(2, 4);
|
|
27
|
-
let numbers = [];
|
|
28
|
-
do {
|
|
29
|
-
numbers = [];
|
|
30
|
-
numbers.push((0, randint_1.randint)(1, 15));
|
|
31
|
-
let sum = numbers[0];
|
|
32
|
-
for (let i = 1; i < nbOperations + 1; i++) {
|
|
33
|
-
numbers.push((0, randint_1.randint)(-sum, 15, [0]));
|
|
34
|
-
sum += numbers[i];
|
|
35
|
-
}
|
|
36
|
-
} while (numbers.every((a) => a > 0));
|
|
37
|
-
const allNumbersNodes = numbers.map((nb) => new numberNode_1.NumberNode(nb));
|
|
38
|
-
statementTree = new addNode_1.AddNode(allNumbersNodes[0], allNumbersNodes[1]);
|
|
39
|
-
for (let i = 2; i < allNumbersNodes.length; i++) {
|
|
40
|
-
statementTree = new addNode_1.AddNode(statementTree, allNumbersNodes[i]);
|
|
41
|
-
}
|
|
42
|
-
answer = numbers.reduce((a, b) => a + b);
|
|
43
|
-
}
|
|
44
|
-
const question = {
|
|
45
|
-
startStatement: statementTree.toTex(),
|
|
46
|
-
answer: answer.toString(),
|
|
47
|
-
keys: [],
|
|
48
|
-
};
|
|
49
|
-
return question;
|
|
50
|
-
}
|
|
51
|
-
exports.getAddAndSubWithoutRelatives = getAddAndSubWithoutRelatives;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getAddAndSubWithoutRelatives = exports.addAndSubWithoutRelatives = void 0;
|
|
4
|
+
const randint_1 = require("../../math/utils/random/randint");
|
|
5
|
+
const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
|
|
6
|
+
const addNode_1 = require("../../tree/nodes/operators/addNode");
|
|
7
|
+
const getDistinctQuestions_1 = require("../utils/getDistinctQuestions");
|
|
8
|
+
/**
|
|
9
|
+
* a±b±c±d
|
|
10
|
+
*/
|
|
11
|
+
exports.addAndSubWithoutRelatives = {
|
|
12
|
+
id: 'addAndSubWithoutRelatives',
|
|
13
|
+
connector: '=',
|
|
14
|
+
instruction: 'Calculer :',
|
|
15
|
+
label: 'Additions et soustractions sans les nombres relatifs',
|
|
16
|
+
levels: ['6', '5'],
|
|
17
|
+
section: 'Calculs',
|
|
18
|
+
isSingleStep: true,
|
|
19
|
+
generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getAddAndSubWithoutRelatives, nb),
|
|
20
|
+
keys: [],
|
|
21
|
+
};
|
|
22
|
+
function getAddAndSubWithoutRelatives() {
|
|
23
|
+
let answer = -1;
|
|
24
|
+
let statementTree;
|
|
25
|
+
while (answer < 0) {
|
|
26
|
+
const nbOperations = (0, randint_1.randint)(2, 4);
|
|
27
|
+
let numbers = [];
|
|
28
|
+
do {
|
|
29
|
+
numbers = [];
|
|
30
|
+
numbers.push((0, randint_1.randint)(1, 15));
|
|
31
|
+
let sum = numbers[0];
|
|
32
|
+
for (let i = 1; i < nbOperations + 1; i++) {
|
|
33
|
+
numbers.push((0, randint_1.randint)(-sum, 15, [0]));
|
|
34
|
+
sum += numbers[i];
|
|
35
|
+
}
|
|
36
|
+
} while (numbers.every((a) => a > 0));
|
|
37
|
+
const allNumbersNodes = numbers.map((nb) => new numberNode_1.NumberNode(nb));
|
|
38
|
+
statementTree = new addNode_1.AddNode(allNumbersNodes[0], allNumbersNodes[1]);
|
|
39
|
+
for (let i = 2; i < allNumbersNodes.length; i++) {
|
|
40
|
+
statementTree = new addNode_1.AddNode(statementTree, allNumbersNodes[i]);
|
|
41
|
+
}
|
|
42
|
+
answer = numbers.reduce((a, b) => a + b);
|
|
43
|
+
}
|
|
44
|
+
const question = {
|
|
45
|
+
startStatement: statementTree.toTex(),
|
|
46
|
+
answer: answer.toString(),
|
|
47
|
+
keys: [],
|
|
48
|
+
};
|
|
49
|
+
return question;
|
|
50
|
+
}
|
|
51
|
+
exports.getAddAndSubWithoutRelatives = getAddAndSubWithoutRelatives;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Exercise, Question } from '../../../exercises/exercise';
|
|
2
|
-
export declare const fractionAndIntegerDivision: Exercise;
|
|
3
|
-
export declare function getFractionAndIntegerDivision(): Question;
|
|
1
|
+
import { Exercise, Question } from '../../../exercises/exercise';
|
|
2
|
+
export declare const fractionAndIntegerDivision: Exercise;
|
|
3
|
+
export declare function getFractionAndIntegerDivision(): Question;
|
|
4
4
|
//# sourceMappingURL=fractionAndIntegerDivision.d.ts.map
|
|
@@ -1,37 +1,37 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getFractionAndIntegerDivision = exports.fractionAndIntegerDivision = void 0;
|
|
4
|
-
const getDistinctQuestions_1 = require("../../../exercises/utils/getDistinctQuestions");
|
|
5
|
-
const integer_1 = require("../../../math/numbers/integer/integer");
|
|
6
|
-
const rational_1 = require("../../../math/numbers/rationals/rational");
|
|
7
|
-
const randint_1 = require("../../../math/utils/random/randint");
|
|
8
|
-
const divideNode_1 = require("../../../tree/nodes/operators/divideNode");
|
|
9
|
-
const coinFlip_1 = require("../../../utils/coinFlip");
|
|
10
|
-
exports.fractionAndIntegerDivision = {
|
|
11
|
-
id: 'fractionAndIntegerDivision',
|
|
12
|
-
connector: '=',
|
|
13
|
-
instruction: "Calculer et donner le résultat sous la forme d'une fraction irréductible.",
|
|
14
|
-
label: "Division d'un entier et d'une fraction",
|
|
15
|
-
levels: ['4', '3', '2', '1'],
|
|
16
|
-
isSingleStep: false,
|
|
17
|
-
section: 'Fractions',
|
|
18
|
-
generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getFractionAndIntegerDivision, nb),
|
|
19
|
-
keys: [],
|
|
20
|
-
};
|
|
21
|
-
function getFractionAndIntegerDivision() {
|
|
22
|
-
const rational = rational_1.RationalConstructor.randomIrreductible();
|
|
23
|
-
const integer = new integer_1.Integer((0, randint_1.randint)(-10, 11, [0]));
|
|
24
|
-
const integerFirst = (0, coinFlip_1.coinFlip)();
|
|
25
|
-
const statementTree = integerFirst
|
|
26
|
-
? new divideNode_1.DivideNode(integer.toTree(), rational.toTree())
|
|
27
|
-
: new divideNode_1.DivideNode(rational.toTree(), integer.toTree());
|
|
28
|
-
const answerTree = integerFirst ? integer.divide(rational).toTree() : rational.divide(integer).toTree();
|
|
29
|
-
const question = {
|
|
30
|
-
instruction: '',
|
|
31
|
-
startStatement: statementTree.toTex(),
|
|
32
|
-
answer: answerTree.toTex(),
|
|
33
|
-
keys: [],
|
|
34
|
-
};
|
|
35
|
-
return question;
|
|
36
|
-
}
|
|
37
|
-
exports.getFractionAndIntegerDivision = getFractionAndIntegerDivision;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getFractionAndIntegerDivision = exports.fractionAndIntegerDivision = void 0;
|
|
4
|
+
const getDistinctQuestions_1 = require("../../../exercises/utils/getDistinctQuestions");
|
|
5
|
+
const integer_1 = require("../../../math/numbers/integer/integer");
|
|
6
|
+
const rational_1 = require("../../../math/numbers/rationals/rational");
|
|
7
|
+
const randint_1 = require("../../../math/utils/random/randint");
|
|
8
|
+
const divideNode_1 = require("../../../tree/nodes/operators/divideNode");
|
|
9
|
+
const coinFlip_1 = require("../../../utils/coinFlip");
|
|
10
|
+
exports.fractionAndIntegerDivision = {
|
|
11
|
+
id: 'fractionAndIntegerDivision',
|
|
12
|
+
connector: '=',
|
|
13
|
+
instruction: "Calculer et donner le résultat sous la forme d'une fraction irréductible.",
|
|
14
|
+
label: "Division d'un entier et d'une fraction",
|
|
15
|
+
levels: ['4', '3', '2', '1'],
|
|
16
|
+
isSingleStep: false,
|
|
17
|
+
section: 'Fractions',
|
|
18
|
+
generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getFractionAndIntegerDivision, nb),
|
|
19
|
+
keys: [],
|
|
20
|
+
};
|
|
21
|
+
function getFractionAndIntegerDivision() {
|
|
22
|
+
const rational = rational_1.RationalConstructor.randomIrreductible();
|
|
23
|
+
const integer = new integer_1.Integer((0, randint_1.randint)(-10, 11, [0]));
|
|
24
|
+
const integerFirst = (0, coinFlip_1.coinFlip)();
|
|
25
|
+
const statementTree = integerFirst
|
|
26
|
+
? new divideNode_1.DivideNode(integer.toTree(), rational.toTree())
|
|
27
|
+
: new divideNode_1.DivideNode(rational.toTree(), integer.toTree());
|
|
28
|
+
const answerTree = integerFirst ? integer.divide(rational).toTree() : rational.divide(integer).toTree();
|
|
29
|
+
const question = {
|
|
30
|
+
instruction: '',
|
|
31
|
+
startStatement: statementTree.toTex(),
|
|
32
|
+
answer: answerTree.toTex(),
|
|
33
|
+
keys: [],
|
|
34
|
+
};
|
|
35
|
+
return question;
|
|
36
|
+
}
|
|
37
|
+
exports.getFractionAndIntegerDivision = getFractionAndIntegerDivision;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Exercise, Question } from '../../../exercises/exercise';
|
|
2
|
-
export declare const fractionAndIntegerProduct: Exercise;
|
|
3
|
-
export declare function getFractionAndIntegerProduct(): Question;
|
|
1
|
+
import { Exercise, Question } from '../../../exercises/exercise';
|
|
2
|
+
export declare const fractionAndIntegerProduct: Exercise;
|
|
3
|
+
export declare function getFractionAndIntegerProduct(): Question;
|
|
4
4
|
//# sourceMappingURL=fractionAndIntegerProduct.d.ts.map
|
|
@@ -1,34 +1,34 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getFractionAndIntegerProduct = exports.fractionAndIntegerProduct = void 0;
|
|
4
|
-
const getDistinctQuestions_1 = require("../../../exercises/utils/getDistinctQuestions");
|
|
5
|
-
const integer_1 = require("../../../math/numbers/integer/integer");
|
|
6
|
-
const rational_1 = require("../../../math/numbers/rationals/rational");
|
|
7
|
-
const randint_1 = require("../../../math/utils/random/randint");
|
|
8
|
-
const multiplyNode_1 = require("../../../tree/nodes/operators/multiplyNode");
|
|
9
|
-
exports.fractionAndIntegerProduct = {
|
|
10
|
-
id: 'fractionAndIntegerProduct',
|
|
11
|
-
connector: '=',
|
|
12
|
-
instruction: "Calculer et donner le résultat sous la forme d'une fraction irréductible.",
|
|
13
|
-
label: "Produit d'un entier et d'une fraction",
|
|
14
|
-
levels: ['4', '3', '2', '1'],
|
|
15
|
-
isSingleStep: false,
|
|
16
|
-
section: 'Fractions',
|
|
17
|
-
generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getFractionAndIntegerProduct, nb),
|
|
18
|
-
keys: [],
|
|
19
|
-
};
|
|
20
|
-
function getFractionAndIntegerProduct() {
|
|
21
|
-
const rational = rational_1.RationalConstructor.randomIrreductible();
|
|
22
|
-
const integer = new integer_1.Integer((0, randint_1.randint)(-10, 11, [0]));
|
|
23
|
-
const statementTree = new multiplyNode_1.MultiplyNode(rational.toTree(), integer.toTree());
|
|
24
|
-
statementTree.shuffle();
|
|
25
|
-
const answerTree = rational.multiply(integer).toTree();
|
|
26
|
-
const question = {
|
|
27
|
-
instruction: '',
|
|
28
|
-
startStatement: statementTree.toTex(),
|
|
29
|
-
answer: answerTree.toTex(),
|
|
30
|
-
keys: [],
|
|
31
|
-
};
|
|
32
|
-
return question;
|
|
33
|
-
}
|
|
34
|
-
exports.getFractionAndIntegerProduct = getFractionAndIntegerProduct;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getFractionAndIntegerProduct = exports.fractionAndIntegerProduct = void 0;
|
|
4
|
+
const getDistinctQuestions_1 = require("../../../exercises/utils/getDistinctQuestions");
|
|
5
|
+
const integer_1 = require("../../../math/numbers/integer/integer");
|
|
6
|
+
const rational_1 = require("../../../math/numbers/rationals/rational");
|
|
7
|
+
const randint_1 = require("../../../math/utils/random/randint");
|
|
8
|
+
const multiplyNode_1 = require("../../../tree/nodes/operators/multiplyNode");
|
|
9
|
+
exports.fractionAndIntegerProduct = {
|
|
10
|
+
id: 'fractionAndIntegerProduct',
|
|
11
|
+
connector: '=',
|
|
12
|
+
instruction: "Calculer et donner le résultat sous la forme d'une fraction irréductible.",
|
|
13
|
+
label: "Produit d'un entier et d'une fraction",
|
|
14
|
+
levels: ['4', '3', '2', '1'],
|
|
15
|
+
isSingleStep: false,
|
|
16
|
+
section: 'Fractions',
|
|
17
|
+
generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getFractionAndIntegerProduct, nb),
|
|
18
|
+
keys: [],
|
|
19
|
+
};
|
|
20
|
+
function getFractionAndIntegerProduct() {
|
|
21
|
+
const rational = rational_1.RationalConstructor.randomIrreductible();
|
|
22
|
+
const integer = new integer_1.Integer((0, randint_1.randint)(-10, 11, [0]));
|
|
23
|
+
const statementTree = new multiplyNode_1.MultiplyNode(rational.toTree(), integer.toTree());
|
|
24
|
+
statementTree.shuffle();
|
|
25
|
+
const answerTree = rational.multiply(integer).toTree();
|
|
26
|
+
const question = {
|
|
27
|
+
instruction: '',
|
|
28
|
+
startStatement: statementTree.toTex(),
|
|
29
|
+
answer: answerTree.toTex(),
|
|
30
|
+
keys: [],
|
|
31
|
+
};
|
|
32
|
+
return question;
|
|
33
|
+
}
|
|
34
|
+
exports.getFractionAndIntegerProduct = getFractionAndIntegerProduct;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Exercise, Question } from '../../../exercises/exercise';
|
|
2
|
-
export declare const fractionAndIntegerSum: Exercise;
|
|
3
|
-
export declare function getFractionAndIntegerSum(): Question;
|
|
1
|
+
import { Exercise, Question } from '../../../exercises/exercise';
|
|
2
|
+
export declare const fractionAndIntegerSum: Exercise;
|
|
3
|
+
export declare function getFractionAndIntegerSum(): Question;
|
|
4
4
|
//# sourceMappingURL=fractionAndIntegerSum.d.ts.map
|
|
@@ -1,34 +1,34 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getFractionAndIntegerSum = exports.fractionAndIntegerSum = void 0;
|
|
4
|
-
const getDistinctQuestions_1 = require("../../../exercises/utils/getDistinctQuestions");
|
|
5
|
-
const integer_1 = require("../../../math/numbers/integer/integer");
|
|
6
|
-
const rational_1 = require("../../../math/numbers/rationals/rational");
|
|
7
|
-
const randint_1 = require("../../../math/utils/random/randint");
|
|
8
|
-
const addNode_1 = require("../../../tree/nodes/operators/addNode");
|
|
9
|
-
exports.fractionAndIntegerSum = {
|
|
10
|
-
id: 'fractionAndIntegerSum',
|
|
11
|
-
connector: '=',
|
|
12
|
-
instruction: "Calculer et donner le résultat sous la forme d'une fraction irréductible.",
|
|
13
|
-
label: "Somme d'un entier et d'une fraction",
|
|
14
|
-
levels: ['4', '3', '2', '1'],
|
|
15
|
-
isSingleStep: false,
|
|
16
|
-
section: 'Fractions',
|
|
17
|
-
generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getFractionAndIntegerSum, nb),
|
|
18
|
-
keys: [],
|
|
19
|
-
};
|
|
20
|
-
function getFractionAndIntegerSum() {
|
|
21
|
-
const rational = rational_1.RationalConstructor.randomIrreductible();
|
|
22
|
-
const integer = new integer_1.Integer((0, randint_1.randint)(-10, 11, [0]));
|
|
23
|
-
const statementTree = new addNode_1.AddNode(rational.toTree(), integer.toTree());
|
|
24
|
-
statementTree.shuffle();
|
|
25
|
-
const answerTree = rational.add(integer).toTree();
|
|
26
|
-
const question = {
|
|
27
|
-
instruction: '',
|
|
28
|
-
startStatement: statementTree.toTex(),
|
|
29
|
-
answer: answerTree.toTex(),
|
|
30
|
-
keys: [],
|
|
31
|
-
};
|
|
32
|
-
return question;
|
|
33
|
-
}
|
|
34
|
-
exports.getFractionAndIntegerSum = getFractionAndIntegerSum;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getFractionAndIntegerSum = exports.fractionAndIntegerSum = void 0;
|
|
4
|
+
const getDistinctQuestions_1 = require("../../../exercises/utils/getDistinctQuestions");
|
|
5
|
+
const integer_1 = require("../../../math/numbers/integer/integer");
|
|
6
|
+
const rational_1 = require("../../../math/numbers/rationals/rational");
|
|
7
|
+
const randint_1 = require("../../../math/utils/random/randint");
|
|
8
|
+
const addNode_1 = require("../../../tree/nodes/operators/addNode");
|
|
9
|
+
exports.fractionAndIntegerSum = {
|
|
10
|
+
id: 'fractionAndIntegerSum',
|
|
11
|
+
connector: '=',
|
|
12
|
+
instruction: "Calculer et donner le résultat sous la forme d'une fraction irréductible.",
|
|
13
|
+
label: "Somme d'un entier et d'une fraction",
|
|
14
|
+
levels: ['4', '3', '2', '1'],
|
|
15
|
+
isSingleStep: false,
|
|
16
|
+
section: 'Fractions',
|
|
17
|
+
generator: (nb) => (0, getDistinctQuestions_1.getDistinctQuestions)(getFractionAndIntegerSum, nb),
|
|
18
|
+
keys: [],
|
|
19
|
+
};
|
|
20
|
+
function getFractionAndIntegerSum() {
|
|
21
|
+
const rational = rational_1.RationalConstructor.randomIrreductible();
|
|
22
|
+
const integer = new integer_1.Integer((0, randint_1.randint)(-10, 11, [0]));
|
|
23
|
+
const statementTree = new addNode_1.AddNode(rational.toTree(), integer.toTree());
|
|
24
|
+
statementTree.shuffle();
|
|
25
|
+
const answerTree = rational.add(integer).toTree();
|
|
26
|
+
const question = {
|
|
27
|
+
instruction: '',
|
|
28
|
+
startStatement: statementTree.toTex(),
|
|
29
|
+
answer: answerTree.toTex(),
|
|
30
|
+
keys: [],
|
|
31
|
+
};
|
|
32
|
+
return question;
|
|
33
|
+
}
|
|
34
|
+
exports.getFractionAndIntegerSum = getFractionAndIntegerSum;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Exercise, Question } from '../../../exercises/exercise';
|
|
2
|
-
export declare const fractionToPercentToDecimal: Exercise;
|
|
3
|
-
export declare function getFractionToPercentToDecimal(): Question;
|
|
1
|
+
import { Exercise, Question } from '../../../exercises/exercise';
|
|
2
|
+
export declare const fractionToPercentToDecimal: Exercise;
|
|
3
|
+
export declare function getFractionToPercentToDecimal(): Question;
|
|
4
4
|
//# sourceMappingURL=fractionToPercentToDecimal.d.ts.map
|