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.
- package/lib/exercises/math/calcul/proportionality/index.d.ts +1 -0
- package/lib/exercises/math/calcul/proportionality/index.d.ts.map +1 -1
- package/lib/exercises/math/calcul/proportionality/index.js +1 -0
- package/lib/exercises/math/calcul/proportionality/isTableProportional.d.ts +8 -0
- package/lib/exercises/math/calcul/proportionality/isTableProportional.d.ts.map +1 -0
- package/lib/exercises/math/calcul/proportionality/isTableProportional.js +91 -0
- package/lib/exercises/math/calculLitteral/equation/equationType4Exercise.d.ts.map +1 -1
- package/lib/exercises/math/calculLitteral/equation/equationType4Exercise.js +0 -1
- package/lib/exercises/math/functions/trinoms/coefficientsIdentification.d.ts +11 -0
- package/lib/exercises/math/functions/trinoms/coefficientsIdentification.d.ts.map +1 -0
- package/lib/exercises/math/functions/trinoms/coefficientsIdentification.js +131 -0
- package/lib/exercises/math/functions/trinoms/index.d.ts +1 -0
- package/lib/exercises/math/functions/trinoms/index.d.ts.map +1 -1
- package/lib/exercises/math/functions/trinoms/index.js +1 -0
- package/lib/exercises/math/functions/trinoms/summitAbscissFromDevForm.d.ts.map +1 -1
- package/lib/exercises/math/functions/trinoms/summitAbscissFromDevForm.js +39 -1
- package/lib/exercises/math/geometry/areas/rightTriangleArea.js +2 -2
- package/lib/exercises/math/geometry/areas/triangleArea.js +2 -2
- package/lib/exercises/math/geometry/euclidianConstructions/buildTriangleWithSizes.d.ts +7 -0
- package/lib/exercises/math/geometry/euclidianConstructions/buildTriangleWithSizes.d.ts.map +1 -0
- package/lib/exercises/math/geometry/euclidianConstructions/buildTriangleWithSizes.js +117 -0
- package/lib/exercises/math/geometry/euclidianConstructions/index.d.ts +2 -0
- package/lib/exercises/math/geometry/euclidianConstructions/index.d.ts.map +1 -1
- package/lib/exercises/math/geometry/euclidianConstructions/index.js +2 -0
- package/lib/exercises/math/geometry/euclidianConstructions/pointImageFromTranslation.d.ts +10 -0
- package/lib/exercises/math/geometry/euclidianConstructions/pointImageFromTranslation.d.ts.map +1 -0
- package/lib/exercises/math/geometry/euclidianConstructions/pointImageFromTranslation.js +102 -0
- package/lib/exercises/math/geometry/pythagore/pythagore.d.ts +2 -0
- package/lib/exercises/math/geometry/pythagore/pythagore.d.ts.map +1 -1
- package/lib/exercises/math/geometry/pythagore/pythagore.js +4 -3
- package/lib/exercises/math/geometry/pythagore/pythagoreCalcul.d.ts +2 -0
- package/lib/exercises/math/geometry/pythagore/pythagoreCalcul.d.ts.map +1 -1
- package/lib/exercises/math/geometry/pythagore/pythagoreCalcul.js +4 -3
- package/lib/exercises/math/geometry/shapes/basicShapesNaming.d.ts.map +1 -1
- package/lib/exercises/math/geometry/shapes/basicShapesNaming.js +0 -1
- package/lib/exercises/math/geometry/thales/index.d.ts.map +1 -1
- package/lib/exercises/math/geometry/thales/index.js +1 -0
- package/lib/exercises/math/geometry/thales/thales.d.ts +7 -0
- package/lib/exercises/math/geometry/thales/thales.d.ts.map +1 -1
- package/lib/exercises/math/geometry/thales/thales.js +1 -1
- package/lib/exercises/math/geometry/thales/thalesCalcul.d.ts +11 -5
- package/lib/exercises/math/geometry/thales/thalesCalcul.d.ts.map +1 -1
- package/lib/exercises/math/geometry/thales/thalesCalcul.js +166 -118
- package/lib/exercises/math/geometry/thales/thalesCalculOld.d.ts +1 -0
- package/lib/exercises/math/geometry/thales/thalesCalculOld.d.ts.map +1 -0
- package/lib/exercises/math/geometry/thales/thalesCalculOld.js +214 -0
- package/lib/exercises/math/percent/index.d.ts +0 -1
- package/lib/exercises/math/percent/index.d.ts.map +1 -1
- package/lib/exercises/math/percent/index.js +0 -1
- package/lib/exercises/math/probaStat/binomial/binomialInequation.d.ts +16 -0
- package/lib/exercises/math/probaStat/binomial/binomialInequation.d.ts.map +1 -0
- package/lib/exercises/math/probaStat/binomial/binomialInequation.js +159 -0
- package/lib/exercises/math/probaStat/binomial/calculateProbaOfBinomialDistribution.d.ts +13 -0
- package/lib/exercises/math/probaStat/binomial/calculateProbaOfBinomialDistribution.d.ts.map +1 -0
- package/lib/exercises/math/probaStat/binomial/calculateProbaOfBinomialDistribution.js +106 -0
- package/lib/exercises/math/probaStat/binomial/expectedValueOfBinomialProba.d.ts +9 -0
- package/lib/exercises/math/probaStat/binomial/expectedValueOfBinomialProba.d.ts.map +1 -0
- package/lib/exercises/math/probaStat/binomial/expectedValueOfBinomialProba.js +89 -0
- package/lib/exercises/math/probaStat/binomial/index.d.ts +5 -0
- package/lib/exercises/math/probaStat/binomial/index.d.ts.map +1 -0
- package/lib/exercises/math/probaStat/binomial/index.js +20 -0
- package/lib/exercises/math/probaStat/binomial/varianceOfBinomialProba.d.ts +9 -0
- package/lib/exercises/math/probaStat/binomial/varianceOfBinomialProba.d.ts.map +1 -0
- package/lib/exercises/math/probaStat/binomial/varianceOfBinomialProba.js +94 -0
- package/lib/exercises/math/probaStat/cardBasicProbas.d.ts +3 -0
- package/lib/exercises/math/probaStat/cardBasicProbas.d.ts.map +1 -1
- package/lib/exercises/math/probaStat/cardBasicProbas.js +3 -2
- package/lib/exercises/math/probaStat/diceBasicProbas.d.ts +1 -0
- package/lib/exercises/math/probaStat/diceBasicProbas.d.ts.map +1 -1
- package/lib/exercises/math/probaStat/diceBasicProbas.js +8 -4
- package/lib/exercises/math/probaStat/index.d.ts +1 -3
- package/lib/exercises/math/probaStat/index.d.ts.map +1 -1
- package/lib/exercises/math/probaStat/index.js +1 -3
- package/lib/exercises/math/probaStat/issuesCountingForCards.d.ts +2 -0
- package/lib/exercises/math/probaStat/issuesCountingForCards.d.ts.map +1 -1
- package/lib/exercises/math/probaStat/issuesCountingForCards.js +1 -1
- package/lib/exercises/math/probaStat/probaFromTableNoContext.d.ts +4 -1
- package/lib/exercises/math/probaStat/probaFromTableNoContext.d.ts.map +1 -1
- package/lib/exercises/math/probaStat/probaFromTableNoContext.js +17 -5
- package/lib/exercises/math/probaStat/stats1var/marginalAndConditionalFrequency.js +0 -1
- package/lib/exercises/math/probaStat/stats2var/fineAdjustementExercise.d.ts +2 -0
- package/lib/exercises/math/probaStat/stats2var/fineAdjustementExercise.d.ts.map +1 -1
- package/lib/exercises/math/probaStat/stats2var/fineAdjustementExercise.js +4 -1
- package/lib/exercises/math/trigonometry/associatePoint.d.ts +3 -0
- package/lib/exercises/math/trigonometry/associatePoint.d.ts.map +1 -1
- package/lib/exercises/math/trigonometry/associatePoint.js +5 -1
- package/lib/exercises/math/trigonometry/trigonometry.js +2 -2
- package/lib/exercises/math/trigonometry/trigonometryAngleCalcul.js +2 -2
- package/lib/exercises/math/trigonometry/trigonometrySideCalcul.js +2 -2
- package/lib/exercises/pc/calibrationCurveOfSolution.d.ts +1 -0
- package/lib/exercises/pc/calibrationCurveOfSolution.d.ts.map +1 -1
- package/lib/exercises/pc/calibrationCurveOfSolution.js +2 -0
- package/lib/exercises/pc/chemicalReactions/stoichiometricReaction.d.ts +6 -1
- package/lib/exercises/pc/chemicalReactions/stoichiometricReaction.d.ts.map +1 -1
- package/lib/exercises/pc/chemicalReactions/stoichiometricReaction.js +1 -1
- package/lib/exercises/pc/electricity/ohmicConductorOrGenerator.d.ts +4 -1
- package/lib/exercises/pc/electricity/ohmicConductorOrGenerator.d.ts.map +1 -1
- package/lib/exercises/pc/electricity/ohmicConductorOrGenerator.js +2 -1
- package/lib/exercises/pc/identifyAtomicMassOrAtomicNb.d.ts +2 -0
- package/lib/exercises/pc/identifyAtomicMassOrAtomicNb.d.ts.map +1 -1
- package/lib/exercises/pc/identifyAtomicMassOrAtomicNb.js +2 -0
- package/lib/exercises/pc/mole/molarMass.js +1 -1
- package/lib/exercises/pc/motion/typeOfAcceleration.d.ts +4 -1
- package/lib/exercises/pc/motion/typeOfAcceleration.d.ts.map +1 -1
- package/lib/exercises/pc/motion/typeOfAcceleration.js +5 -1
- package/lib/exercises/pc/motion/typeOfMovement.d.ts +4 -1
- package/lib/exercises/pc/motion/typeOfMovement.d.ts.map +1 -1
- package/lib/exercises/pc/motion/typeOfMovement.js +1 -1
- package/lib/exercises/pc/recognizeRefractionOrReflectionAngles.d.ts +3 -1
- package/lib/exercises/pc/recognizeRefractionOrReflectionAngles.d.ts.map +1 -1
- package/lib/exercises/pc/recognizeRefractionOrReflectionAngles.js +1 -1
- package/lib/exercises/utils/geogebra/toGGBCommandsProps.d.ts +3 -0
- package/lib/exercises/utils/geogebra/toGGBCommandsProps.d.ts.map +1 -1
- package/lib/exercises/utils/geogebra/toolBarConstructor.d.ts +4 -0
- package/lib/exercises/utils/geogebra/toolBarConstructor.d.ts.map +1 -1
- package/lib/exercises/utils/geogebra/toolBarConstructor.js +8 -0
- package/lib/exercises/utils/getDistinctQuestions.d.ts.map +1 -1
- package/lib/exercises/utils/getDistinctQuestions.js +11 -4
- package/lib/index.d.ts +94 -26
- package/lib/index.d.ts.map +1 -1
- package/lib/math/geometry/CloudPoints.d.ts +5 -1
- package/lib/math/geometry/CloudPoints.d.ts.map +1 -1
- package/lib/math/geometry/CloudPoints.js +5 -0
- package/lib/math/geometry/line.d.ts +23 -1
- package/lib/math/geometry/line.d.ts.map +1 -1
- package/lib/math/geometry/line.js +53 -2
- package/lib/math/geometry/point.d.ts +15 -13
- package/lib/math/geometry/point.d.ts.map +1 -1
- package/lib/math/geometry/point.js +28 -12
- package/lib/math/geometry/segment.d.ts +11 -1
- package/lib/math/geometry/segment.d.ts.map +1 -1
- package/lib/math/geometry/segment.js +12 -0
- package/lib/math/geometry/triangle.d.ts +67 -0
- package/lib/math/geometry/triangle.d.ts.map +1 -0
- package/lib/math/geometry/triangle.js +227 -0
- package/lib/math/numbers/decimals/decimal.d.ts.map +1 -1
- package/lib/math/numbers/decimals/decimal.js +0 -2
- package/lib/math/numbers/rationals/rational.d.ts +1 -0
- package/lib/math/numbers/rationals/rational.d.ts.map +1 -1
- package/lib/math/numbers/rationals/rational.js +5 -0
- package/lib/math/polynomials/generalTrinom.d.ts +2 -2
- package/lib/math/polynomials/generalTrinom.d.ts.map +1 -1
- package/lib/math/probability/binomial.d.ts +10 -0
- package/lib/math/probability/binomial.d.ts.map +1 -0
- package/lib/math/probability/binomial.js +30 -0
- package/lib/math/sets/intervals/intervals.d.ts +1 -1
- package/lib/math/systems/generalSystem.d.ts +11 -0
- package/lib/math/systems/generalSystem.d.ts.map +1 -0
- package/lib/math/systems/generalSystem.js +79 -0
- package/lib/playground.d.ts.map +1 -1
- package/lib/playground.js +1 -4
- package/lib/server.js +0 -2
- package/lib/tree/nodes/geometry/pointNode.d.ts +1 -10
- package/lib/tree/nodes/geometry/pointNode.d.ts.map +1 -1
- package/lib/tree/nodes/inequations/inequationNode.js +1 -1
- package/lib/tree/nodes/inequations/inequationSolutionNode.d.ts +2 -11
- package/lib/tree/nodes/inequations/inequationSolutionNode.d.ts.map +1 -1
- package/lib/tree/nodes/node.d.ts +2 -1
- package/lib/tree/nodes/node.d.ts.map +1 -1
- package/lib/tree/nodes/node.js +1 -0
- package/lib/tree/nodes/nodeConstructor.d.ts +4 -3
- package/lib/tree/nodes/nodeConstructor.d.ts.map +1 -1
- package/lib/tree/nodes/nodeConstructor.js +4 -0
- package/lib/tree/nodes/operators/addNode.d.ts.map +1 -1
- package/lib/tree/nodes/operators/addNode.js +20 -8
- package/lib/tree/nodes/operators/binomialCoefficientNode.d.ts +35 -0
- package/lib/tree/nodes/operators/binomialCoefficientNode.d.ts.map +1 -0
- package/lib/tree/nodes/operators/binomialCoefficientNode.js +52 -0
- package/lib/tree/nodes/operators/fractionNode.d.ts +1 -1
- package/lib/tree/nodes/operators/fractionNode.d.ts.map +1 -1
- package/lib/tree/nodes/operators/fractionNode.js +2 -4
- package/lib/tree/nodes/operators/operatorNode.d.ts +2 -1
- package/lib/tree/nodes/operators/operatorNode.d.ts.map +1 -1
- package/lib/tree/nodes/operators/operatorNode.js +1 -0
- package/lib/tree/nodes/sets/intervalNode.d.ts +9 -10
- package/lib/tree/nodes/sets/intervalNode.d.ts.map +1 -1
- package/lib/tree/nodes/sets/intervalNode.js +1 -0
- package/lib/utils/alea/random.d.ts.map +1 -1
- 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":"
|
|
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)(
|
|
12
|
-
const y = (0, randint_1.randint)(
|
|
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
|
-
|
|
67
|
-
throw Error("general point not implemented yet");
|
|
68
|
-
return this.x.value;
|
|
77
|
+
return this.x.evaluate();
|
|
69
78
|
}
|
|
70
79
|
getYnumber() {
|
|
71
|
-
|
|
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
|
-
|
|
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;
|
|
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;
|
|
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
|
|
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?:
|
|
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,
|
|
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):
|
|
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"}
|