math-exercises 1.3.12 → 1.3.13

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 (254) hide show
  1. package/README.md +73 -73
  2. package/lib/exercises/calcul/addAndSub.d.ts +6 -6
  3. package/lib/exercises/calcul/addAndSub.js +39 -39
  4. package/lib/exercises/calcul/fractions/fractionAndIntegerDivision.d.ts +3 -3
  5. package/lib/exercises/calcul/fractions/fractionAndIntegerDivision.js +35 -35
  6. package/lib/exercises/calcul/fractions/fractionAndIntegerProduct.d.ts +3 -3
  7. package/lib/exercises/calcul/fractions/fractionAndIntegerProduct.js +32 -32
  8. package/lib/exercises/calcul/fractions/fractionAndIntegerSum.d.ts +3 -3
  9. package/lib/exercises/calcul/fractions/fractionAndIntegerSum.js +32 -32
  10. package/lib/exercises/calcul/fractions/fractionsDivision.d.ts +3 -3
  11. package/lib/exercises/calcul/fractions/fractionsDivision.js +29 -29
  12. package/lib/exercises/calcul/fractions/fractionsProduct.d.ts +3 -3
  13. package/lib/exercises/calcul/fractions/fractionsProduct.js +28 -28
  14. package/lib/exercises/calcul/fractions/fractionsSum.d.ts +3 -3
  15. package/lib/exercises/calcul/fractions/fractionsSum.js +28 -28
  16. package/lib/exercises/calcul/fractions/simplifyFraction.d.ts +3 -3
  17. package/lib/exercises/calcul/fractions/simplifyFraction.js +24 -24
  18. package/lib/exercises/calcul/operations/operationsPriorities.d.ts +10 -10
  19. package/lib/exercises/calcul/operations/operationsPriorities.js +98 -98
  20. package/lib/exercises/calcul/operations/operationsPrioritiesWithoutRelative.js +111 -111
  21. package/lib/exercises/calcul/operationsPriorities.js +88 -88
  22. package/lib/exercises/calcul/rounding/rounding.d.ts +19 -19
  23. package/lib/exercises/calcul/rounding/rounding.js +85 -85
  24. package/lib/exercises/calculLitteral/distributivity/allIdentities.d.ts +3 -3
  25. package/lib/exercises/calculLitteral/distributivity/allIdentities.js +27 -27
  26. package/lib/exercises/calculLitteral/distributivity/doubleDistributivity.d.ts +3 -3
  27. package/lib/exercises/calculLitteral/distributivity/doubleDistributivity.js +30 -30
  28. package/lib/exercises/calculLitteral/distributivity/firstIdentity.d.ts +3 -3
  29. package/lib/exercises/calculLitteral/distributivity/firstIdentity.js +31 -31
  30. package/lib/exercises/calculLitteral/distributivity/secondIdentity.d.ts +3 -3
  31. package/lib/exercises/calculLitteral/distributivity/secondIdentity.js +32 -32
  32. package/lib/exercises/calculLitteral/distributivity/simpleDistributivity.d.ts +3 -3
  33. package/lib/exercises/calculLitteral/distributivity/simpleDistributivity.js +32 -32
  34. package/lib/exercises/calculLitteral/distributivity/thirdIdentity.d.ts +3 -3
  35. package/lib/exercises/calculLitteral/distributivity/thirdIdentity.js +31 -31
  36. package/lib/exercises/calculLitteral/equation/equationType1Exercise.d.ts +6 -6
  37. package/lib/exercises/calculLitteral/equation/equationType1Exercise.js +37 -37
  38. package/lib/exercises/calculLitteral/equation/equationType2Exercise.d.ts +6 -6
  39. package/lib/exercises/calculLitteral/equation/equationType2Exercise.js +40 -40
  40. package/lib/exercises/calculLitteral/equation/equationType3Exercise.d.ts +6 -6
  41. package/lib/exercises/calculLitteral/equation/equationType3Exercise.js +41 -41
  42. package/lib/exercises/calculLitteral/equation/equationType4Exercise.d.ts +6 -6
  43. package/lib/exercises/calculLitteral/equation/equationType4Exercise.js +43 -43
  44. package/lib/exercises/calculLitteral/factorisation/factoIdRmq1.d.ts +3 -3
  45. package/lib/exercises/calculLitteral/factorisation/factoIdRmq1.js +32 -32
  46. package/lib/exercises/calculLitteral/factorisation/factoIdRmq2.d.ts +3 -3
  47. package/lib/exercises/calculLitteral/factorisation/factoIdRmq2.js +33 -33
  48. package/lib/exercises/calculLitteral/factorisation/factoIdRmq3.d.ts +3 -3
  49. package/lib/exercises/calculLitteral/factorisation/factoIdRmq3.js +32 -32
  50. package/lib/exercises/calculLitteral/factorisation/factoType1Exercise.d.ts +6 -6
  51. package/lib/exercises/calculLitteral/factorisation/factoType1Exercise.js +38 -38
  52. package/lib/exercises/derivation/derivative/affineDerivative.d.ts +4 -0
  53. package/lib/exercises/derivation/derivative/affineDerivative.d.ts.map +1 -0
  54. package/lib/exercises/derivation/derivative/affineDerivative.js +27 -0
  55. package/lib/exercises/derivation/derivative/secondDegreeDerivative.d.ts +1 -0
  56. package/lib/exercises/derivation/derivative/secondDegreeDerivative.d.ts.map +1 -0
  57. package/lib/exercises/derivation/derivative/secondDegreeDerivative.js +28 -0
  58. package/lib/exercises/derivation/derivative/thridDegreeDerivative.d.ts +1 -0
  59. package/lib/exercises/derivation/derivative/thridDegreeDerivative.d.ts.map +1 -0
  60. package/lib/exercises/derivation/derivative/thridDegreeDerivative.js +1 -0
  61. package/lib/exercises/exercise.d.ts +16 -16
  62. package/lib/exercises/exercise.js +7 -7
  63. package/lib/exercises/exercises.d.ts +1 -1
  64. package/lib/exercises/exercises.js +113 -113
  65. package/lib/exercises/geometry/cartesian/midpoint.d.ts +3 -3
  66. package/lib/exercises/geometry/cartesian/midpoint.js +29 -29
  67. package/lib/exercises/geometry/vectors/scalarProductViaCoords.d.ts +3 -3
  68. package/lib/exercises/geometry/vectors/scalarProductViaCoords.js +28 -28
  69. package/lib/exercises/geometry/vectors/scalarProductViaNorms.js +27 -27
  70. package/lib/exercises/powers/powersDivision.d.ts +7 -7
  71. package/lib/exercises/powers/powersDivision.js +44 -44
  72. package/lib/exercises/powers/powersOfTenToDecimal.d.ts +6 -6
  73. package/lib/exercises/powers/powersOfTenToDecimal.js +32 -32
  74. package/lib/exercises/powers/powersPower.d.ts +7 -7
  75. package/lib/exercises/powers/powersPower.js +43 -43
  76. package/lib/exercises/powers/powersProduct.d.ts +7 -7
  77. package/lib/exercises/powers/powersProduct.js +44 -44
  78. package/lib/exercises/powers/scientificToDecimal.d.ts +6 -6
  79. package/lib/exercises/powers/scientificToDecimal.js +37 -37
  80. package/lib/exercises/sequences/geometric/geometricExplicitFormulaUsage.d.ts +3 -3
  81. package/lib/exercises/sequences/geometric/geometricExplicitFormulaUsage.js +34 -34
  82. package/lib/exercises/sequences/geometric/geometricFindExplicitFormula.d.ts +3 -3
  83. package/lib/exercises/sequences/geometric/geometricFindExplicitFormula.js +33 -33
  84. package/lib/exercises/sequences/geometric/geometricFindReason.d.ts +3 -3
  85. package/lib/exercises/sequences/geometric/geometricFindReason.js +29 -29
  86. package/lib/exercises/sequences/geometric/geometricReasonUsage.d.ts +3 -3
  87. package/lib/exercises/sequences/geometric/geometricReasonUsage.js +28 -28
  88. package/lib/exercises/sequences/geometric/geometricRecurrenceFormulaUsage.d.ts +7 -7
  89. package/lib/exercises/sequences/geometric/geometricRecurrenceFormulaUsage.js +28 -28
  90. package/lib/exercises/squareRoots/simpifySquareRoot.d.ts +3 -3
  91. package/lib/exercises/squareRoots/simpifySquareRoot.js +27 -27
  92. package/lib/exercises/trigonometry/mainRemarkableValues.d.ts +3 -3
  93. package/lib/exercises/trigonometry/mainRemarkableValues.js +28 -28
  94. package/lib/exercises/trigonometry/remarkableValues.d.ts +3 -3
  95. package/lib/exercises/trigonometry/remarkableValues.js +28 -28
  96. package/lib/exercises/utils/getDistinctQuestions.d.ts +2 -2
  97. package/lib/exercises/utils/getDistinctQuestions.js +15 -15
  98. package/lib/geometry/point.js +27 -27
  99. package/lib/geometry/vector.js +31 -31
  100. package/lib/index.d.ts +3 -2
  101. package/lib/index.d.ts.map +1 -1
  102. package/lib/index.js +39 -6
  103. package/lib/math/geometry/point.d.ts +12 -12
  104. package/lib/math/geometry/point.js +27 -27
  105. package/lib/math/geometry/vector.d.ts +15 -15
  106. package/lib/math/geometry/vector.js +31 -31
  107. package/lib/math/numbers/decimals/decimal.d.ts +24 -24
  108. package/lib/math/numbers/decimals/decimal.js +140 -140
  109. package/lib/math/numbers/epsilon.d.ts +1 -1
  110. package/lib/math/numbers/epsilon.js +10 -10
  111. package/lib/math/numbers/integer/integer.d.ts +14 -14
  112. package/lib/math/numbers/integer/integer.js +68 -68
  113. package/lib/math/numbers/integer/power.d.ts +13 -13
  114. package/lib/math/numbers/integer/power.js +52 -52
  115. package/lib/math/numbers/nombre.d.ts +13 -13
  116. package/lib/math/numbers/nombre.js +10 -10
  117. package/lib/math/numbers/rationals/rational.d.ts +25 -25
  118. package/lib/math/numbers/rationals/rational.js +113 -113
  119. package/lib/math/numbers/reals/real.d.ts +9 -9
  120. package/lib/math/numbers/reals/real.js +16 -16
  121. package/lib/math/numbers/reals/squareRoot.d.ts +18 -18
  122. package/lib/math/numbers/reals/squareRoot.js +63 -63
  123. package/lib/math/polynomials/affine.d.ts +15 -15
  124. package/lib/math/polynomials/affine.js +42 -42
  125. package/lib/math/polynomials/polynomial.d.ts +25 -24
  126. package/lib/math/polynomials/polynomial.d.ts.map +1 -1
  127. package/lib/math/polynomials/polynomial.js +129 -125
  128. package/lib/math/sequences/arithmeticSequence.js +1 -1
  129. package/lib/math/sequences/geometricSequence.d.ts +3 -3
  130. package/lib/math/sequences/geometricSequence.js +8 -8
  131. package/lib/math/sequences/sequence.d.ts +22 -22
  132. package/lib/math/sequences/sequence.js +21 -21
  133. package/lib/math/sets/discreteSet.d.ts +10 -10
  134. package/lib/math/sets/discreteSet.js +28 -28
  135. package/lib/math/sets/emptySet.js +6 -6
  136. package/lib/math/sets/intervals/intervals.d.ts +26 -26
  137. package/lib/math/sets/intervals/intervals.js +104 -104
  138. package/lib/math/sets/mathSet.d.ts +7 -7
  139. package/lib/math/sets/mathSet.js +10 -10
  140. package/lib/math/sets/mathSetInterface.d.ts +5 -5
  141. package/lib/math/sets/mathSetInterface.js +2 -2
  142. package/lib/math/trigonometry/remarkableValue.d.ts +10 -10
  143. package/lib/math/trigonometry/remarkableValue.js +29 -29
  144. package/lib/math/trigonometry/remarkableValues.d.ts +2 -2
  145. package/lib/math/trigonometry/remarkableValues.js +51 -51
  146. package/lib/math/utils/arithmetic/coprimesOf.d.ts +1 -1
  147. package/lib/math/utils/arithmetic/coprimesOf.js +13 -13
  148. package/lib/math/utils/arithmetic/dividersOf.d.ts +1 -1
  149. package/lib/math/utils/arithmetic/dividersOf.js +12 -12
  150. package/lib/math/utils/arithmetic/gcd.d.ts +1 -1
  151. package/lib/math/utils/arithmetic/gcd.js +7 -7
  152. package/lib/math/utils/arithmetic/isSquare.d.ts +1 -1
  153. package/lib/math/utils/arithmetic/isSquare.js +7 -7
  154. package/lib/math/utils/arithmetic/lcd.d.ts +1 -1
  155. package/lib/math/utils/arithmetic/lcd.js +12 -12
  156. package/lib/math/utils/arithmetic/nonCoprimesOf.d.ts +1 -1
  157. package/lib/math/utils/arithmetic/nonCoprimesOf.js +13 -13
  158. package/lib/math/utils/arithmetic/nonDividersOf.d.ts +1 -1
  159. package/lib/math/utils/arithmetic/nonDividersOf.js +14 -14
  160. package/lib/math/utils/arithmetic/primeFactors.d.ts +5 -5
  161. package/lib/math/utils/arithmetic/primeFactors.js +22 -22
  162. package/lib/math/utils/decimals/decimalPartLengthOf.d.ts +1 -1
  163. package/lib/math/utils/decimals/decimalPartLengthOf.js +14 -14
  164. package/lib/math/utils/random/randTupleInt.d.ts +13 -13
  165. package/lib/math/utils/random/randTupleInt.js +30 -30
  166. package/lib/math/utils/random/randint.d.ts +4 -4
  167. package/lib/math/utils/random/randint.js +18 -18
  168. package/lib/math/utils/round.d.ts +1 -1
  169. package/lib/math/utils/round.js +8 -8
  170. package/lib/mathutils/arithmetic/coprimesOf.js +13 -13
  171. package/lib/mathutils/arithmetic/dividersOf.js +12 -12
  172. package/lib/mathutils/arithmetic/gcd.js +7 -7
  173. package/lib/mathutils/arithmetic/isSquare.js +7 -7
  174. package/lib/mathutils/arithmetic/lcd.js +12 -12
  175. package/lib/mathutils/arithmetic/nonCoprimesOf.js +13 -13
  176. package/lib/mathutils/arithmetic/nonDividersOf.js +14 -14
  177. package/lib/mathutils/arithmetic/primeFactors.js +22 -22
  178. package/lib/mathutils/decimals/decimalPartLengthOf.js +14 -14
  179. package/lib/mathutils/random/randTupleInt.js +30 -30
  180. package/lib/mathutils/random/randint.js +18 -18
  181. package/lib/mathutils/round.js +8 -8
  182. package/lib/numbers/decimals/decimal.js +140 -140
  183. package/lib/numbers/epsilon.js +10 -10
  184. package/lib/numbers/integer/integer.js +68 -68
  185. package/lib/numbers/integer/power.js +52 -52
  186. package/lib/numbers/nombre.js +10 -10
  187. package/lib/numbers/rationals/rational.js +113 -113
  188. package/lib/numbers/reals/real.js +16 -16
  189. package/lib/numbers/reals/squareRoot.js +63 -63
  190. package/lib/polynomials/affine.js +42 -42
  191. package/lib/polynomials/polynomial.js +125 -125
  192. package/lib/server.d.ts +2 -0
  193. package/lib/server.d.ts.map +1 -0
  194. package/lib/server.js +33 -0
  195. package/lib/sets/discreteSet.js +28 -28
  196. package/lib/sets/emptySet.js +6 -6
  197. package/lib/sets/intervals/intervals.js +108 -104
  198. package/lib/sets/intervals/union.js +1 -1
  199. package/lib/sets/mathSet.js +10 -10
  200. package/lib/sets/mathSetInterface.js +2 -2
  201. package/lib/tree/nodes/functions/cosNode.d.ts +9 -9
  202. package/lib/tree/nodes/functions/cosNode.js +21 -21
  203. package/lib/tree/nodes/functions/functionNode.d.ts +14 -14
  204. package/lib/tree/nodes/functions/functionNode.js +20 -20
  205. package/lib/tree/nodes/functions/oppositeNode.d.ts +7 -7
  206. package/lib/tree/nodes/functions/oppositeNode.js +26 -26
  207. package/lib/tree/nodes/functions/sinNode.js +1 -1
  208. package/lib/tree/nodes/functions/sqrtNode.d.ts +8 -8
  209. package/lib/tree/nodes/functions/sqrtNode.js +18 -18
  210. package/lib/tree/nodes/node.d.ts +12 -12
  211. package/lib/tree/nodes/node.js +11 -11
  212. package/lib/tree/nodes/numbers/constantNode.d.ts +9 -9
  213. package/lib/tree/nodes/numbers/constantNode.js +18 -18
  214. package/lib/tree/nodes/numbers/numberNode.d.ts +10 -10
  215. package/lib/tree/nodes/numbers/numberNode.js +19 -19
  216. package/lib/tree/nodes/numbers/piNode.d.ts +2 -2
  217. package/lib/tree/nodes/numbers/piNode.js +5 -5
  218. package/lib/tree/nodes/operators/addNode.d.ts +7 -7
  219. package/lib/tree/nodes/operators/addNode.js +19 -19
  220. package/lib/tree/nodes/operators/divideNode.d.ts +11 -11
  221. package/lib/tree/nodes/operators/divideNode.js +34 -34
  222. package/lib/tree/nodes/operators/equalNode.d.ts +7 -7
  223. package/lib/tree/nodes/operators/equalNode.js +16 -16
  224. package/lib/tree/nodes/operators/fractionNode.d.ts +11 -11
  225. package/lib/tree/nodes/operators/fractionNode.js +20 -20
  226. package/lib/tree/nodes/operators/multiplyNode.d.ts +7 -7
  227. package/lib/tree/nodes/operators/multiplyNode.js +43 -43
  228. package/lib/tree/nodes/operators/operatorNode.d.ts +21 -21
  229. package/lib/tree/nodes/operators/operatorNode.js +35 -35
  230. package/lib/tree/nodes/operators/powerNode.d.ts +7 -7
  231. package/lib/tree/nodes/operators/powerNode.js +33 -33
  232. package/lib/tree/nodes/operators/substractNode.d.ts +7 -7
  233. package/lib/tree/nodes/operators/substractNode.js +24 -24
  234. package/lib/tree/nodes/variables/variableNode.d.ts +8 -8
  235. package/lib/tree/nodes/variables/variableNode.js +19 -19
  236. package/lib/tree/parsers/derivateParser.js +62 -62
  237. package/lib/tree/parsers/latexParser.js +110 -110
  238. package/lib/tree/parsers/simplify.d.ts +2 -2
  239. package/lib/tree/parsers/simplify.js +52 -52
  240. package/lib/utils/arrayEqual.d.ts +1 -1
  241. package/lib/utils/arrayEqual.js +13 -13
  242. package/lib/utils/coin.js +7 -7
  243. package/lib/utils/coinFlip.d.ts +1 -1
  244. package/lib/utils/coinFlip.js +7 -7
  245. package/lib/utils/random.d.ts +1 -1
  246. package/lib/utils/random.js +7 -7
  247. package/lib/utils/shuffle.d.ts +1 -1
  248. package/lib/utils/shuffle.js +15 -15
  249. package/package.json +50 -45
  250. package/lib/exercises/calculLitteral/factorisation/factoIdRmq.d.ts +0 -7
  251. package/lib/exercises/calculLitteral/factorisation/factoIdRmq.d.ts.map +0 -1
  252. package/lib/exercises/calculLitteral/factorisation/factoIdRmq.js +0 -38
  253. package/lib/trigonometry/remarkableValue.js +0 -29
  254. package/lib/trigonometry/remarkableValues.js +0 -51
