math-exercises 2.2.55 → 2.2.57

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 (179) hide show
  1. package/lib/exercises/math/calcul/proportionality/index.d.ts +1 -0
  2. package/lib/exercises/math/calcul/proportionality/index.d.ts.map +1 -1
  3. package/lib/exercises/math/calcul/proportionality/index.js +1 -0
  4. package/lib/exercises/math/calcul/proportionality/isTableProportional.d.ts +8 -0
  5. package/lib/exercises/math/calcul/proportionality/isTableProportional.d.ts.map +1 -0
  6. package/lib/exercises/math/calcul/proportionality/isTableProportional.js +91 -0
  7. package/lib/exercises/math/calculLitteral/equation/equationType4Exercise.d.ts.map +1 -1
  8. package/lib/exercises/math/calculLitteral/equation/equationType4Exercise.js +0 -1
  9. package/lib/exercises/math/functions/trinoms/coefficientsIdentification.d.ts +11 -0
  10. package/lib/exercises/math/functions/trinoms/coefficientsIdentification.d.ts.map +1 -0
  11. package/lib/exercises/math/functions/trinoms/coefficientsIdentification.js +131 -0
  12. package/lib/exercises/math/functions/trinoms/index.d.ts +1 -0
  13. package/lib/exercises/math/functions/trinoms/index.d.ts.map +1 -1
  14. package/lib/exercises/math/functions/trinoms/index.js +1 -0
  15. package/lib/exercises/math/functions/trinoms/summitAbscissFromDevForm.d.ts.map +1 -1
  16. package/lib/exercises/math/functions/trinoms/summitAbscissFromDevForm.js +39 -1
  17. package/lib/exercises/math/geometry/areas/rightTriangleArea.js +2 -2
  18. package/lib/exercises/math/geometry/areas/triangleArea.js +2 -2
  19. package/lib/exercises/math/geometry/euclidianConstructions/buildTriangleWithSizes.d.ts +7 -0
  20. package/lib/exercises/math/geometry/euclidianConstructions/buildTriangleWithSizes.d.ts.map +1 -0
  21. package/lib/exercises/math/geometry/euclidianConstructions/buildTriangleWithSizes.js +117 -0
  22. package/lib/exercises/math/geometry/euclidianConstructions/index.d.ts +2 -0
  23. package/lib/exercises/math/geometry/euclidianConstructions/index.d.ts.map +1 -1
  24. package/lib/exercises/math/geometry/euclidianConstructions/index.js +2 -0
  25. package/lib/exercises/math/geometry/euclidianConstructions/pointImageFromTranslation.d.ts +10 -0
  26. package/lib/exercises/math/geometry/euclidianConstructions/pointImageFromTranslation.d.ts.map +1 -0
  27. package/lib/exercises/math/geometry/euclidianConstructions/pointImageFromTranslation.js +102 -0
  28. package/lib/exercises/math/geometry/pythagore/pythagore.d.ts +2 -0
  29. package/lib/exercises/math/geometry/pythagore/pythagore.d.ts.map +1 -1
  30. package/lib/exercises/math/geometry/pythagore/pythagore.js +4 -3
  31. package/lib/exercises/math/geometry/pythagore/pythagoreCalcul.d.ts +2 -0
  32. package/lib/exercises/math/geometry/pythagore/pythagoreCalcul.d.ts.map +1 -1
  33. package/lib/exercises/math/geometry/pythagore/pythagoreCalcul.js +4 -3
  34. package/lib/exercises/math/geometry/shapes/basicShapesNaming.d.ts.map +1 -1
  35. package/lib/exercises/math/geometry/shapes/basicShapesNaming.js +0 -1
  36. package/lib/exercises/math/geometry/thales/index.d.ts.map +1 -1
  37. package/lib/exercises/math/geometry/thales/index.js +1 -0
  38. package/lib/exercises/math/geometry/thales/thales.d.ts +7 -0
  39. package/lib/exercises/math/geometry/thales/thales.d.ts.map +1 -1
  40. package/lib/exercises/math/geometry/thales/thales.js +1 -1
  41. package/lib/exercises/math/geometry/thales/thalesCalcul.d.ts +11 -5
  42. package/lib/exercises/math/geometry/thales/thalesCalcul.d.ts.map +1 -1
  43. package/lib/exercises/math/geometry/thales/thalesCalcul.js +166 -118
  44. package/lib/exercises/math/geometry/thales/thalesCalculOld.d.ts +1 -0
  45. package/lib/exercises/math/geometry/thales/thalesCalculOld.d.ts.map +1 -0
  46. package/lib/exercises/math/geometry/thales/thalesCalculOld.js +214 -0
  47. package/lib/exercises/math/percent/index.d.ts +0 -1
  48. package/lib/exercises/math/percent/index.d.ts.map +1 -1
  49. package/lib/exercises/math/percent/index.js +0 -1
  50. package/lib/exercises/math/probaStat/binomial/binomialInequation.d.ts +16 -0
  51. package/lib/exercises/math/probaStat/binomial/binomialInequation.d.ts.map +1 -0
  52. package/lib/exercises/math/probaStat/binomial/binomialInequation.js +159 -0
  53. package/lib/exercises/math/probaStat/binomial/calculateProbaOfBinomialDistribution.d.ts +13 -0
  54. package/lib/exercises/math/probaStat/binomial/calculateProbaOfBinomialDistribution.d.ts.map +1 -0
  55. package/lib/exercises/math/probaStat/binomial/calculateProbaOfBinomialDistribution.js +106 -0
  56. package/lib/exercises/math/probaStat/binomial/expectedValueOfBinomialProba.d.ts +9 -0
  57. package/lib/exercises/math/probaStat/binomial/expectedValueOfBinomialProba.d.ts.map +1 -0
  58. package/lib/exercises/math/probaStat/binomial/expectedValueOfBinomialProba.js +89 -0
  59. package/lib/exercises/math/probaStat/binomial/index.d.ts +5 -0
  60. package/lib/exercises/math/probaStat/binomial/index.d.ts.map +1 -0
  61. package/lib/exercises/math/probaStat/binomial/index.js +20 -0
  62. package/lib/exercises/math/probaStat/binomial/varianceOfBinomialProba.d.ts +9 -0
  63. package/lib/exercises/math/probaStat/binomial/varianceOfBinomialProba.d.ts.map +1 -0
  64. package/lib/exercises/math/probaStat/binomial/varianceOfBinomialProba.js +94 -0
  65. package/lib/exercises/math/probaStat/cardBasicProbas.d.ts +3 -0
  66. package/lib/exercises/math/probaStat/cardBasicProbas.d.ts.map +1 -1
  67. package/lib/exercises/math/probaStat/cardBasicProbas.js +3 -2
  68. package/lib/exercises/math/probaStat/diceBasicProbas.d.ts +1 -0
  69. package/lib/exercises/math/probaStat/diceBasicProbas.d.ts.map +1 -1
  70. package/lib/exercises/math/probaStat/diceBasicProbas.js +8 -4
  71. package/lib/exercises/math/probaStat/index.d.ts +1 -3
  72. package/lib/exercises/math/probaStat/index.d.ts.map +1 -1
  73. package/lib/exercises/math/probaStat/index.js +1 -3
  74. package/lib/exercises/math/probaStat/issuesCountingForCards.d.ts +2 -0
  75. package/lib/exercises/math/probaStat/issuesCountingForCards.d.ts.map +1 -1
  76. package/lib/exercises/math/probaStat/issuesCountingForCards.js +1 -1
  77. package/lib/exercises/math/probaStat/probaFromTableNoContext.d.ts +4 -1
  78. package/lib/exercises/math/probaStat/probaFromTableNoContext.d.ts.map +1 -1
  79. package/lib/exercises/math/probaStat/probaFromTableNoContext.js +17 -5
  80. package/lib/exercises/math/probaStat/stats1var/marginalAndConditionalFrequency.js +0 -1
  81. package/lib/exercises/math/probaStat/stats2var/fineAdjustementExercise.d.ts +2 -0
  82. package/lib/exercises/math/probaStat/stats2var/fineAdjustementExercise.d.ts.map +1 -1
  83. package/lib/exercises/math/probaStat/stats2var/fineAdjustementExercise.js +4 -1
  84. package/lib/exercises/math/trigonometry/associatePoint.d.ts +3 -0
  85. package/lib/exercises/math/trigonometry/associatePoint.d.ts.map +1 -1
  86. package/lib/exercises/math/trigonometry/associatePoint.js +5 -1
  87. package/lib/exercises/math/trigonometry/trigonometry.js +2 -2
  88. package/lib/exercises/math/trigonometry/trigonometryAngleCalcul.js +2 -2
  89. package/lib/exercises/math/trigonometry/trigonometrySideCalcul.js +2 -2
  90. package/lib/exercises/pc/calibrationCurveOfSolution.d.ts +1 -0
  91. package/lib/exercises/pc/calibrationCurveOfSolution.d.ts.map +1 -1
  92. package/lib/exercises/pc/calibrationCurveOfSolution.js +2 -0
  93. package/lib/exercises/pc/chemicalReactions/stoichiometricReaction.d.ts +6 -1
  94. package/lib/exercises/pc/chemicalReactions/stoichiometricReaction.d.ts.map +1 -1
  95. package/lib/exercises/pc/chemicalReactions/stoichiometricReaction.js +1 -1
  96. package/lib/exercises/pc/electricity/ohmicConductorOrGenerator.d.ts +4 -1
  97. package/lib/exercises/pc/electricity/ohmicConductorOrGenerator.d.ts.map +1 -1
  98. package/lib/exercises/pc/electricity/ohmicConductorOrGenerator.js +2 -1
  99. package/lib/exercises/pc/identifyAtomicMassOrAtomicNb.d.ts +2 -0
  100. package/lib/exercises/pc/identifyAtomicMassOrAtomicNb.d.ts.map +1 -1
  101. package/lib/exercises/pc/identifyAtomicMassOrAtomicNb.js +2 -0
  102. package/lib/exercises/pc/mole/molarMass.js +1 -1
  103. package/lib/exercises/pc/motion/typeOfAcceleration.d.ts +4 -1
  104. package/lib/exercises/pc/motion/typeOfAcceleration.d.ts.map +1 -1
  105. package/lib/exercises/pc/motion/typeOfAcceleration.js +5 -1
  106. package/lib/exercises/pc/motion/typeOfMovement.d.ts +4 -1
  107. package/lib/exercises/pc/motion/typeOfMovement.d.ts.map +1 -1
  108. package/lib/exercises/pc/motion/typeOfMovement.js +1 -1
  109. package/lib/exercises/pc/recognizeRefractionOrReflectionAngles.d.ts +3 -1
  110. package/lib/exercises/pc/recognizeRefractionOrReflectionAngles.d.ts.map +1 -1
  111. package/lib/exercises/pc/recognizeRefractionOrReflectionAngles.js +1 -1
  112. package/lib/exercises/utils/geogebra/toGGBCommandsProps.d.ts +3 -0
  113. package/lib/exercises/utils/geogebra/toGGBCommandsProps.d.ts.map +1 -1
  114. package/lib/exercises/utils/geogebra/toolBarConstructor.d.ts +4 -0
  115. package/lib/exercises/utils/geogebra/toolBarConstructor.d.ts.map +1 -1
  116. package/lib/exercises/utils/geogebra/toolBarConstructor.js +8 -0
  117. package/lib/exercises/utils/getDistinctQuestions.d.ts.map +1 -1
  118. package/lib/exercises/utils/getDistinctQuestions.js +11 -4
  119. package/lib/index.d.ts +94 -26
  120. package/lib/index.d.ts.map +1 -1
  121. package/lib/math/geometry/CloudPoints.d.ts +5 -1
  122. package/lib/math/geometry/CloudPoints.d.ts.map +1 -1
  123. package/lib/math/geometry/CloudPoints.js +5 -0
  124. package/lib/math/geometry/line.d.ts +23 -1
  125. package/lib/math/geometry/line.d.ts.map +1 -1
  126. package/lib/math/geometry/line.js +53 -2
  127. package/lib/math/geometry/point.d.ts +15 -13
  128. package/lib/math/geometry/point.d.ts.map +1 -1
  129. package/lib/math/geometry/point.js +28 -12
  130. package/lib/math/geometry/segment.d.ts +11 -1
  131. package/lib/math/geometry/segment.d.ts.map +1 -1
  132. package/lib/math/geometry/segment.js +12 -0
  133. package/lib/math/geometry/triangle.d.ts +67 -0
  134. package/lib/math/geometry/triangle.d.ts.map +1 -0
  135. package/lib/math/geometry/triangle.js +227 -0
  136. package/lib/math/numbers/decimals/decimal.d.ts.map +1 -1
  137. package/lib/math/numbers/decimals/decimal.js +0 -2
  138. package/lib/math/numbers/rationals/rational.d.ts +1 -0
  139. package/lib/math/numbers/rationals/rational.d.ts.map +1 -1
  140. package/lib/math/numbers/rationals/rational.js +5 -0
  141. package/lib/math/polynomials/generalTrinom.d.ts +2 -2
  142. package/lib/math/polynomials/generalTrinom.d.ts.map +1 -1
  143. package/lib/math/probability/binomial.d.ts +10 -0
  144. package/lib/math/probability/binomial.d.ts.map +1 -0
  145. package/lib/math/probability/binomial.js +30 -0
  146. package/lib/math/sets/intervals/intervals.d.ts +1 -1
  147. package/lib/math/systems/generalSystem.d.ts +11 -0
  148. package/lib/math/systems/generalSystem.d.ts.map +1 -0
  149. package/lib/math/systems/generalSystem.js +79 -0
  150. package/lib/playground.d.ts.map +1 -1
  151. package/lib/playground.js +1 -4
  152. package/lib/server.js +0 -2
  153. package/lib/tree/nodes/geometry/pointNode.d.ts +1 -10
  154. package/lib/tree/nodes/geometry/pointNode.d.ts.map +1 -1
  155. package/lib/tree/nodes/inequations/inequationNode.js +1 -1
  156. package/lib/tree/nodes/inequations/inequationSolutionNode.d.ts +2 -11
  157. package/lib/tree/nodes/inequations/inequationSolutionNode.d.ts.map +1 -1
  158. package/lib/tree/nodes/node.d.ts +2 -1
  159. package/lib/tree/nodes/node.d.ts.map +1 -1
  160. package/lib/tree/nodes/node.js +1 -0
  161. package/lib/tree/nodes/nodeConstructor.d.ts +4 -3
  162. package/lib/tree/nodes/nodeConstructor.d.ts.map +1 -1
  163. package/lib/tree/nodes/nodeConstructor.js +4 -0
  164. package/lib/tree/nodes/operators/addNode.d.ts.map +1 -1
  165. package/lib/tree/nodes/operators/addNode.js +20 -8
  166. package/lib/tree/nodes/operators/binomialCoefficientNode.d.ts +35 -0
  167. package/lib/tree/nodes/operators/binomialCoefficientNode.d.ts.map +1 -0
  168. package/lib/tree/nodes/operators/binomialCoefficientNode.js +52 -0
  169. package/lib/tree/nodes/operators/fractionNode.d.ts +1 -1
  170. package/lib/tree/nodes/operators/fractionNode.d.ts.map +1 -1
  171. package/lib/tree/nodes/operators/fractionNode.js +2 -4
  172. package/lib/tree/nodes/operators/operatorNode.d.ts +2 -1
  173. package/lib/tree/nodes/operators/operatorNode.d.ts.map +1 -1
  174. package/lib/tree/nodes/operators/operatorNode.js +1 -0
  175. package/lib/tree/nodes/sets/intervalNode.d.ts +9 -10
  176. package/lib/tree/nodes/sets/intervalNode.d.ts.map +1 -1
  177. package/lib/tree/nodes/sets/intervalNode.js +1 -0
  178. package/lib/utils/alea/random.d.ts.map +1 -1
  179. package/package.json +1 -1
@@ -1,8 +1,19 @@
1
- import { NodeIds } from "../../tree/nodes/node";
2
1
  import { AlgebraicNode } from "../../tree/nodes/algebraicNode";
3
2
  import { ToGGBCommandsProps } from "../../exercises/utils/geogebra/toGGBCommandsProps";
3
+ import { NodeIdentifiers } from "../../tree/nodes/nodeConstructor";
4
+ export type PointIdentifiers = {
5
+ id: "point";
6
+ name: string;
7
+ x: NodeIdentifiers;
8
+ y: NodeIdentifiers;
9
+ };
4
10
  export declare abstract class PointConstructor {
5
- static random(name: string): Point;
11
+ static random(name: string, min?: number, max?: number): Point;
12
+ static fromIdentifiers(identifiers: PointIdentifiers): Point;
13
+ static onSegment(A: Point, B: Point, name: string, { spacing, coefficient, }?: {
14
+ spacing?: number;
15
+ coefficient?: number;
16
+ }): Point;
6
17
  static randomDifferent(names: string[]): Point[];
7
18
  static fromGGBCommand(str: string): Point;
8
19
  }
@@ -12,16 +23,7 @@ export declare class Point {
12
23
  y: AlgebraicNode;
13
24
  constructor(name: string, x: AlgebraicNode, y: AlgebraicNode);
14
25
  toTex(): string;
15
- toIdentifiers(): {
16
- id: string;
17
- name: string;
18
- x: {
19
- id: NodeIds;
20
- } & Record<string, any>;
21
- y: {
22
- id: NodeIds;
23
- } & Record<string, any>;
24
- };
26
+ toIdentifiers(): PointIdentifiers;
25
27
  toTexWithCoords(): string;
26
28
  toCoords(): string;
27
29
  getXnumber(): number;
@@ -30,6 +32,6 @@ export declare class Point {
30
32
  distanceTo(B: Point): number;
31
33
  equals(B: Point): boolean;
32
34
  isAligned(B: Point, C: Point): boolean;
33
- toGGBCommand({ isFixed, showLabel }?: ToGGBCommandsProps): string[];
35
+ toGGBCommand({ isFixed, showLabel, style, size, color, }?: ToGGBCommandsProps): string[];
34
36
  }
35
37
  //# sourceMappingURL=point.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"point.d.ts","sourceRoot":"","sources":["../../../src/math/geometry/point.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAY,MAAM,uBAAuB,CAAC;AAI1D,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAG/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,mDAAmD,CAAC;AAEvF,8BAAsB,gBAAgB;IACpC,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,KAAK;IAMlC,MAAM,CAAC,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE;IAetC,MAAM,CAAC,cAAc,CAAC,GAAG,EAAE,MAAM;CAclC;AAED,qBAAa,KAAK;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,CAAC,EAAE,aAAa,CAAC;IACjB,CAAC,EAAE,aAAa,CAAC;gBACL,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,aAAa,EAAE,CAAC,EAAE,aAAa;IAM5D,KAAK,IAAI,MAAM;IAGf,aAAa;;;;;;;;;;IAQb,eAAe,IAAI,MAAM;IAGzB,QAAQ,IAAI,MAAM;IAIlB,UAAU,IAAI,MAAM;IAMpB,UAAU,IAAI,MAAM;IAMpB,QAAQ,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,SAAM,GAAG,KAAK;IAiBrC,UAAU,CAAC,CAAC,EAAE,KAAK,GAAG,MAAM;IAM5B,MAAM,CAAC,CAAC,EAAE,KAAK,GAAG,OAAO;IAGzB,SAAS,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK;IAM5B,YAAY,CAAC,EAAE,OAAc,EAAE,SAAgB,EAAE,GAAE,kBAAuB;CAQ3E"}
1
+ {"version":3,"file":"point.d.ts","sourceRoot":"","sources":["../../../src/math/geometry/point.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAG/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,mDAAmD,CAAC;AACvF,OAAO,EAEL,eAAe,EAChB,MAAM,kCAAkC,CAAC;AAG1C,MAAM,MAAM,gBAAgB,GAAG;IAC7B,EAAE,EAAE,OAAO,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,CAAC,EAAE,eAAe,CAAC;IACnB,CAAC,EAAE,eAAe,CAAC;CACpB,CAAC;AACF,8BAAsB,gBAAgB;IACpC,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,SAAM,EAAE,GAAG,SAAK,GAAG,KAAK;IAMvD,MAAM,CAAC,eAAe,CAAC,WAAW,EAAE,gBAAgB;IAQpD,MAAM,CAAC,SAAS,CACd,CAAC,EAAE,KAAK,EACR,CAAC,EAAE,KAAK,EACR,IAAI,EAAE,MAAM,EACZ,EACE,OAAa,EACb,WAAW,GACZ,GAAE;QAAE,OAAO,CAAC,EAAE,MAAM,CAAC;QAAC,WAAW,CAAC,EAAE,MAAM,CAAA;KAAO;IAQpD,MAAM,CAAC,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE;IAetC,MAAM,CAAC,cAAc,CAAC,GAAG,EAAE,MAAM;CAclC;AAED,qBAAa,KAAK;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,CAAC,EAAE,aAAa,CAAC;IACjB,CAAC,EAAE,aAAa,CAAC;gBACL,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,aAAa,EAAE,CAAC,EAAE,aAAa;IAM5D,KAAK,IAAI,MAAM;IAGf,aAAa,IAAI,gBAAgB;IAQjC,eAAe,IAAI,MAAM;IAGzB,QAAQ,IAAI,MAAM;IAIlB,UAAU,IAAI,MAAM;IAIpB,UAAU,IAAI,MAAM;IAIpB,QAAQ,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,SAAM,GAAG,KAAK;IAiBrC,UAAU,CAAC,CAAC,EAAE,KAAK,GAAG,MAAM;IAM5B,MAAM,CAAC,CAAC,EAAE,KAAK,GAAG,OAAO;IAGzB,SAAS,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK;IAM5B,YAAY,CAAC,EACX,OAAc,EACd,SAAgB,EAChB,KAAK,EACL,IAAI,EACJ,KAAK,GACN,GAAE,kBAAuB;CAiB3B"}
@@ -6,12 +6,23 @@ const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
6
6
  const rational_1 = require("../numbers/rationals/rational");
7
7
  const vector_1 = require("./vector");
8
8
  const randint_1 = require("../utils/random/randint");
9
+ const nodeConstructor_1 = require("../../tree/nodes/nodeConstructor");
10
+ const randfloat_1 = require("../utils/random/randfloat");
9
11
  class PointConstructor {
10
- static random(name) {
11
- const x = (0, randint_1.randint)(-10, 11);
12
- const y = (0, randint_1.randint)(-10, 11);
12
+ static random(name, min = -10, max = 11) {
13
+ const x = (0, randint_1.randint)(min, max);
14
+ const y = (0, randint_1.randint)(min, max);
13
15
  return new Point(name, new numberNode_1.NumberNode(x), new numberNode_1.NumberNode(y));
14
16
  }
17
+ static fromIdentifiers(identifiers) {
18
+ return new Point(identifiers.name, nodeConstructor_1.NodeConstructor.fromIdentifiers(identifiers.x), nodeConstructor_1.NodeConstructor.fromIdentifiers(identifiers.y));
19
+ }
20
+ static onSegment(A, B, name, { spacing = 0.1, coefficient, } = {}) {
21
+ const coeff = coefficient ?? (0, randfloat_1.randfloat)(spacing, 1 - spacing);
22
+ const vector = vector_1.VectorConstructor.fromPoints(A, B).times(coeff.toTree());
23
+ const point = vector.getEndPoint(A, name);
24
+ return point;
25
+ }
15
26
  static randomDifferent(names) {
16
27
  const res = [];
17
28
  const points = [];
@@ -63,14 +74,10 @@ class Point {
63
74
  return `\\left(${this.x.toTex()};${this.y.toTex()}\\right)`;
64
75
  }
65
76
  getXnumber() {
66
- if (this.x.type !== node_1.NodeType.number)
67
- throw Error("general point not implemented yet");
68
- return this.x.value;
77
+ return this.x.evaluate();
69
78
  }
70
79
  getYnumber() {
71
- if (this.y.type !== node_1.NodeType.number)
72
- throw Error("general point not implemented yet");
73
- return this.y.value;
80
+ return this.y.evaluate();
74
81
  }
75
82
  midpoint(B, name = "I") {
76
83
  const types = [this.x.type, this.y.type, B.x.type, B.y.type];
@@ -96,13 +103,22 @@ class Point {
96
103
  const AC = vector_1.VectorConstructor.fromPoints(this, C);
97
104
  return AB.isColinear(AC);
98
105
  }
99
- toGGBCommand({ isFixed = true, showLabel = true } = {}) {
100
- return [
106
+ toGGBCommand({ isFixed = true, showLabel = true, style, size, color, } = {}) {
107
+ const commands = [
101
108
  `${this.name} = (${this.x.toMathString()}, ${this.y.toMathString()})`,
102
109
  `SetFixed(${this.name},${isFixed ? "true" : "false"})`,
103
110
  `ShowLabel(${this.name},${showLabel ? "true" : "false"})`,
104
- `SetPointStyle(${this.name}, 1)`,
105
111
  ];
112
+ if (style !== undefined) {
113
+ commands.push(`SetPointStyle(${this.name}, ${style})`);
114
+ }
115
+ if (size) {
116
+ commands.push(`SetPointSize(${this.name}, ${size})`);
117
+ }
118
+ if (color) {
119
+ commands.push(`SetColor(${this.name}, "${color}")`);
120
+ }
121
+ return commands;
106
122
  }
107
123
  }
108
124
  exports.Point = Point;
@@ -1,7 +1,12 @@
1
1
  import { ToGGBCommandsProps } from "../../exercises/utils/geogebra/toGGBCommandsProps";
2
- import { Point } from "./point";
2
+ import { Point, PointIdentifiers } from "./point";
3
+ export type SegmentIdentifiers = {
4
+ pointA: PointIdentifiers;
5
+ pointB: PointIdentifiers;
6
+ };
3
7
  export declare abstract class SegmentConstructor {
4
8
  static random(): Segment;
9
+ static fromIdentifiers(identifiers: SegmentIdentifiers): Segment;
5
10
  }
6
11
  export declare class Segment {
7
12
  pointA: Point;
@@ -9,8 +14,13 @@ export declare class Segment {
9
14
  name: string;
10
15
  ggbName: string;
11
16
  constructor(pointA: Point, pointB: Point);
17
+ toIdentifiers(): {
18
+ pointA: PointIdentifiers;
19
+ pointB: PointIdentifiers;
20
+ };
12
21
  getLength(): number;
13
22
  toTex(): string;
23
+ toInsideName(): string;
14
24
  toGGBCommands(shouldBuildPoints: boolean, { isFixed, showLabel, showUnderlyingPointsLabel, }?: ToGGBCommandsProps): string[];
15
25
  }
16
26
  //# sourceMappingURL=segment.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"segment.d.ts","sourceRoot":"","sources":["../../../src/math/geometry/segment.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mDAAmD,CAAC;AAEvF,OAAO,EAAE,KAAK,EAAoB,MAAM,SAAS,CAAC;AAElD,8BAAsB,kBAAkB;IACtC,MAAM,CAAC,MAAM;CAKd;AACD,qBAAa,OAAO;IAClB,MAAM,EAAE,KAAK,CAAC;IACd,MAAM,EAAE,KAAK,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;gBACJ,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK;IAMxC,SAAS;IAGT,KAAK;IAGL,aAAa,CACX,iBAAiB,EAAE,OAAO,EAC1B,EACE,OAAc,EACd,SAAiB,EACjB,yBAAgC,GACjC,GAAE,kBAAuB;CAoB7B"}
1
+ {"version":3,"file":"segment.d.ts","sourceRoot":"","sources":["../../../src/math/geometry/segment.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mDAAmD,CAAC;AAEvF,OAAO,EAAE,KAAK,EAAoB,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAEpE,MAAM,MAAM,kBAAkB,GAAG;IAC/B,MAAM,EAAE,gBAAgB,CAAC;IACzB,MAAM,EAAE,gBAAgB,CAAC;CAC1B,CAAC;AACF,8BAAsB,kBAAkB;IACtC,MAAM,CAAC,MAAM;IAKb,MAAM,CAAC,eAAe,CAAC,WAAW,EAAE,kBAAkB;CAMvD;AACD,qBAAa,OAAO;IAClB,MAAM,EAAE,KAAK,CAAC;IACd,MAAM,EAAE,KAAK,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;gBACJ,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK;IAOxC,aAAa;;;;IAMb,SAAS;IAGT,KAAK;IAGL,YAAY;IAGZ,aAAa,CACX,iBAAiB,EAAE,OAAO,EAC1B,EACE,OAAc,EACd,SAAiB,EACjB,yBAAgC,GACjC,GAAE,kBAAuB;CAoB7B"}
@@ -9,6 +9,9 @@ class SegmentConstructor {
9
9
  const points = point_1.PointConstructor.randomDifferent(name.split(""));
10
10
  return new Segment(points[0], points[1]);
11
11
  }
12
+ static fromIdentifiers(identifiers) {
13
+ return new Segment(point_1.PointConstructor.fromIdentifiers(identifiers.pointA), point_1.PointConstructor.fromIdentifiers(identifiers.pointB));
14
+ }
12
15
  }
13
16
  exports.SegmentConstructor = SegmentConstructor;
14
17
  class Segment {
@@ -18,12 +21,21 @@ class Segment {
18
21
  this.name = `[${pointA.name}${pointB.name}]`;
19
22
  this.ggbName = `segment_{${pointA.name}${pointB.name}}`;
20
23
  }
24
+ toIdentifiers() {
25
+ return {
26
+ pointA: this.pointA.toIdentifiers(),
27
+ pointB: this.pointB.toIdentifiers(),
28
+ };
29
+ }
21
30
  getLength() {
22
31
  return this.pointA.distanceTo(this.pointB);
23
32
  }
24
33
  toTex() {
25
34
  return this.name;
26
35
  }
36
+ toInsideName() {
37
+ return `${this.pointA.name}${this.pointB.name}`;
38
+ }
27
39
  toGGBCommands(shouldBuildPoints, { isFixed = true, showLabel = false, showUnderlyingPointsLabel = true, } = {}) {
28
40
  const commands = [
29
41
  `${this.ggbName}=Segment(${this.pointA.name},${this.pointB.name})`,
@@ -0,0 +1,67 @@
1
+ import { Point, PointIdentifiers } from "./point";
2
+ import { SqrtNode } from "../../tree/nodes/functions/sqrtNode";
3
+ import { Segment } from "./segment";
4
+ export type TriangleIdentifiers = {
5
+ vertexA: PointIdentifiers;
6
+ vertexB: PointIdentifiers;
7
+ vertexC: PointIdentifiers;
8
+ };
9
+ export declare abstract class TriangleConstructor {
10
+ static fromIdentifiers(identifiers: TriangleIdentifiers): Triangle;
11
+ static createRandomRightTriangle({ minRapport, maxRapport, names, }: {
12
+ minRapport?: number | undefined;
13
+ maxRapport?: number | undefined;
14
+ names?: string[] | undefined;
15
+ }): Triangle;
16
+ static createRandomTriangle({ minAngle, maxAngle, names, }: {
17
+ minAngle?: number | undefined;
18
+ maxAngle?: number | undefined;
19
+ names?: string[] | undefined;
20
+ }): Triangle;
21
+ static randomName(): string[];
22
+ }
23
+ type GenerateCommandsProps = {
24
+ highlightedAngle?: string;
25
+ colorHighlightedAngle?: string;
26
+ highlightedSide?: string;
27
+ colorHighlightedSide?: string;
28
+ showLabels?: string[];
29
+ setCaptions?: string[];
30
+ showAxes?: boolean;
31
+ showGrid?: boolean;
32
+ };
33
+ export declare class Triangle {
34
+ vertexA: Point;
35
+ vertexB: Point;
36
+ vertexC: Point;
37
+ constructor(vertexA: Point, vertexB: Point, vertexC: Point);
38
+ getSegments(): Segment[];
39
+ getSideASegment(): Segment;
40
+ getSideBSegment(): Segment;
41
+ getSideCSegment(): Segment;
42
+ toIdentifiers(): TriangleIdentifiers;
43
+ getSideAnumber(): number;
44
+ getSideBnumber(): number;
45
+ getSideCnumber(): number;
46
+ getTriangleName(): string;
47
+ getSideAnode(): SqrtNode;
48
+ getSideBnode(): SqrtNode;
49
+ getSideCnode(): SqrtNode;
50
+ getAngleA(): number;
51
+ getAngleB(): number;
52
+ getAngleC(): number;
53
+ getPerimeter(): number;
54
+ getArea(): number;
55
+ isRight(): Boolean;
56
+ isEquilateral(): Boolean;
57
+ isIsosceles(): Boolean;
58
+ isScalene(): boolean;
59
+ getRightAngle(): string;
60
+ generateCommands({ highlightedAngle: highlightedAngle, colorHighlightedAngle: colorHighlightedAngle, showLabels: showLabels, setCaptions: setCaptions, highlightedSide: highlightedSide, colorHighlightedSide: colorHighlightedSide, }: GenerateCommandsProps): string[];
61
+ generateCoords(): number[];
62
+ getSideAName(): string;
63
+ getSideBName(): string;
64
+ getSideCName(): string;
65
+ }
66
+ export {};
67
+ //# sourceMappingURL=triangle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triangle.d.ts","sourceRoot":"","sources":["../../../src/math/geometry/triangle.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAoB,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAKpE,OAAO,EAAE,QAAQ,EAAE,MAAM,qCAAqC,CAAC;AAI/D,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,MAAM,MAAM,mBAAmB,GAAG;IAChC,OAAO,EAAE,gBAAgB,CAAC;IAC1B,OAAO,EAAE,gBAAgB,CAAC;IAC1B,OAAO,EAAE,gBAAgB,CAAC;CAC3B,CAAC;AACF,8BAAsB,mBAAmB;IACvC,MAAM,CAAC,eAAe,CAAC,WAAW,EAAE,mBAAmB,GAAG,QAAQ;IAOlE,MAAM,CAAC,yBAAyB,CAAC,EAC/B,UAAc,EACd,UAAc,EACd,KAAuB,GACxB;;;;KAAA,GAAG,QAAQ;IAkBZ,MAAM,CAAC,oBAAoB,CAAC,EAC1B,QAAe,EACf,QAAc,EACd,KAAuB,GACxB;;;;KAAA,GAAG,QAAQ;IA+BZ,MAAM,CAAC,UAAU;CAQlB;AAED,KAAK,qBAAqB,GAAG;IAC3B,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,qBAAqB,CAAC,EAAE,MAAM,CAAC;IAC/B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF,qBAAa,QAAQ;IACnB,OAAO,EAAE,KAAK,CAAC;IACf,OAAO,EAAE,KAAK,CAAC;IACf,OAAO,EAAE,KAAK,CAAC;gBAEH,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK;IAK1D,WAAW;IAOX,eAAe;IAGf,eAAe;IAGf,eAAe;IAGf,aAAa,IAAI,mBAAmB;IAQpC,cAAc,IAAI,MAAM;IAOxB,cAAc,IAAI,MAAM;IAOxB,cAAc,IAAI,MAAM;IAIxB,eAAe,IAAI,MAAM;IAIzB,YAAY;IAeZ,YAAY;IAeZ,YAAY;IAeZ,SAAS,IAAI,MAAM;IASnB,SAAS,IAAI,MAAM;IASnB,SAAS,IAAI,MAAM;IASnB,YAAY,IAAI,MAAM;IAMtB,OAAO,IAAI,MAAM;IAUjB,OAAO,IAAI,OAAO;IAOlB,aAAa,IAAI,OAAO;IAOxB,WAAW,IAAI,OAAO;IAQtB,SAAS,IAAI,OAAO;IAQpB,aAAa,IAAI,MAAM;IAOvB,gBAAgB,CAAC,EACf,gBAAgB,EAAE,gBAAgB,EAClC,qBAAqB,EAAE,qBAAqB,EAC5C,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,WAAW,EACxB,eAAe,EAAE,eAAe,EAChC,oBAAoB,EAAE,oBAAoB,GAC3C,EAAE,qBAAqB,GAAG,MAAM,EAAE;IAoEnC,cAAc,IAAI,MAAM,EAAE;IAyB1B,YAAY,IAAI,MAAM;IAItB,YAAY,IAAI,MAAM;IAItB,YAAY,IAAI,MAAM;CAGvB"}
@@ -0,0 +1,227 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Triangle = exports.TriangleConstructor = void 0;
4
+ const point_1 = require("./point");
5
+ const substractNode_1 = require("../../tree/nodes/operators/substractNode");
6
+ const powerNode_1 = require("../../tree/nodes/operators/powerNode");
7
+ const addNode_1 = require("../../tree/nodes/operators/addNode");
8
+ const numberNode_1 = require("../../tree/nodes/numbers/numberNode");
9
+ const sqrtNode_1 = require("../../tree/nodes/functions/sqrtNode");
10
+ const randint_1 = require("../utils/random/randint");
11
+ const randomLetter_1 = require("../../utils/strings/randomLetter");
12
+ const segment_1 = require("./segment");
13
+ class TriangleConstructor {
14
+ static fromIdentifiers(identifiers) {
15
+ return new Triangle(point_1.PointConstructor.fromIdentifiers(identifiers.vertexA), point_1.PointConstructor.fromIdentifiers(identifiers.vertexB), point_1.PointConstructor.fromIdentifiers(identifiers.vertexC));
16
+ }
17
+ static createRandomRightTriangle({ minRapport = 0, maxRapport = 5, names = ["A", "B", "C"], }) {
18
+ let pointA, pointB, pointC, d1, d2;
19
+ do {
20
+ const xA = (0, randint_1.randint)(-10, 11);
21
+ const yA = (0, randint_1.randint)(-10, 11);
22
+ const xB = (0, randint_1.randint)(-10, 11);
23
+ const yB = (0, randint_1.randint)(-10, 11);
24
+ pointA = new point_1.Point(names[0], new numberNode_1.NumberNode(xA), new numberNode_1.NumberNode(yA));
25
+ pointB = new point_1.Point(names[1], new numberNode_1.NumberNode(xB), new numberNode_1.NumberNode(yB));
26
+ d1 = pointA.distanceTo(pointB);
27
+ const xC = (0, randint_1.randint)(-11, 10);
28
+ const yC = yA - ((xB - xA) * (xC - xA)) / (yB - yA);
29
+ pointC = new point_1.Point(names[2], new numberNode_1.NumberNode(xC), new numberNode_1.NumberNode(yC));
30
+ d2 = pointA.distanceTo(pointC);
31
+ } while (!d1 || !d2 || d1 / d2 < minRapport || d1 / d2 > maxRapport);
32
+ return new Triangle(pointA, pointB, pointC);
33
+ }
34
+ static createRandomTriangle({ minAngle = 0.69, maxAngle = 1.5, names = ["A", "B", "C"], }) {
35
+ let pointA, pointB, pointC, triangle;
36
+ do {
37
+ pointA = new point_1.Point(names[0], new numberNode_1.NumberNode((0, randint_1.randint)(-10, 11)), new numberNode_1.NumberNode((0, randint_1.randint)(-10, 11)));
38
+ pointB = new point_1.Point(names[1], new numberNode_1.NumberNode((0, randint_1.randint)(-10, 11)), new numberNode_1.NumberNode((0, randint_1.randint)(-10, 11)));
39
+ pointC = new point_1.Point(names[2], new numberNode_1.NumberNode((0, randint_1.randint)(-10, 11)), new numberNode_1.NumberNode((0, randint_1.randint)(-10, 11)));
40
+ triangle = new Triangle(pointA, pointB, pointC);
41
+ } while (triangle.isRight() ||
42
+ pointA.distanceTo(pointB) === 0 ||
43
+ pointB.distanceTo(pointC) === 0 ||
44
+ pointC.distanceTo(pointA) === 0 ||
45
+ triangle.getAngleA() < minAngle ||
46
+ triangle.getAngleA() > maxAngle ||
47
+ triangle.getAngleB() < minAngle ||
48
+ triangle.getAngleB() > maxAngle);
49
+ return new Triangle(pointA, pointB, pointC);
50
+ }
51
+ static randomName() {
52
+ const startVertix = (0, randomLetter_1.randomLetter)(true, ["Y", "Z"]);
53
+ return [
54
+ startVertix,
55
+ String.fromCharCode(startVertix.charCodeAt(0) + 1),
56
+ String.fromCharCode(startVertix.charCodeAt(0) + 2),
57
+ ];
58
+ }
59
+ }
60
+ exports.TriangleConstructor = TriangleConstructor;
61
+ class Triangle {
62
+ constructor(vertexA, vertexB, vertexC) {
63
+ this.vertexA = vertexA;
64
+ this.vertexB = vertexB;
65
+ this.vertexC = vertexC;
66
+ }
67
+ getSegments() {
68
+ return [
69
+ this.getSideASegment(),
70
+ this.getSideBSegment(),
71
+ this.getSideCSegment(),
72
+ ];
73
+ }
74
+ getSideASegment() {
75
+ return new segment_1.Segment(this.vertexB, this.vertexC);
76
+ }
77
+ getSideBSegment() {
78
+ return new segment_1.Segment(this.vertexA, this.vertexC);
79
+ }
80
+ getSideCSegment() {
81
+ return new segment_1.Segment(this.vertexA, this.vertexB);
82
+ }
83
+ toIdentifiers() {
84
+ return {
85
+ vertexA: this.vertexA.toIdentifiers(),
86
+ vertexB: this.vertexB.toIdentifiers(),
87
+ vertexC: this.vertexC.toIdentifiers(),
88
+ };
89
+ }
90
+ getSideAnumber() {
91
+ return Math.hypot(this.vertexC.getXnumber() - this.vertexB.getXnumber(), this.vertexC.getYnumber() - this.vertexB.getYnumber());
92
+ }
93
+ getSideBnumber() {
94
+ return Math.hypot(this.vertexA.getXnumber() - this.vertexC.getXnumber(), this.vertexA.getYnumber() - this.vertexC.getYnumber());
95
+ }
96
+ getSideCnumber() {
97
+ return this.vertexA.distanceTo(this.vertexB);
98
+ }
99
+ getTriangleName() {
100
+ return this.vertexA.name + this.vertexB.name + this.vertexC.name;
101
+ }
102
+ getSideAnode() {
103
+ return new sqrtNode_1.SqrtNode(new addNode_1.AddNode(new powerNode_1.PowerNode(new substractNode_1.SubstractNode(this.vertexC.x, this.vertexB.x), new numberNode_1.NumberNode(2)), new powerNode_1.PowerNode(new substractNode_1.SubstractNode(this.vertexC.y, this.vertexB.y), new numberNode_1.NumberNode(2))));
104
+ }
105
+ getSideBnode() {
106
+ return new sqrtNode_1.SqrtNode(new addNode_1.AddNode(new powerNode_1.PowerNode(new substractNode_1.SubstractNode(this.vertexC.x, this.vertexA.x), new numberNode_1.NumberNode(2)), new powerNode_1.PowerNode(new substractNode_1.SubstractNode(this.vertexC.y, this.vertexA.y), new numberNode_1.NumberNode(2))));
107
+ }
108
+ getSideCnode() {
109
+ return new sqrtNode_1.SqrtNode(new addNode_1.AddNode(new powerNode_1.PowerNode(new substractNode_1.SubstractNode(this.vertexA.x, this.vertexB.x), new numberNode_1.NumberNode(2)), new powerNode_1.PowerNode(new substractNode_1.SubstractNode(this.vertexC.y, this.vertexB.y), new numberNode_1.NumberNode(2))));
110
+ }
111
+ getAngleA() {
112
+ return Math.acos((this.getSideBnumber() ** 2 +
113
+ this.getSideCnumber() ** 2 -
114
+ this.getSideAnumber() ** 2) /
115
+ (2 * this.getSideBnumber() * this.getSideCnumber()));
116
+ }
117
+ getAngleB() {
118
+ return Math.acos((this.getSideAnumber() ** 2 +
119
+ this.getSideCnumber() ** 2 -
120
+ this.getSideBnumber() ** 2) /
121
+ (2 * this.getSideAnumber() * this.getSideCnumber()));
122
+ }
123
+ getAngleC() {
124
+ return Math.acos((this.getSideAnumber() ** 2 +
125
+ this.getSideBnumber() ** 2 -
126
+ this.getSideCnumber() ** 2) /
127
+ (2 * this.getSideAnumber() * this.getSideBnumber()));
128
+ }
129
+ getPerimeter() {
130
+ return (this.getSideAnumber() + this.getSideBnumber() + this.getSideCnumber());
131
+ }
132
+ getArea() {
133
+ const s = this.getPerimeter() / 2;
134
+ return Math.sqrt(s *
135
+ (s - this.getSideAnumber()) *
136
+ (s - this.getSideBnumber()) *
137
+ (s - this.getSideCnumber()));
138
+ }
139
+ isRight() {
140
+ if (Math.abs(Math.cos(this.getAngleA())) < 0.001)
141
+ return true;
142
+ if (Math.abs(Math.cos(this.getAngleB())) < 0.001)
143
+ return true;
144
+ if (Math.abs(Math.cos(this.getAngleC())) < 0.001)
145
+ return true;
146
+ return false;
147
+ }
148
+ isEquilateral() {
149
+ return (this.getSideAnumber() === this.getSideBnumber() &&
150
+ this.getSideAnumber() === this.getSideCnumber());
151
+ }
152
+ isIsosceles() {
153
+ return (this.getSideAnumber() === this.getSideBnumber() ||
154
+ this.getSideAnumber() === this.getSideCnumber() ||
155
+ this.getSideBnumber() === this.getSideCnumber());
156
+ }
157
+ isScalene() {
158
+ return (this.getSideAnumber() !== this.getSideBnumber() &&
159
+ this.getSideBnumber() !== this.getSideCnumber() &&
160
+ this.getSideCnumber() !== this.getSideAnumber());
161
+ }
162
+ getRightAngle() {
163
+ if (Math.abs(Math.cos(this.getAngleA())) < 0.001)
164
+ return this.vertexA.name;
165
+ if (Math.abs(Math.cos(this.getAngleB())) < 0.001)
166
+ return this.vertexB.name;
167
+ if (Math.abs(Math.cos(this.getAngleC())) < 0.001)
168
+ return this.vertexC.name;
169
+ return "";
170
+ }
171
+ generateCommands({ highlightedAngle: highlightedAngle, colorHighlightedAngle: colorHighlightedAngle, showLabels: showLabels, setCaptions: setCaptions, highlightedSide: highlightedSide, colorHighlightedSide: colorHighlightedSide, }) {
172
+ let commands = [
173
+ `${this.vertexA.name} = Point({${this.vertexA.getXnumber()}, ${this.vertexA.getYnumber()}})`,
174
+ `${this.vertexB.name} = Point({${this.vertexB.getXnumber()}, ${this.vertexB.getYnumber()}})`,
175
+ `${this.vertexC.name} = Point({${this.vertexC.getXnumber()}, ${this.vertexC.getYnumber()}})`,
176
+ `ShowLabel(${this.vertexA.name}, true)`,
177
+ `ShowLabel(${this.vertexB.name}, true)`,
178
+ `ShowLabel(${this.vertexC.name}, true)`,
179
+ `${this.getSideCName()} = Segment(${this.vertexA.name}, ${this.vertexB.name})`,
180
+ `${this.getSideBName()} = Segment(${this.vertexA.name}, ${this.vertexC.name})`,
181
+ `${this.getSideAName()} = Segment(${this.vertexC.name}, ${this.vertexB.name})`,
182
+ `ShowLabel(${this.getSideCName()}, false)`,
183
+ `ShowLabel(${this.getSideBName()}, false)`,
184
+ `ShowLabel(${this.getSideBName()}, false)`,
185
+ ];
186
+ if (this.isRight())
187
+ commands.push(`alpha = Angle(${this.vertexB.name},${this.vertexA.name},${this.vertexC.name}, Line(${this.vertexB.name},${this.vertexA.name}))`, `ShowLabel(alpha, false)`);
188
+ const defautColor = "Red";
189
+ if (highlightedAngle) {
190
+ let temp = [""];
191
+ if (highlightedAngle === this.vertexB.name)
192
+ temp = [this.vertexA.name, this.vertexB.name, this.vertexC.name];
193
+ if (highlightedAngle === this.vertexC.name)
194
+ temp = [this.vertexB.name, this.vertexC.name, this.vertexA.name];
195
+ if (highlightedAngle === this.vertexA.name)
196
+ temp = [this.vertexC.name, this.vertexA.name, this.vertexB.name];
197
+ commands.push(`be = Angle(${temp[0]}, ${temp[1]}, ${temp[2]}, Line(${temp[0]}, ${temp[1]}))`, `ShowLabel(be, false)`, `SetColor(be, "${colorHighlightedAngle ?? defautColor}")`);
198
+ }
199
+ if (showLabels)
200
+ for (let i = 0; i < showLabels.length; i++) {
201
+ commands.push(`ShowLabel(${showLabels[i]}, true)`);
202
+ if (setCaptions)
203
+ commands.push(`SetCaption(${showLabels[i]}, "${setCaptions[i]}")`);
204
+ }
205
+ if (highlightedSide)
206
+ commands.push(`SetColor(${highlightedSide}, "${colorHighlightedSide ?? defautColor}")`);
207
+ return commands;
208
+ }
209
+ generateCoords() {
210
+ return [
211
+ Math.min(this.vertexA.getXnumber(), this.vertexB.getXnumber(), this.vertexC.getXnumber()) - 1,
212
+ Math.max(this.vertexA.getXnumber(), this.vertexB.getXnumber(), this.vertexC.getXnumber()) + 1,
213
+ Math.min(this.vertexA.getYnumber(), this.vertexB.getYnumber(), this.vertexC.getYnumber()) - 1,
214
+ Math.max(this.vertexA.getYnumber(), this.vertexB.getYnumber(), this.vertexC.getYnumber()) + 1,
215
+ ];
216
+ }
217
+ getSideAName() {
218
+ return this.vertexB.name + this.vertexC.name;
219
+ }
220
+ getSideBName() {
221
+ return this.vertexC.name + this.vertexA.name;
222
+ }
223
+ getSideCName() {
224
+ return this.vertexA.name + this.vertexB.name;
225
+ }
226
+ }
227
+ exports.Triangle = Triangle;
@@ -1 +1 @@
1
- {"version":3,"file":"decimal.d.ts","sourceRoot":"","sources":["../../../../src/math/numbers/decimals/decimal.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;AACjE,OAAO,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,yCAAyC,CAAC;AAEvE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAEjD,eAAO,MAAM,iBAAiB,UAAyC,CAAC;AACxE,8BAAsB,kBAAkB;IACtC,MAAM,CAAC,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,YAAY,GAAE,MAAU,GAAG,MAAM;IAY1E,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO;IAMpE,MAAM,CAAC,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO;IAK/D,MAAM,CAAC,gBAAgB,CAAC,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO;CAMrD;AAED,qBAAa,OAAQ,YAAW,MAAM;IACpC,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,aAAsB;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;gBACR,KAAK,EAAE,MAAM,GAAG,MAAM;IAQlC,KAAK,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IASxB,MAAM,CAAC,CAAC,EAAE,MAAM;IAIhB;;;;OAIG;IACH,KAAK,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM;IAIhC,oBAAoB,CAAC,KAAK,EAAE,MAAM;IAkClC,gBAAgB;IA6BhB,oBAAoB,CAAC,QAAQ,CAAC,EAAE,MAAM;IAwCtC,cAAc,CAAC,IAAI,EAAE,MAAM;IAS3B,UAAU;IAMV,MAAM;IAIN,aAAa;IAIb,YAAY,CAAC,UAAU,EAAE,MAAM;IAS/B,YAAY,CAAC,UAAU,EAAE,MAAM;CAShC"}
1
+ {"version":3,"file":"decimal.d.ts","sourceRoot":"","sources":["../../../../src/math/numbers/decimals/decimal.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;AACjE,OAAO,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,yCAAyC,CAAC;AAEvE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAEjD,eAAO,MAAM,iBAAiB,UAAyC,CAAC;AACxE,8BAAsB,kBAAkB;IACtC,MAAM,CAAC,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,YAAY,GAAE,MAAU,GAAG,MAAM;IAY1E,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO;IAMpE,MAAM,CAAC,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO;IAK/D,MAAM,CAAC,gBAAgB,CAAC,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO;CAMrD;AAED,qBAAa,OAAQ,YAAW,MAAM;IACpC,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,aAAsB;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;gBACR,KAAK,EAAE,MAAM,GAAG,MAAM;IAQlC,KAAK,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IASxB,MAAM,CAAC,CAAC,EAAE,MAAM;IAIhB;;;;OAIG;IACH,KAAK,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM;IAIhC,oBAAoB,CAAC,KAAK,EAAE,MAAM;IAiClC,gBAAgB;IA6BhB,oBAAoB,CAAC,QAAQ,CAAC,EAAE,MAAM;IAuCtC,cAAc,CAAC,IAAI,EAAE,MAAM;IAS3B,UAAU;IAMV,MAAM;IAIN,aAAa;IAIb,YAAY,CAAC,UAAU,EAAE,MAAM;IAS/B,YAAY,CAAC,UAAU,EAAE,MAAM;CAShC"}
@@ -101,7 +101,6 @@ class Decimal {
101
101
  (isNegative ? "-" : "") +
102
102
  intPartString.slice(0, power + intPartString.length);
103
103
  }
104
- // console.log("in", newIntPart, newFracPart);
105
104
  return DecimalConstructor.fromParts(newIntPart, newFracPart);
106
105
  }
107
106
  toScientificPart() {
@@ -142,7 +141,6 @@ class Decimal {
142
141
  let value = decimals === undefined
143
142
  ? this.toScientificPart()
144
143
  : (0, round_1.round)(this.toScientificPart(), decimals);
145
- // console.log(value);
146
144
  let power = 0;
147
145
  if (value >= 10) {
148
146
  value = 1;
@@ -9,6 +9,7 @@ export declare abstract class RationalConstructor {
9
9
  */
10
10
  static randomSimplifiable(maxGcd?: number): Rational;
11
11
  static randomIrreductible(max?: number): Rational;
12
+ static randomIrreductibleProba(maxDenum?: number): Rational | Integer;
12
13
  static randomIrreductibleWithSign(max?: number): Rational;
13
14
  static randomPureRational(): Rational;
14
15
  }
@@ -1 +1 @@
1
- {"version":3,"file":"rational.d.ts","sourceRoot":"","sources":["../../../../src/math/numbers/rationals/rational.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,YAAY,EAAE,MAAM,yCAAyC,CAAC;AACvE,OAAO,EAAQ,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE1D,OAAO,EAAE,YAAY,EAAE,MAAM,yCAAyC,CAAC;AAKvE,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAE7C,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAE/C,8BAAsB,mBAAmB;IACvC;;OAEG;IACH,MAAM,CAAC,kBAAkB,CAAC,MAAM,GAAE,MAAW;IAW7C,MAAM,CAAC,kBAAkB,CAAC,GAAG,GAAE,MAAW;IAO1C,MAAM,CAAC,0BAA0B,CAAC,GAAG,GAAE,MAAW;IAQlD,MAAM,CAAC,kBAAkB;CAO1B;AAED,qBAAa,QAAS,YAAW,MAAM;IACrC,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,EAAE,OAAO,CAAC;IACtB,IAAI,EAAE,UAAU,CAAC;gBAEL,SAAS,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM;IAYlD,MAAM,CAAC,CAAC,EAAE,MAAM;IAGhB,KAAK;IAML,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM;IAkBvB,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO;IAgBxC,OAAO,CAAC,cAAc,EAAE,OAAO,GAAG,MAAM;IAIxC,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM;IAgB1B,QAAQ,IAAI,QAAQ;IAIpB,MAAM,CAAC,IAAI,CAAC,EAAE,WAAW;IAgBzB,cAAc;IAId,QAAQ,IAAI,OAAO,GAAG,QAAQ;CAS/B"}
1
+ {"version":3,"file":"rational.d.ts","sourceRoot":"","sources":["../../../../src/math/numbers/rationals/rational.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,YAAY,EAAE,MAAM,yCAAyC,CAAC;AACvE,OAAO,EAAQ,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE1D,OAAO,EAAE,YAAY,EAAE,MAAM,yCAAyC,CAAC;AAKvE,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAE7C,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAE/C,8BAAsB,mBAAmB;IACvC;;OAEG;IACH,MAAM,CAAC,kBAAkB,CAAC,MAAM,GAAE,MAAW;IAW7C,MAAM,CAAC,kBAAkB,CAAC,GAAG,GAAE,MAAW;IAO1C,MAAM,CAAC,uBAAuB,CAAC,QAAQ,GAAE,MAAW;IAKpD,MAAM,CAAC,0BAA0B,CAAC,GAAG,GAAE,MAAW;IAQlD,MAAM,CAAC,kBAAkB;CAO1B;AAED,qBAAa,QAAS,YAAW,MAAM;IACrC,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,EAAE,OAAO,CAAC;IACtB,IAAI,EAAE,UAAU,CAAC;gBAEL,SAAS,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM;IAYlD,MAAM,CAAC,CAAC,EAAE,MAAM;IAGhB,KAAK;IAML,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM;IAkBvB,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO;IAgBxC,OAAO,CAAC,cAAc,EAAE,OAAO,GAAG,MAAM;IAIxC,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM;IAgB1B,QAAQ,IAAI,QAAQ;IAIpB,MAAM,CAAC,IAAI,CAAC,EAAE,WAAW;IAgBzB,cAAc;IAId,QAAQ,IAAI,OAAO,GAAG,QAAQ;CAS/B"}
@@ -38,6 +38,11 @@ class RationalConstructor {
38
38
  const [num, denum] = (0, shuffle_1.shuffle)([a, b]);
39
39
  return new Rational(num, denum);
40
40
  }
41
+ static randomIrreductibleProba(maxDenum = 11) {
42
+ const b = (0, randint_1.randint)(2, maxDenum);
43
+ const a = (0, randint_1.randint)(1, b);
44
+ return new Rational(a, b).simplify();
45
+ }
41
46
  static randomIrreductibleWithSign(max = 11) {
42
47
  const sign = (0, coinFlip_1.coinFlip)() ? 1 : -1;
43
48
  const a = (0, randint_1.randint)(2, max);
@@ -32,7 +32,7 @@ export declare abstract class GeneralTrinomConstructor {
32
32
  static randomNiceRoots(nbOfRoots?: number): GeneralTrinom;
33
33
  static fromCoeffs(coeffs: number[]): GeneralTrinom;
34
34
  }
35
- type TrinomOptions = {
35
+ type GeneralTrinomOptions = {
36
36
  variable: string;
37
37
  };
38
38
  export declare class GeneralTrinom {
@@ -41,7 +41,7 @@ export declare class GeneralTrinom {
41
41
  c: AlgebraicNode;
42
42
  variable: string;
43
43
  type: NodeType;
44
- constructor(a: AlgebraicNode | number, b: AlgebraicNode | number, c: AlgebraicNode | number, opts?: TrinomOptions);
44
+ constructor(a: AlgebraicNode | number, b: AlgebraicNode | number, c: AlgebraicNode | number, opts?: GeneralTrinomOptions);
45
45
  getDelta(): AlgebraicNode;
46
46
  getRoots(): AlgebraicNode[];
47
47
  toTree(): AddNode;
@@ -1 +1 @@
1
- {"version":3,"file":"generalTrinom.d.ts","sourceRoot":"","sources":["../../../src/math/polynomials/generalTrinom.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAO,MAAM,oCAAoC,CAAC;AA0BlE,OAAO,EAAE,aAAa,EAAmB,MAAM,gCAAgC,CAAC;AAIhF,OAAO,EAGL,QAAQ,EAET,MAAM,uBAAuB,CAAC;AAG/B,8BAAsB,wBAAwB;IAC5C,MAAM,CAAC,MAAM,CACX,KAAK,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,EAC3D,KAAK,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,EAC3D,KAAK,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,GAC1D,aAAa;IAmBhB,MAAM,CAAC,eAAe,CACpB,KAAK,CAAC,EAAE;QACN,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;QACpB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;KACjB,EACD,SAAS,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,EAC/D,QAAQ,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,GAC7D,aAAa;IAmBhB,MAAM,CAAC,eAAe,CAAC,SAAS,GAAE,MAAU;IAqB5C,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE;CAGnC;AAED,KAAK,aAAa,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC;AAC1C,qBAAa,aAAa;IACxB,CAAC,EAAE,aAAa,CAAC;IACjB,CAAC,EAAE,aAAa,CAAC;IACjB,CAAC,EAAE,aAAa,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,QAAQ,CAAmB;gBAG/B,CAAC,EAAE,aAAa,GAAG,MAAM,EACzB,CAAC,EAAE,aAAa,GAAG,MAAM,EACzB,CAAC,EAAE,aAAa,GAAG,MAAM,EACzB,IAAI,CAAC,EAAE,aAAa;IAStB,QAAQ;IAiBR,QAAQ,IAAI,aAAa,EAAE;IAgB3B,MAAM;IAON,KAAK;IAGL,SAAS;CAGV"}
1
+ {"version":3,"file":"generalTrinom.d.ts","sourceRoot":"","sources":["../../../src/math/polynomials/generalTrinom.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAO,MAAM,oCAAoC,CAAC;AA0BlE,OAAO,EAAE,aAAa,EAAmB,MAAM,gCAAgC,CAAC;AAIhF,OAAO,EAGL,QAAQ,EAET,MAAM,uBAAuB,CAAC;AAG/B,8BAAsB,wBAAwB;IAC5C,MAAM,CAAC,MAAM,CACX,KAAK,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,EAC3D,KAAK,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,EAC3D,KAAK,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,GAC1D,aAAa;IAmBhB,MAAM,CAAC,eAAe,CACpB,KAAK,CAAC,EAAE;QACN,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;QACpB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;KACjB,EACD,SAAS,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,EAC/D,QAAQ,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,GAC7D,aAAa;IAmBhB,MAAM,CAAC,eAAe,CAAC,SAAS,GAAE,MAAU;IAqB5C,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE;CAGnC;AAED,KAAK,oBAAoB,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC;AACjD,qBAAa,aAAa;IACxB,CAAC,EAAE,aAAa,CAAC;IACjB,CAAC,EAAE,aAAa,CAAC;IACjB,CAAC,EAAE,aAAa,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,QAAQ,CAAmB;gBAG/B,CAAC,EAAE,aAAa,GAAG,MAAM,EACzB,CAAC,EAAE,aAAa,GAAG,MAAM,EACzB,CAAC,EAAE,aAAa,GAAG,MAAM,EACzB,IAAI,CAAC,EAAE,oBAAoB;IAS7B,QAAQ;IAiBR,QAAQ,IAAI,aAAa,EAAE;IAgB3B,MAAM;IAON,KAAK;IAGL,SAAS;CAGV"}
@@ -0,0 +1,10 @@
1
+ import { AlgebraicNode } from "../../tree/nodes/algebraicNode";
2
+ export declare class Binomial {
3
+ n: number;
4
+ p: AlgebraicNode;
5
+ constructor(n: number, p: AlgebraicNode);
6
+ sup(k: number): number;
7
+ inf(k: number): number;
8
+ ineq(a: number, b: number): number;
9
+ }
10
+ //# sourceMappingURL=binomial.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"binomial.d.ts","sourceRoot":"","sources":["../../../src/math/probability/binomial.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAK/D,qBAAa,QAAQ;IACnB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,aAAa,CAAC;gBACL,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,aAAa;IAKvC,GAAG,CAAC,CAAC,EAAE,MAAM;IAWb,GAAG,CAAC,CAAC,EAAE,MAAM;IAWb,IAAI,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM;CAW1B"}
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Binomial = void 0;
4
+ const combination_1 = require("../utils/combinatorics/combination");
5
+ const sum_1 = require("../utils/sum");
6
+ class Binomial {
7
+ constructor(n, p) {
8
+ this.n = n;
9
+ this.p = p;
10
+ }
11
+ sup(k) {
12
+ const proba = this.p.evaluate();
13
+ return (0, sum_1.sum)(k, this.n, (i) => (0, combination_1.combinations)(i, this.n) *
14
+ Math.pow(proba, i) *
15
+ Math.pow(1 - proba, this.n - i));
16
+ }
17
+ inf(k) {
18
+ const proba = this.p.evaluate();
19
+ return (0, sum_1.sum)(0, k, (i) => (0, combination_1.combinations)(i, this.n) *
20
+ Math.pow(proba, i) *
21
+ Math.pow(1 - proba, this.n - i));
22
+ }
23
+ ineq(a, b) {
24
+ const proba = this.p.evaluate();
25
+ return (0, sum_1.sum)(a, b, (i) => (0, combination_1.combinations)(i, this.n) *
26
+ Math.pow(proba, i) *
27
+ Math.pow(1 - proba, this.n - i));
28
+ }
29
+ }
30
+ exports.Binomial = Binomial;
@@ -26,7 +26,7 @@ export declare class Interval implements MathSetInterface {
26
26
  constructor(min: AlgebraicNode, max: AlgebraicNode, closure: ClosureType);
27
27
  equals(interval: Interval): boolean;
28
28
  union(interval: Interval): MathSet;
29
- intersection(interval: Interval): IntervalNode | DiscreteSetNode;
29
+ intersection(interval: Interval): DiscreteSetNode | IntervalNode;
30
30
  insideToTex(): string;
31
31
  toTex(): string;
32
32
  toInequality(): string;
@@ -0,0 +1,11 @@
1
+ import { AlgebraicNode } from "../../tree/nodes/algebraicNode";
2
+ export declare class GeneralSystem {
3
+ coeffs: AlgebraicNode[][];
4
+ constructor(coeffs: AlgebraicNode[][]);
5
+ solve(): {
6
+ x: AlgebraicNode;
7
+ y: AlgebraicNode;
8
+ };
9
+ toTex(): string;
10
+ }
11
+ //# sourceMappingURL=generalSystem.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generalSystem.d.ts","sourceRoot":"","sources":["../../../src/math/systems/generalSystem.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAgB/D,qBAAa,aAAa;IACxB,MAAM,EAAE,aAAa,EAAE,EAAE,CAAC;gBAWd,MAAM,EAAE,aAAa,EAAE,EAAE;IAGrC,KAAK;;;;IA4CL,KAAK;CAYN"}