@@ -1,16 +1,16 @@
1
- import { Nombre } from '../numbers/nombre';
2
- import { MathSet } from '../sets/mathSet';
3
- import { Polynomial } from './polynomial';
4
- export declare abstract class AffineConstructor {
5
- static random(domainA?: MathSet, domainB?: MathSet): Affine;
6
- static differentRandoms(nb: number, domainA?: MathSet, domainB?: MathSet): Affine[];
7
- }
8
- export declare class Affine extends Polynomial {
9
- a: number;
10
- b: number;
11
- variable: string;
12
- constructor(a: number, b: number, variable?: string);
13
- getRoot(): Nombre;
14
- toString(): string;
15
- }
1
+ import { Nombre } from '../numbers/nombre';
2
+ import { MathSet } from '../sets/mathSet';
3
+ import { Polynomial } from './polynomial';
4
+ export declare abstract class AffineConstructor {
5
+ static random(domainA?: MathSet, domainB?: MathSet): Affine;
6
+ static differentRandoms(nb: number, domainA?: MathSet, domainB?: MathSet): Affine[];
7
+ }
8
+ export declare class Affine extends Polynomial {
9
+ a: number;
10
+ b: number;
11
+ variable: string;
12
+ constructor(a: number, b: number, variable?: string);
13
+ getRoot(): Nombre;
14
+ toString(): string;
15
+ }
16
16
  //# sourceMappingURL=affine.d.ts.map
@@ -1,42 +1,42 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Affine = exports.AffineConstructor = void 0;
4
- const integer_1 = require("../numbers/integer/integer");
5
- const rational_1 = require("../numbers/rationals/rational");
6
- const discreteSet_1 = require("../sets/discreteSet");
7
- const intervals_1 = require("../sets/intervals/intervals");
8
- const polynomial_1 = require("./polynomial");
9
- class AffineConstructor {
10
- static random(domainA = new intervals_1.Interval('[[-10; 10]]').difference(new discreteSet_1.DiscreteSet([new integer_1.Integer(0)])), domainB = new intervals_1.Interval('[[-10; 10]]')) {
11
- const a = domainA.getRandomElement();
12
- const b = domainB.getRandomElement();
13
- return new Affine(a.value, b.value);
14
- }
15
- static differentRandoms(nb, domainA = new intervals_1.Interval('[[-10; 10]]').difference(new discreteSet_1.DiscreteSet([new integer_1.Integer(0)])), domainB = new intervals_1.Interval('[[-10; 10]]')) {
16
- const res = [];
17
- for (let i = 0; i < nb; i++) {
18
- let aff;
19
- do {
20
- aff = AffineConstructor.random(domainA, domainB);
21
- } while (res.some((affine) => affine.equals(aff)));
22
- res.push(aff);
23
- }
24
- return res;
25
- }
26
- }
27
- exports.AffineConstructor = AffineConstructor;
28
- class Affine extends polynomial_1.Polynomial {
29
- constructor(a, b, variable = 'x') {
30
- super([b, a], variable);
31
- this.a = a;
32
- this.b = b;
33
- this.variable = variable;
34
- }
35
- getRoot() {
36
- return new rational_1.Rational(-this.b, this.a).simplify();
37
- }
38
- toString() {
39
- return super.toTex();
40
- }
41
- }
42
- exports.Affine = Affine;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Affine = exports.AffineConstructor = void 0;
4
+ const integer_1 = require("../numbers/integer/integer");
5
+ const rational_1 = require("../numbers/rationals/rational");
6
+ const discreteSet_1 = require("../sets/discreteSet");
7
+ const intervals_1 = require("../sets/intervals/intervals");
8
+ const polynomial_1 = require("./polynomial");
9
+ class AffineConstructor {
10
+ static random(domainA = new intervals_1.Interval('[[-10; 10]]').difference(new discreteSet_1.DiscreteSet([new integer_1.Integer(0)])), domainB = new intervals_1.Interval('[[-10; 10]]')) {
11
+ const a = domainA.getRandomElement();
12
+ const b = domainB.getRandomElement();
13
+ return new Affine(a.value, b.value);
14
+ }
15
+ static differentRandoms(nb, domainA = new intervals_1.Interval('[[-10; 10]]').difference(new discreteSet_1.DiscreteSet([new integer_1.Integer(0)])), domainB = new intervals_1.Interval('[[-10; 10]]')) {
16
+ const res = [];
17
+ for (let i = 0; i < nb; i++) {
18
+ let aff;
19
+ do {
20
+ aff = AffineConstructor.random(domainA, domainB);
21
+ } while (res.some((affine) => affine.equals(aff)));
22
+ res.push(aff);
23
+ }
24
+ return res;
25
+ }
26
+ }
27
+ exports.AffineConstructor = AffineConstructor;
28
+ class Affine extends polynomial_1.Polynomial {
29
+ constructor(a, b, variable = 'x') {
30
+ super([b, a], variable);
31
+ this.a = a;
32
+ this.b = b;
33
+ this.variable = variable;
34
+ }
35
+ getRoot() {
36
+ return new rational_1.Rational(-this.b, this.a).simplify();
37
+ }
38
+ toString() {
39
+ return super.toTex();
40
+ }
41
+ }
42
+ exports.Affine = Affine;
@@ -1,25 +1,26 @@
1
- import { Node } from '../../tree/nodes/node';
2
- export declare class Polynomial {
3
- degree: number;
4
- variable: string;
5
- /**
6
- * coefficients[i] est le coeff de x^i
7
- */
8
- coefficients: number[];
9
- /**
10
- *
11
- * @param coefficients coefficients[i] est le coeff de x^i
12
- * @param variable
13
- */
14
- constructor(coefficients: number[], variable?: string);
15
- equals(P: Polynomial): boolean;
16
- getRoots(): void;
17
- add(P: Polynomial): Polynomial;
18
- times(nb: number): Polynomial;
19
- multiply(Q: Polynomial): Polynomial;
20
- opposite(): Polynomial;
21
- toTree(): Node;
22
- toTex(): string;
23
- toString(): string;
24
- }
1
+ import { Node } from '../../tree/nodes/node';
2
+ export declare class Polynomial {
3
+ degree: number;
4
+ variable: string;
5
+ /**
6
+ * coefficients[i] est le coeff de x^i
7
+ */
8
+ coefficients: number[];
9
+ /**
10
+ *
11
+ * @param coefficients coefficients[i] est le coeff de x^i
12
+ * @param variable
13
+ */
14
+ constructor(coefficients: number[], variable?: string);
15
+ equals(P: Polynomial): boolean;
16
+ getRoots(): void;
17
+ add(P: Polynomial): Polynomial;
18
+ times(nb: number): Polynomial;
19
+ multiply(Q: Polynomial): Polynomial;
20
+ opposite(): Polynomial;
21
+ derivate(): Polynomial;
22
+ toTree(): Node;
23
+ toTex(): string;
24
+ toString(): string;
25
+ }
25
26
  //# sourceMappingURL=polynomial.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"polynomial.d.ts","sourceRoot":"","sources":["../../../src/math/polynomials/polynomial.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAS7C,qBAAa,UAAU;IACrB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB;;OAEG;IACH,YAAY,EAAE,MAAM,EAAE,CAAC;IAEvB;;;;OAIG;gBACS,YAAY,EAAE,MAAM,EAAE,EAAE,QAAQ,GAAE,MAAY;IAS1D,MAAM,CAAC,CAAC,EAAE,UAAU,GAAG,OAAO;IAG9B,QAAQ;IACR,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,UAAU;IAc9B,KAAK,CAAC,EAAE,EAAE,MAAM,GAAG,UAAU;IAM7B,QAAQ,CAAC,CAAC,EAAE,UAAU,GAAG,UAAU;IAkBnC,QAAQ,IAAI,UAAU;IAOtB,MAAM,IAAI,IAAI;IAmCd,KAAK,IAAI,MAAM;IAkBf,QAAQ,IAAI,MAAM;CAGnB"}
1
+ {"version":3,"file":"polynomial.d.ts","sourceRoot":"","sources":["../../../src/math/polynomials/polynomial.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAS7C,qBAAa,UAAU;IACrB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB;;OAEG;IACH,YAAY,EAAE,MAAM,EAAE,CAAC;IAEvB;;;;OAIG;gBACS,YAAY,EAAE,MAAM,EAAE,EAAE,QAAQ,GAAE,MAAY;IAS1D,MAAM,CAAC,CAAC,EAAE,UAAU,GAAG,OAAO;IAG9B,QAAQ;IACR,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,UAAU;IAc9B,KAAK,CAAC,EAAE,EAAE,MAAM,GAAG,UAAU;IAM7B,QAAQ,CAAC,CAAC,EAAE,UAAU,GAAG,UAAU;IAkBnC,QAAQ,IAAI,UAAU;IAOtB,QAAQ,IAAI,UAAU;IAItB,MAAM,IAAI,IAAI;IAmCd,KAAK,IAAI,MAAM;IAkBf,QAAQ,IAAI,MAAM;CAGnB"}
@@ -1,125 +1,129 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Polynomial = void 0;
4
- const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
5
- const addNode_1 = require("../../tree/nodes/operators/addNode");
6
- const multiplyNode_1 = require("../../tree/nodes/operators/multiplyNode");
7
- const oppositeNode_1 = require("../../tree/nodes/functions/oppositeNode");
8
- const powerNode_1 = require("../../tree/nodes/operators/powerNode");
9
- const variableNode_1 = require("../../tree/nodes/variables/variableNode");
10
- class Polynomial {
11
- /**
12
- *
13
- * @param coefficients coefficients[i] est le coeff de x^i
14
- * @param variable
15
- */
16
- constructor(coefficients, variable = 'x') {
17
- if (coefficients.length === 0)
18
- throw Error('coeffs must be not null');
19
- if (coefficients[coefficients.length - 1] === 0) {
20
- throw Error('n-th coeff must be not null');
21
- }
22
- this.coefficients = coefficients;
23
- this.variable = variable;
24
- this.degree = coefficients.length - 1;
25
- }
26
- equals(P) {
27
- return P.degree === this.degree && this.coefficients.every((coeff, i) => coeff === P.coefficients[i]);
28
- }
29
- getRoots() { }
30
- add(P) {
31
- if (P.variable !== this.variable)
32
- throw Error("Can't add two polynomials with different variables");
33
- const newDegree = P.degree === this.degree && P.coefficients[P.degree] === -this.coefficients[this.degree]
34
- ? P.degree - 1
35
- : Math.max(P.degree, this.degree);
36
- const res = [];
37
- for (let i = 0; i < newDegree + 1; i++) {
38
- res[i] = P.coefficients[i] + this.coefficients[i];
39
- }
40
- return new Polynomial(res, this.variable);
41
- }
42
- times(nb) {
43
- return new Polynomial(this.coefficients.map((coeff) => coeff * nb), this.variable);
44
- }
45
- multiply(Q) {
46
- if (Q.variable !== this.variable)
47
- throw Error("Can't multiply two polynomials with different variables");
48
- const p = this.degree;
49
- const q = Q.degree;
50
- const res = Array.apply(0, new Array(this.degree)).map((i) => 0);
51
- for (let k = 0; k <= p + q; k++) {
52
- let sum = 0;
53
- for (let m = 0; m <= k; m++) {
54
- sum += (this.coefficients[m] || 0) * (Q.coefficients[k - m] || 0);
55
- }
56
- res[k] = sum;
57
- }
58
- return new Polynomial(res, this.variable);
59
- }
60
- opposite() {
61
- return new Polynomial(this.coefficients.map((coeff) => -coeff), this.variable);
62
- }
63
- toTree() {
64
- const recursive = (cursor) => {
65
- const coeff = this.coefficients[cursor];
66
- if (coeff === 0)
67
- return recursive(cursor - 1);
68
- if (cursor === 0) {
69
- return new numberNode_1.NumberNode(coeff);
70
- }
71
- const monome = cursor > 1
72
- ? new powerNode_1.PowerNode(new variableNode_1.VariableNode(this.variable), new numberNode_1.NumberNode(cursor))
73
- : new variableNode_1.VariableNode(this.variable);
74
- let res;
75
- if (coeff === 1)
76
- res = monome;
77
- else if (coeff === -1)
78
- res = new oppositeNode_1.OppositeNode(monome);
79
- else
80
- res = new multiplyNode_1.MultiplyNode(new numberNode_1.NumberNode(coeff), monome);
81
- let nextCoeff;
82
- for (let i = cursor - 1; i > -1; i--) {
83
- if (this.coefficients[i]) {
84
- nextCoeff = this.coefficients[i];
85
- break;
86
- }
87
- }
88
- if (nextCoeff) {
89
- return new addNode_1.AddNode(res, recursive(cursor - 1));
90
- }
91
- else {
92
- return res;
93
- }
94
- };
95
- return recursive(this.degree);
96
- }
97
- toTex() {
98
- let s = '';
99
- for (let i = this.degree; i > -1; i--) {
100
- const coeff = this.coefficients[i];
101
- if (coeff === 0)
102
- continue;
103
- if (i === 0)
104
- s += coeff > 0 ? `+${coeff}` : coeff;
105
- else if (i === this.degree) {
106
- s += coeff === 1 ? '' : coeff === -1 ? '-' : coeff;
107
- }
108
- else {
109
- s += coeff === 1 ? '+' : coeff === -1 ? '-' : coeff > 0 ? `+${coeff}` : coeff;
110
- }
111
- //x^n
112
- if (i === 0)
113
- continue;
114
- if (i === 1)
115
- s += this.variable;
116
- else
117
- s += `${this.variable}^{${i}}`;
118
- }
119
- return s;
120
- }
121
- toString() {
122
- return this.toTex();
123
- }
124
- }
125
- exports.Polynomial = Polynomial;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Polynomial = void 0;
4
+ const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
5
+ const addNode_1 = require("../../tree/nodes/operators/addNode");
6
+ const multiplyNode_1 = require("../../tree/nodes/operators/multiplyNode");
7
+ const oppositeNode_1 = require("../../tree/nodes/functions/oppositeNode");
8
+ const powerNode_1 = require("../../tree/nodes/operators/powerNode");
9
+ const variableNode_1 = require("../../tree/nodes/variables/variableNode");
10
+ class Polynomial {
11
+ /**
12
+ *
13
+ * @param coefficients coefficients[i] est le coeff de x^i
14
+ * @param variable
15
+ */
16
+ constructor(coefficients, variable = 'x') {
17
+ if (coefficients.length === 0)
18
+ throw Error('coeffs must be not null');
19
+ if (coefficients[coefficients.length - 1] === 0) {
20
+ throw Error('n-th coeff must be not null');
21
+ }
22
+ this.coefficients = coefficients;
23
+ this.variable = variable;
24
+ this.degree = coefficients.length - 1;
25
+ }
26
+ equals(P) {
27
+ return P.degree === this.degree && this.coefficients.every((coeff, i) => coeff === P.coefficients[i]);
28
+ }
29
+ getRoots() { }
30
+ add(P) {
31
+ if (P.variable !== this.variable)
32
+ throw Error("Can't add two polynomials with different variables");
33
+ const newDegree = P.degree === this.degree && P.coefficients[P.degree] === -this.coefficients[this.degree]
34
+ ? P.degree - 1
35
+ : Math.max(P.degree, this.degree);
36
+ const res = [];
37
+ for (let i = 0; i < newDegree + 1; i++) {
38
+ res[i] = P.coefficients[i] + this.coefficients[i];
39
+ }
40
+ return new Polynomial(res, this.variable);
41
+ }
42
+ times(nb) {
43
+ return new Polynomial(this.coefficients.map((coeff) => coeff * nb), this.variable);
44
+ }
45
+ multiply(Q) {
46
+ if (Q.variable !== this.variable)
47
+ throw Error("Can't multiply two polynomials with different variables");
48
+ const p = this.degree;
49
+ const q = Q.degree;
50
+ const res = Array.apply(0, new Array(this.degree)).map((i) => 0);
51
+ for (let k = 0; k <= p + q; k++) {
52
+ let sum = 0;
53
+ for (let m = 0; m <= k; m++) {
54
+ sum += (this.coefficients[m] || 0) * (Q.coefficients[k - m] || 0);
55
+ }
56
+ res[k] = sum;
57
+ }
58
+ return new Polynomial(res, this.variable);
59
+ }
60
+ opposite() {
61
+ return new Polynomial(this.coefficients.map((coeff) => -coeff), this.variable);
62
+ }
63
+ derivate() {
64
+ const res = [];
65
+ return new Polynomial(this.coefficients, this.variable);
66
+ }
67
+ toTree() {
68
+ const recursive = (cursor) => {
69
+ const coeff = this.coefficients[cursor];
70
+ if (coeff === 0)
71
+ return recursive(cursor - 1);
72
+ if (cursor === 0) {
73
+ return new numberNode_1.NumberNode(coeff);
74
+ }
75
+ const monome = cursor > 1
76
+ ? new powerNode_1.PowerNode(new variableNode_1.VariableNode(this.variable), new numberNode_1.NumberNode(cursor))
77
+ : new variableNode_1.VariableNode(this.variable);
78
+ let res;
79
+ if (coeff === 1)
80
+ res = monome;
81
+ else if (coeff === -1)
82
+ res = new oppositeNode_1.OppositeNode(monome);
83
+ else
84
+ res = new multiplyNode_1.MultiplyNode(new numberNode_1.NumberNode(coeff), monome);
85
+ let nextCoeff;
86
+ for (let i = cursor - 1; i > -1; i--) {
87
+ if (this.coefficients[i]) {
88
+ nextCoeff = this.coefficients[i];
89
+ break;
90
+ }
91
+ }
92
+ if (nextCoeff) {
93
+ return new addNode_1.AddNode(res, recursive(cursor - 1));
94
+ }
95
+ else {
96
+ return res;
97
+ }
98
+ };
99
+ return recursive(this.degree);
100
+ }
101
+ toTex() {
102
+ let s = '';
103
+ for (let i = this.degree; i > -1; i--) {
104
+ const coeff = this.coefficients[i];
105
+ if (coeff === 0)
106
+ continue;
107
+ if (i === 0)
108
+ s += coeff > 0 ? `+${coeff}` : coeff;
109
+ else if (i === this.degree) {
110
+ s += coeff === 1 ? '' : coeff === -1 ? '-' : coeff;
111
+ }
112
+ else {
113
+ s += coeff === 1 ? '+' : coeff === -1 ? '-' : coeff > 0 ? `+${coeff}` : coeff;
114
+ }
115
+ //x^n
116
+ if (i === 0)
117
+ continue;
118
+ if (i === 1)
119
+ s += this.variable;
120
+ else
121
+ s += `${this.variable}^{${i}}`;
122
+ }
123
+ return s;
124
+ }
125
+ toString() {
126
+ return this.toTex();
127
+ }
128
+ }
129
+ exports.Polynomial = Polynomial;
@@ -1 +1 @@
1
- "use strict";
1
+ "use strict";
@@ -1,4 +1,4 @@
1
- export declare abstract class GeometricSequenceConstructor {
2
- static random(): void;
3
- }
1
+ export declare abstract class GeometricSequenceConstructor {
2
+ static random(): void;
3
+ }
4
4
  //# sourceMappingURL=geometricSequence.d.ts.map
@@ -1,8 +1,8 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.GeometricSequenceConstructor = void 0;
4
- class GeometricSequenceConstructor {
5
- static random() {
6
- }
7
- }
8
- exports.GeometricSequenceConstructor = GeometricSequenceConstructor;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.GeometricSequenceConstructor = void 0;
4
+ class GeometricSequenceConstructor {
5
+ static random() {
6
+ }
7
+ }
8
+ exports.GeometricSequenceConstructor = GeometricSequenceConstructor;
@@ -1,23 +1,23 @@
1
- import { Node } from '../../tree/nodes/node';
2
- import { Integer } from '../numbers/integer/integer';
3
- declare enum SequenceType {
4
- arithmetic = 0,
5
- geometric = 1,
6
- other = 2
7
- }
8
- export declare class Sequence {
9
- type: SequenceType;
10
- firstRank: Integer;
11
- firstTerm: Node;
12
- recurrenceFormula?: string;
13
- explicitFormula?: string;
14
- constructor({ type, recurrenceFormula, explicitFormula, firstRank, firstTerm, }: {
15
- type: SequenceType;
16
- recurrenceFormula?: string;
17
- explicitFormula?: string;
18
- firstRank: Integer;
19
- firstTerm: Node;
20
- });
21
- }
22
- export {};
1
+ import { Node } from '../../tree/nodes/node';
2
+ import { Integer } from '../numbers/integer/integer';
3
+ declare enum SequenceType {
4
+ arithmetic = 0,
5
+ geometric = 1,
6
+ other = 2
7
+ }
8
+ export declare class Sequence {
9
+ type: SequenceType;
10
+ firstRank: Integer;
11
+ firstTerm: Node;
12
+ recurrenceFormula?: string;
13
+ explicitFormula?: string;
14
+ constructor({ type, recurrenceFormula, explicitFormula, firstRank, firstTerm, }: {
15
+ type: SequenceType;
16
+ recurrenceFormula?: string;
17
+ explicitFormula?: string;
18
+ firstRank: Integer;
19
+ firstTerm: Node;
20
+ });
21
+ }
22
+ export {};
23
23
  //# sourceMappingURL=sequence.d.ts.map
@@ -1,21 +1,21 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Sequence = void 0;
4
- const integer_1 = require("../numbers/integer/integer");
5
- var SequenceType;
6
- (function (SequenceType) {
7
- SequenceType[SequenceType["arithmetic"] = 0] = "arithmetic";
8
- SequenceType[SequenceType["geometric"] = 1] = "geometric";
9
- SequenceType[SequenceType["other"] = 2] = "other";
10
- })(SequenceType || (SequenceType = {}));
11
- class Sequence {
12
- constructor({ type, recurrenceFormula, explicitFormula, firstRank, firstTerm, }) {
13
- this.firstRank = new integer_1.Integer(0);
14
- this.type = type;
15
- this.firstTerm = firstTerm;
16
- this.recurrenceFormula = recurrenceFormula;
17
- this.explicitFormula = explicitFormula;
18
- this.firstRank = firstRank;
19
- }
20
- }
21
- exports.Sequence = Sequence;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Sequence = void 0;
4
+ const integer_1 = require("../numbers/integer/integer");
5
+ var SequenceType;
6
+ (function (SequenceType) {
7
+ SequenceType[SequenceType["arithmetic"] = 0] = "arithmetic";
8
+ SequenceType[SequenceType["geometric"] = 1] = "geometric";
9
+ SequenceType[SequenceType["other"] = 2] = "other";
10
+ })(SequenceType || (SequenceType = {}));
11
+ class Sequence {
12
+ constructor({ type, recurrenceFormula, explicitFormula, firstRank, firstTerm, }) {
13
+ this.firstRank = new integer_1.Integer(0);
14
+ this.type = type;
15
+ this.firstTerm = firstTerm;
16
+ this.recurrenceFormula = recurrenceFormula;
17
+ this.explicitFormula = explicitFormula;
18
+ this.firstRank = firstRank;
19
+ }
20
+ }
21
+ exports.Sequence = Sequence;
@@ -1,11 +1,11 @@
1
- import { Nombre } from '../numbers/nombre';
2
- import { MathSetInterface } from './mathSetInterface';
3
- export declare class DiscreteSet implements MathSetInterface {
4
- elements: Nombre[];
5
- tex: string;
6
- constructor(elements: Nombre[]);
7
- toTex(): string;
8
- includes(el: Nombre): boolean;
9
- getRandomElement(): Nombre;
10
- }
1
+ import { Nombre } from '../numbers/nombre';
2
+ import { MathSetInterface } from './mathSetInterface';
3
+ export declare class DiscreteSet implements MathSetInterface {
4
+ elements: Nombre[];
5
+ tex: string;
6
+ constructor(elements: Nombre[]);
7
+ toTex(): string;
8
+ includes(el: Nombre): boolean;
9
+ getRandomElement(): Nombre;
10
+ }
11
11
  //# sourceMappingURL=discreteSet.d.ts.map
@@ -1,28 +1,28 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DiscreteSet = void 0;
4
- const random_1 = require("../../utils/random");
5
- class DiscreteSet {
6
- constructor(elements) {
7
- this.elements = Array.from(new Set(elements));
8
- let tex = '\\{';
9
- this.elements.forEach((el, index) => {
10
- tex += el.tex;
11
- if (index < this.elements.length - 1)
12
- tex += ';';
13
- else
14
- tex += '\\}';
15
- });
16
- this.tex = tex;
17
- }
18
- toTex() {
19
- return this.tex;
20
- }
21
- includes(el) {
22
- return this.elements.some((nb) => nb.value === el.value && nb.tex === el.tex);
23
- }
24
- getRandomElement() {
25
- return (0, random_1.random)(this.elements);
26
- }
27
- }
28
- exports.DiscreteSet = DiscreteSet;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DiscreteSet = void 0;
4
+ const random_1 = require("../../utils/random");
5
+ class DiscreteSet {
6
+ constructor(elements) {
7
+ this.elements = Array.from(new Set(elements));
8
+ let tex = '\\{';
9
+ this.elements.forEach((el, index) => {
10
+ tex += el.tex;
11
+ if (index < this.elements.length - 1)
12
+ tex += ';';
13
+ else
14
+ tex += '\\}';
15
+ });
16
+ this.tex = tex;
17
+ }
18
+ toTex() {
19
+ return this.tex;
20
+ }
21
+ includes(el) {
22
+ return this.elements.some((nb) => nb.value === el.value && nb.tex === el.tex);
23
+ }
24
+ getRandomElement() {
25
+ return (0, random_1.random)(this.elements);
26
+ }
27
+ }
28
+ exports.DiscreteSet = DiscreteSet;
@@ -1,6 +1,6 @@
1
- "use strict";
2
- // import { MathSetInterface } from "./mathSetInterface";
3
- // export abstract class EmptySet implements MathSetInterface {
4
- // tex: string = "\\emptyset";
5
- // getRandomElement = () => null;
6
- // }
1
+ "use strict";
2
+ // import { MathSetInterface } from "./mathSetInterface";
3
+ // export abstract class EmptySet implements MathSetInterface {
4
+ // tex: string = "\\emptyset";
5
+ // getRandomElement = () => null;
6
+ // }