pimath 0.0.120 → 0.0.122
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/.idea/PI.iml +7 -1
- package/.idea/shelf/Uncommitted_changes_before_Update_at_24_07_2023_15_31_[Default_Changelist]/shelved.patch +90 -0
- package/.idea/shelf/Uncommitted_changes_before_Update_at_24_07_2023_15_31_[Default_Changelist]1/shelved.patch +107 -0
- package/.idea/shelf/Uncommitted_changes_before_Update_at_24_07_2023_15_31__Default_Changelist_.xml +4 -0
- package/.idea/shelf/Uncommitted_changes_before_Update_at_24_07_2023_15_31__Default_Changelist_1.xml +4 -0
- package/LICENSE.md +1 -1
- package/dev/pimath.js +7929 -0
- package/dev/pimath.js.map +1 -0
- package/dist/{pi.js → pimath.js} +7613 -7840
- package/dist/pimath.js.map +1 -0
- package/dist/pimath.min.js +2 -0
- package/dist/pimath.min.js.map +1 -0
- package/docs/assets/main.js +58 -58
- package/docs/assets/search.js +1 -1
- package/docs/assets/style.css +1367 -1280
- package/docs/classes/Logicalset.Logicalset.html +221 -212
- package/docs/classes/Polynom.Rational.html +391 -388
- package/docs/classes/Vector-1.Vector.html +494 -448
- package/docs/classes/Vector.Point.html +341 -342
- package/docs/classes/algebra_equation.Equation.html +796 -753
- package/docs/classes/algebra_linearSystem.LinearSystem.html +408 -397
- package/docs/classes/algebra_monom.Monom.html +967 -910
- package/docs/classes/algebra_polynom.Polynom.html +1281 -1260
- package/docs/classes/coefficients_fraction.Fraction.html +939 -931
- package/docs/classes/geometry_circle.Circle.html +476 -476
- package/docs/classes/geometry_line.Line.html +779 -719
- package/docs/classes/geometry_triangle.Triangle.html +429 -420
- package/docs/classes/numeric.Numeric.html +269 -263
- package/docs/classes/shutingyard.Shutingyard.html +259 -248
- package/docs/enums/algebra_equation.PARTICULAR_SOLUTION.html +89 -88
- package/docs/enums/geometry_line.LinePropriety.html +102 -102
- package/docs/enums/shutingyard.ShutingyardMode.html +106 -102
- package/docs/enums/shutingyard.ShutingyardType.html +120 -116
- package/docs/index.html +63 -65
- package/docs/interfaces/algebra_equation.ISolution.html +111 -109
- package/docs/interfaces/algebra_polynom.IEuclidian.html +93 -92
- package/docs/interfaces/geometry_triangle.remarquableLines.html +150 -150
- package/docs/modules/Logicalset.html +69 -74
- package/docs/modules/Polynom.html +69 -74
- package/docs/modules/Vector-1.html +69 -74
- package/docs/modules/Vector.html +69 -74
- package/docs/modules/algebra_equation.html +75 -81
- package/docs/modules/algebra_linearSystem.html +65 -71
- package/docs/modules/algebra_monom.html +70 -76
- package/docs/modules/algebra_polynom.html +75 -81
- package/docs/modules/coefficients_fraction.html +70 -76
- package/docs/modules/geometry_circle.html +65 -71
- package/docs/modules/geometry_line.html +70 -76
- package/docs/modules/geometry_triangle.html +70 -76
- package/docs/modules/numeric.html +65 -71
- package/docs/modules/shutingyard.html +84 -90
- package/docs/types/algebra_monom.literalType.html +66 -70
- package/docs/types/algebra_polynom.PolynomParsingType.html +62 -66
- package/docs/types/coefficients_fraction.FractionParsingType.html +61 -65
- package/docs/types/shutingyard.Token.html +72 -76
- package/docs/types/shutingyard.tokenType.html +77 -81
- package/docs/variables/shutingyard.tokenConstant.html +70 -74
- package/esm/index.d.ts +38 -41
- package/esm/index.js +43 -46
- package/esm/index.js.map +1 -1
- package/esm/maths/algebra/equation.d.ts +119 -117
- package/esm/maths/algebra/equation.js +796 -785
- package/esm/maths/algebra/equation.js.map +1 -1
- package/esm/maths/algebra/linearSystem.d.ts +39 -38
- package/esm/maths/algebra/linearSystem.js +278 -262
- package/esm/maths/algebra/linearSystem.js.map +1 -1
- package/esm/maths/algebra/logicalset.d.ts +28 -28
- package/esm/maths/algebra/logicalset.js +157 -157
- package/esm/maths/algebra/monom.d.ts +206 -206
- package/esm/maths/algebra/monom.js +908 -908
- package/esm/maths/algebra/monom.js.map +1 -1
- package/esm/maths/algebra/polynom.d.ts +157 -157
- package/esm/maths/algebra/polynom.js +1277 -1277
- package/esm/maths/algebra/rational.d.ts +45 -45
- package/esm/maths/algebra/rational.js +183 -183
- package/esm/maths/algebra/study/rationalStudy.d.ts +28 -28
- package/esm/maths/algebra/study/rationalStudy.js +243 -243
- package/esm/maths/algebra/study.d.ts +143 -142
- package/esm/maths/algebra/study.js +378 -377
- package/esm/maths/algebra/study.js.map +1 -1
- package/esm/maths/coefficients/fraction.d.ts +90 -90
- package/esm/maths/coefficients/fraction.js +516 -516
- package/esm/maths/coefficients/fraction.js.map +1 -1
- package/esm/maths/coefficients/nthRoot.d.ts +23 -23
- package/esm/maths/coefficients/nthRoot.js +136 -136
- package/esm/maths/geometry/circle.d.ts +45 -45
- package/esm/maths/geometry/circle.js +323 -323
- package/esm/maths/geometry/line.d.ts +99 -99
- package/esm/maths/geometry/line.js +481 -481
- package/esm/maths/geometry/line.js.map +1 -1
- package/esm/maths/geometry/point.d.ts +34 -34
- package/esm/maths/geometry/point.js +166 -166
- package/esm/maths/geometry/point.js.map +1 -1
- package/esm/maths/geometry/triangle.d.ts +85 -85
- package/esm/maths/geometry/triangle.js +268 -268
- package/esm/maths/geometry/vector.d.ts +41 -41
- package/esm/maths/geometry/vector.js +197 -197
- package/esm/maths/geometry/vector.js.map +1 -1
- package/esm/maths/numeric.d.ts +28 -28
- package/esm/maths/numeric.js +180 -180
- package/esm/maths/numexp.d.ts +19 -0
- package/esm/maths/numexp.js +186 -0
- package/esm/maths/numexp.js.map +1 -0
- package/esm/maths/randomization/random.d.ts +23 -23
- package/esm/maths/randomization/random.js +78 -78
- package/esm/maths/randomization/random.js.map +1 -1
- package/esm/maths/randomization/randomCore.d.ts +7 -7
- package/esm/maths/randomization/randomCore.js +21 -21
- package/esm/maths/randomization/rndFraction.d.ts +12 -12
- package/esm/maths/randomization/rndFraction.js +43 -43
- package/esm/maths/randomization/rndGeometryLine.d.ts +12 -12
- package/esm/maths/randomization/rndGeometryLine.js +45 -45
- package/esm/maths/randomization/rndGeometryPoint.d.ts +12 -12
- package/esm/maths/randomization/rndGeometryPoint.js +60 -60
- package/esm/maths/randomization/rndHelpers.d.ts +23 -23
- package/esm/maths/randomization/rndHelpers.js +76 -76
- package/esm/maths/randomization/rndMonom.d.ts +12 -12
- package/esm/maths/randomization/rndMonom.js +52 -52
- package/esm/maths/randomization/rndPolynom.d.ts +13 -13
- package/esm/maths/randomization/rndPolynom.js +74 -74
- package/esm/maths/randomization/rndTypes.d.ts +34 -34
- package/esm/maths/randomization/rndTypes.js +2 -2
- package/esm/maths/shutingyard.d.ts +59 -59
- package/esm/maths/shutingyard.js +442 -442
- package/esm/maths/shutingyard.js.map +1 -1
- package/package.json +11 -11
- package/public/index.html +50 -81
- package/public/playground.html +7 -8
- package/src/index.ts +1 -4
- package/src/maths/algebra/equation.ts +16 -0
- package/src/maths/algebra/linearSystem.ts +20 -0
- package/src/maths/algebra/study.ts +12 -10
- package/src/maths/{expressions/numexp.ts → numexp.ts} +2 -2
- package/tests/algebra/equation.test.ts +19 -5
- package/tests/algebra/linear.test.ts +3 -11
- package/tests/algebra/polynom.test.ts +7 -8
- package/tests/algebra/rationnal.test.ts +1 -1
- package/tests/algebra/study.test.ts +2 -9
- package/tests/coefficients/fraction.test.ts +8 -8
- package/tests/custom.test.ts +33 -37
- package/tests/numeric.test.ts +1 -2
- package/tests/numexp.test.ts +13 -5
- package/tests/shutingyard.test.ts +3 -3
- package/webpack-production-min.config.js +1 -1
- package/webpack-production.config.js +1 -1
- package/webpack.config.js +1 -1
- package/dist/pi.js.map +0 -1
- package/dist/pi.min.js +0 -2
- package/dist/pi.min.js.map +0 -1
- package/docs/classes/expressions_numexp.NumExp.html +0 -236
- package/docs/classes/expressions_polynomexp.PolynomExpFactor.html +0 -317
- package/docs/classes/expressions_polynomexp.PolynomExpProduct.html +0 -285
- package/docs/modules/expressions_numexp.html +0 -71
- package/docs/modules/expressions_polynomexp.html +0 -73
- package/docs/modules.html +0 -76
- package/graph.svg +0 -1033
- package/src/maths/expressions/ExpressionTree.ts +0 -172
- package/src/maths/expressions/expression.ts +0 -286
- package/src/maths/expressions/expressionFactor.ts +0 -190
- package/src/maths/expressions/expressionMember.ts +0 -233
- package/src/maths/expressions/expressionOperators.ts +0 -49
- package/src/maths/expressions/expressionParser.ts +0 -295
- package/src/maths/expressions/factors/ExpFactor.ts +0 -39
- package/src/maths/expressions/factors/ExpFactorConstant.ts +0 -60
- package/src/maths/expressions/factors/ExpFactorExponential.ts +0 -26
- package/src/maths/expressions/factors/ExpFactorNumber.ts +0 -72
- package/src/maths/expressions/factors/ExpFactorPower.ts +0 -42
- package/src/maths/expressions/factors/ExpFactorTrigo.ts +0 -53
- package/src/maths/expressions/factors/ExpFactorVariable.ts +0 -45
- package/src/maths/expressions/internals.ts +0 -14
- package/src/maths/expressions/polynomexp.bkp.ts +0 -221
- package/src/maths/expressions/polynomexp.ts +0 -310
- package/tests/expressions/expressions.test.ts +0 -145
- package/tests/expressions/expressiontree.test.ts +0 -11
- package/tests/polynomexp.test.ts +0 -12
|
@@ -1,269 +1,269 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Triangle = void 0;
|
|
4
|
-
const point_1 = require("./point");
|
|
5
|
-
const fraction_1 = require("../coefficients/fraction");
|
|
6
|
-
const vector_1 = require("./vector");
|
|
7
|
-
const line_1 = require("./line");
|
|
8
|
-
const equation_1 = require("../algebra/equation");
|
|
9
|
-
class Triangle {
|
|
10
|
-
constructor(...values) {
|
|
11
|
-
// ------------------------------------------
|
|
12
|
-
// Creation / parsing functions
|
|
13
|
-
// ------------------------------------------
|
|
14
|
-
/**
|
|
15
|
-
* Parse values to a triangle. Supported formats:
|
|
16
|
-
* Point, Point, Point
|
|
17
|
-
* x1, y1, x2, y2, x3, y3
|
|
18
|
-
* TODO: Something else ?
|
|
19
|
-
* @param values
|
|
20
|
-
*/
|
|
21
|
-
this.parse = (...values) => {
|
|
22
|
-
if (values.length === 6) {
|
|
23
|
-
// Check if all values are number or fractions.
|
|
24
|
-
let v = values.map((x) => new fraction_1.Fraction(x));
|
|
25
|
-
return this.parse(new point_1.Point(v[0], v[1]), new point_1.Point(v[2], v[3]), new point_1.Point(v[4], v[5]));
|
|
26
|
-
}
|
|
27
|
-
else if (values.length === 3) {
|
|
28
|
-
// Possibilities:
|
|
29
|
-
// - Three points (or part of points, only dict for example, or array (TODO: Add the array syntax for point)
|
|
30
|
-
// - Three lines
|
|
31
|
-
// - Three lines as text.
|
|
32
|
-
if (values.filter((x) => typeof x === 'string').length === 3) {
|
|
33
|
-
return this.parse(...values.map((x) => new line_1.Line(x)));
|
|
34
|
-
}
|
|
35
|
-
else if (values.filter((x) => x instanceof line_1.Line).length === 3) {
|
|
36
|
-
// We have three lines
|
|
37
|
-
this._lines = {
|
|
38
|
-
'AB': values[0],
|
|
39
|
-
'BC': values[1],
|
|
40
|
-
'AC': values[2]
|
|
41
|
-
};
|
|
42
|
-
// Get the intersection points -> build the triangle using these intersection points.
|
|
43
|
-
let intersect = values[0].intersection(values[1]);
|
|
44
|
-
if (intersect.hasIntersection) {
|
|
45
|
-
this._B = intersect.point.clone();
|
|
46
|
-
}
|
|
47
|
-
else {
|
|
48
|
-
return this;
|
|
49
|
-
}
|
|
50
|
-
intersect = values[1].intersection(values[2]);
|
|
51
|
-
if (intersect.hasIntersection) {
|
|
52
|
-
this._C = intersect.point.clone();
|
|
53
|
-
}
|
|
54
|
-
else {
|
|
55
|
-
return this;
|
|
56
|
-
}
|
|
57
|
-
intersect = values[2].intersection(values[0]);
|
|
58
|
-
if (intersect.hasIntersection) {
|
|
59
|
-
this._A = intersect.point.clone();
|
|
60
|
-
}
|
|
61
|
-
else {
|
|
62
|
-
return this;
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
else {
|
|
66
|
-
// At least, one of the value is not a point.
|
|
67
|
-
if (values.filter((x) => (x instanceof point_1.Point)).length < 3) {
|
|
68
|
-
return this.parse(new point_1.Point(values[0]), new point_1.Point(values[1]), new point_1.Point(values[2]));
|
|
69
|
-
}
|
|
70
|
-
// We have three points.
|
|
71
|
-
this._A = values[0].clone();
|
|
72
|
-
this._B = values[1].clone();
|
|
73
|
-
this._C = values[2].clone();
|
|
74
|
-
this._lines = {
|
|
75
|
-
'AB': new line_1.Line(this._A, this._B),
|
|
76
|
-
'BC': new line_1.Line(this._B, this._C),
|
|
77
|
-
'AC': new line_1.Line(this._A, this._C)
|
|
78
|
-
};
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
else if (values.length === 1) {
|
|
82
|
-
if (values[0] instanceof Triangle) {
|
|
83
|
-
return values[0].clone();
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
this._updateTriangle();
|
|
87
|
-
return this;
|
|
88
|
-
};
|
|
89
|
-
/**
|
|
90
|
-
* Clone the Triangle class
|
|
91
|
-
*/
|
|
92
|
-
this.clone = () => {
|
|
93
|
-
this._A = this._A.clone();
|
|
94
|
-
this._B = this._B.clone();
|
|
95
|
-
this._C = this._C.clone();
|
|
96
|
-
this._lines = {
|
|
97
|
-
'AB': this._lines.AB.clone(),
|
|
98
|
-
'BC': this._lines.BC.clone(),
|
|
99
|
-
'AC': this._lines.AC.clone()
|
|
100
|
-
};
|
|
101
|
-
this._updateTriangle();
|
|
102
|
-
return this;
|
|
103
|
-
};
|
|
104
|
-
// ------------------------------------------
|
|
105
|
-
// Triangle operations and properties
|
|
106
|
-
// ------------------------------------------
|
|
107
|
-
/**
|
|
108
|
-
* Generate the Line object for the three segments of the triangle
|
|
109
|
-
*/
|
|
110
|
-
this._updateTriangle = () => {
|
|
111
|
-
this._middles = {
|
|
112
|
-
'AB': new point_1.Point().middleOf(this._A, this._B),
|
|
113
|
-
'AC': new point_1.Point().middleOf(this._A, this._C),
|
|
114
|
-
'BC': new point_1.Point().middleOf(this._B, this._C)
|
|
115
|
-
};
|
|
116
|
-
this._remarquables = this._calculateRemarquableLines();
|
|
117
|
-
};
|
|
118
|
-
/**
|
|
119
|
-
* Get the Point class for the given name
|
|
120
|
-
* @param ptName
|
|
121
|
-
*/
|
|
122
|
-
this.getPointByName = (ptName) => {
|
|
123
|
-
switch (ptName.toUpperCase()) {
|
|
124
|
-
case 'A':
|
|
125
|
-
return this._A;
|
|
126
|
-
case 'B':
|
|
127
|
-
return this._B;
|
|
128
|
-
case 'C':
|
|
129
|
-
return this._C;
|
|
130
|
-
}
|
|
131
|
-
// Something went wrong ! Return the first point
|
|
132
|
-
return this._A;
|
|
133
|
-
};
|
|
134
|
-
/**
|
|
135
|
-
* Get the vector for the segment given by name.
|
|
136
|
-
* @param ptName1
|
|
137
|
-
* @param ptName2
|
|
138
|
-
*/
|
|
139
|
-
this.getSegment = (ptName1, ptName2) => {
|
|
140
|
-
return new vector_1.Vector(this.getPointByName(ptName1), this.getPointByName(ptName2));
|
|
141
|
-
};
|
|
142
|
-
this._calculateRemarquableLines = () => {
|
|
143
|
-
let remarquables = {
|
|
144
|
-
'medians': {
|
|
145
|
-
'A': new line_1.Line(this._A, this._middles.BC),
|
|
146
|
-
'B': new line_1.Line(this._B, this._middles.AC),
|
|
147
|
-
'C': new line_1.Line(this._C, this._middles.AB),
|
|
148
|
-
'intersection': null
|
|
149
|
-
},
|
|
150
|
-
'mediators': {
|
|
151
|
-
'AB': new line_1.Line(this._middles.AB, new vector_1.Vector(this._A, this._B).normal()),
|
|
152
|
-
'AC': new line_1.Line(this._middles.AC, new vector_1.Vector(this._A, this._C).normal()),
|
|
153
|
-
'BC': new line_1.Line(this._middles.BC, new vector_1.Vector(this._B, this._C).normal()),
|
|
154
|
-
'intersection': null
|
|
155
|
-
},
|
|
156
|
-
'heights': {
|
|
157
|
-
'A': new line_1.Line(this._A, new vector_1.Vector(this._B, this._C).normal()),
|
|
158
|
-
'B': new line_1.Line(this._B, new vector_1.Vector(this._A, this._C).normal()),
|
|
159
|
-
'C': new line_1.Line(this._C, new vector_1.Vector(this._A, this._B).normal()),
|
|
160
|
-
'intersection': null
|
|
161
|
-
},
|
|
162
|
-
'bisectors': {
|
|
163
|
-
'A': this._calculateBisectors('A'),
|
|
164
|
-
'B': this._calculateBisectors('B'),
|
|
165
|
-
'C': this._calculateBisectors('C'),
|
|
166
|
-
'intersection': null
|
|
167
|
-
}
|
|
168
|
-
};
|
|
169
|
-
// As it's a triangle, we assume the lines are intersecting and aren't parallel or superposed.
|
|
170
|
-
remarquables.medians.intersection = remarquables.medians.A.intersection(remarquables.medians.B).point;
|
|
171
|
-
remarquables.mediators.intersection = remarquables.mediators.AB.intersection(remarquables.mediators.BC).point;
|
|
172
|
-
remarquables.heights.intersection = remarquables.heights.A.intersection(remarquables.heights.B).point;
|
|
173
|
-
remarquables.bisectors.intersection = remarquables.bisectors.A.intersection(remarquables.bisectors.B).point;
|
|
174
|
-
// Everything was calculated for the remarquable lines.
|
|
175
|
-
return remarquables;
|
|
176
|
-
};
|
|
177
|
-
this._calculateBisectors = (pt) => {
|
|
178
|
-
let tlines = this.lines, d1, d2;
|
|
179
|
-
if (pt === 'A') {
|
|
180
|
-
d1 = tlines.AB;
|
|
181
|
-
d2 = tlines.AC;
|
|
182
|
-
}
|
|
183
|
-
else if (pt === 'B') {
|
|
184
|
-
d1 = tlines.AB;
|
|
185
|
-
d2 = tlines.BC;
|
|
186
|
-
}
|
|
187
|
-
else if (pt === 'C') {
|
|
188
|
-
d1 = tlines.BC;
|
|
189
|
-
d2 = tlines.AC;
|
|
190
|
-
}
|
|
191
|
-
let b1 = new line_1.Line(new equation_1.Equation(d1.equation.left.clone().multiply(d2.n.simplify().norm), d2.equation.left.clone().multiply(d1.n.simplify().norm)).reorder(true).simplify()), b2 = new line_1.Line(new equation_1.Equation(d1.equation.left.clone().multiply(d2.n.simplify().norm), d2.equation.left.clone().multiply(d1.n.simplify().norm).opposed()).reorder(true).simplify());
|
|
192
|
-
// Must determine which bisectors is in the triangle
|
|
193
|
-
if (pt === 'A') {
|
|
194
|
-
return b1.hitSegment(this.B, this.C) ? b1 : b2;
|
|
195
|
-
}
|
|
196
|
-
if (pt === 'B') {
|
|
197
|
-
return b1.hitSegment(this.A, this.C) ? b1 : b2;
|
|
198
|
-
}
|
|
199
|
-
if (pt === 'C') {
|
|
200
|
-
return b1.hitSegment(this.B, this.A) ? b1 : b2;
|
|
201
|
-
}
|
|
202
|
-
// Default returns the first bisector
|
|
203
|
-
return b1;
|
|
204
|
-
};
|
|
205
|
-
if (values.length > 0) {
|
|
206
|
-
this.parse(...values);
|
|
207
|
-
}
|
|
208
|
-
return this;
|
|
209
|
-
}
|
|
210
|
-
// ------------------------------------------
|
|
211
|
-
// Getter and setters
|
|
212
|
-
// ------------------------------------------
|
|
213
|
-
get A() {
|
|
214
|
-
return this._A;
|
|
215
|
-
}
|
|
216
|
-
get B() {
|
|
217
|
-
return this._B;
|
|
218
|
-
}
|
|
219
|
-
get C() {
|
|
220
|
-
return this._C;
|
|
221
|
-
}
|
|
222
|
-
get AB() {
|
|
223
|
-
return this.getSegment('A', 'B');
|
|
224
|
-
}
|
|
225
|
-
get BA() {
|
|
226
|
-
return this.getSegment('B', 'A');
|
|
227
|
-
}
|
|
228
|
-
get BC() {
|
|
229
|
-
return this.getSegment('B', 'C');
|
|
230
|
-
}
|
|
231
|
-
get CB() {
|
|
232
|
-
return this.getSegment('C', 'B');
|
|
233
|
-
}
|
|
234
|
-
get AC() {
|
|
235
|
-
return this.getSegment('A', 'C');
|
|
236
|
-
}
|
|
237
|
-
get CA() {
|
|
238
|
-
return this.getSegment('C', 'A');
|
|
239
|
-
}
|
|
240
|
-
get isRectangle() {
|
|
241
|
-
if (this.AB.isNormalTo(this.BC)) {
|
|
242
|
-
return true;
|
|
243
|
-
}
|
|
244
|
-
if (this.AB.isNormalTo(this.AC)) {
|
|
245
|
-
return true;
|
|
246
|
-
}
|
|
247
|
-
if (this.BC.isNormalTo(this.AC)) {
|
|
248
|
-
return true;
|
|
249
|
-
}
|
|
250
|
-
return false;
|
|
251
|
-
}
|
|
252
|
-
get isEquilateral() {
|
|
253
|
-
return this.AB.normSquare.isEqual(this.BC.normSquare) &&
|
|
254
|
-
this.AB.normSquare.isEqual(this.AC.normSquare);
|
|
255
|
-
}
|
|
256
|
-
get isIsocele() {
|
|
257
|
-
return this.AB.normSquare.isEqual(this.BC.normSquare) ||
|
|
258
|
-
this.AB.normSquare.isEqual(this.AC.normSquare) ||
|
|
259
|
-
this.BC.normSquare.isEqual(this.AC.normSquare);
|
|
260
|
-
}
|
|
261
|
-
get lines() {
|
|
262
|
-
return this._lines;
|
|
263
|
-
}
|
|
264
|
-
get remarquables() {
|
|
265
|
-
return this._remarquables;
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
exports.Triangle = Triangle;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Triangle = void 0;
|
|
4
|
+
const point_1 = require("./point");
|
|
5
|
+
const fraction_1 = require("../coefficients/fraction");
|
|
6
|
+
const vector_1 = require("./vector");
|
|
7
|
+
const line_1 = require("./line");
|
|
8
|
+
const equation_1 = require("../algebra/equation");
|
|
9
|
+
class Triangle {
|
|
10
|
+
constructor(...values) {
|
|
11
|
+
// ------------------------------------------
|
|
12
|
+
// Creation / parsing functions
|
|
13
|
+
// ------------------------------------------
|
|
14
|
+
/**
|
|
15
|
+
* Parse values to a triangle. Supported formats:
|
|
16
|
+
* Point, Point, Point
|
|
17
|
+
* x1, y1, x2, y2, x3, y3
|
|
18
|
+
* TODO: Something else ?
|
|
19
|
+
* @param values
|
|
20
|
+
*/
|
|
21
|
+
this.parse = (...values) => {
|
|
22
|
+
if (values.length === 6) {
|
|
23
|
+
// Check if all values are number or fractions.
|
|
24
|
+
let v = values.map((x) => new fraction_1.Fraction(x));
|
|
25
|
+
return this.parse(new point_1.Point(v[0], v[1]), new point_1.Point(v[2], v[3]), new point_1.Point(v[4], v[5]));
|
|
26
|
+
}
|
|
27
|
+
else if (values.length === 3) {
|
|
28
|
+
// Possibilities:
|
|
29
|
+
// - Three points (or part of points, only dict for example, or array (TODO: Add the array syntax for point)
|
|
30
|
+
// - Three lines
|
|
31
|
+
// - Three lines as text.
|
|
32
|
+
if (values.filter((x) => typeof x === 'string').length === 3) {
|
|
33
|
+
return this.parse(...values.map((x) => new line_1.Line(x)));
|
|
34
|
+
}
|
|
35
|
+
else if (values.filter((x) => x instanceof line_1.Line).length === 3) {
|
|
36
|
+
// We have three lines
|
|
37
|
+
this._lines = {
|
|
38
|
+
'AB': values[0],
|
|
39
|
+
'BC': values[1],
|
|
40
|
+
'AC': values[2]
|
|
41
|
+
};
|
|
42
|
+
// Get the intersection points -> build the triangle using these intersection points.
|
|
43
|
+
let intersect = values[0].intersection(values[1]);
|
|
44
|
+
if (intersect.hasIntersection) {
|
|
45
|
+
this._B = intersect.point.clone();
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
return this;
|
|
49
|
+
}
|
|
50
|
+
intersect = values[1].intersection(values[2]);
|
|
51
|
+
if (intersect.hasIntersection) {
|
|
52
|
+
this._C = intersect.point.clone();
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
return this;
|
|
56
|
+
}
|
|
57
|
+
intersect = values[2].intersection(values[0]);
|
|
58
|
+
if (intersect.hasIntersection) {
|
|
59
|
+
this._A = intersect.point.clone();
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
return this;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
// At least, one of the value is not a point.
|
|
67
|
+
if (values.filter((x) => (x instanceof point_1.Point)).length < 3) {
|
|
68
|
+
return this.parse(new point_1.Point(values[0]), new point_1.Point(values[1]), new point_1.Point(values[2]));
|
|
69
|
+
}
|
|
70
|
+
// We have three points.
|
|
71
|
+
this._A = values[0].clone();
|
|
72
|
+
this._B = values[1].clone();
|
|
73
|
+
this._C = values[2].clone();
|
|
74
|
+
this._lines = {
|
|
75
|
+
'AB': new line_1.Line(this._A, this._B),
|
|
76
|
+
'BC': new line_1.Line(this._B, this._C),
|
|
77
|
+
'AC': new line_1.Line(this._A, this._C)
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
else if (values.length === 1) {
|
|
82
|
+
if (values[0] instanceof Triangle) {
|
|
83
|
+
return values[0].clone();
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
this._updateTriangle();
|
|
87
|
+
return this;
|
|
88
|
+
};
|
|
89
|
+
/**
|
|
90
|
+
* Clone the Triangle class
|
|
91
|
+
*/
|
|
92
|
+
this.clone = () => {
|
|
93
|
+
this._A = this._A.clone();
|
|
94
|
+
this._B = this._B.clone();
|
|
95
|
+
this._C = this._C.clone();
|
|
96
|
+
this._lines = {
|
|
97
|
+
'AB': this._lines.AB.clone(),
|
|
98
|
+
'BC': this._lines.BC.clone(),
|
|
99
|
+
'AC': this._lines.AC.clone()
|
|
100
|
+
};
|
|
101
|
+
this._updateTriangle();
|
|
102
|
+
return this;
|
|
103
|
+
};
|
|
104
|
+
// ------------------------------------------
|
|
105
|
+
// Triangle operations and properties
|
|
106
|
+
// ------------------------------------------
|
|
107
|
+
/**
|
|
108
|
+
* Generate the Line object for the three segments of the triangle
|
|
109
|
+
*/
|
|
110
|
+
this._updateTriangle = () => {
|
|
111
|
+
this._middles = {
|
|
112
|
+
'AB': new point_1.Point().middleOf(this._A, this._B),
|
|
113
|
+
'AC': new point_1.Point().middleOf(this._A, this._C),
|
|
114
|
+
'BC': new point_1.Point().middleOf(this._B, this._C)
|
|
115
|
+
};
|
|
116
|
+
this._remarquables = this._calculateRemarquableLines();
|
|
117
|
+
};
|
|
118
|
+
/**
|
|
119
|
+
* Get the Point class for the given name
|
|
120
|
+
* @param ptName
|
|
121
|
+
*/
|
|
122
|
+
this.getPointByName = (ptName) => {
|
|
123
|
+
switch (ptName.toUpperCase()) {
|
|
124
|
+
case 'A':
|
|
125
|
+
return this._A;
|
|
126
|
+
case 'B':
|
|
127
|
+
return this._B;
|
|
128
|
+
case 'C':
|
|
129
|
+
return this._C;
|
|
130
|
+
}
|
|
131
|
+
// Something went wrong ! Return the first point
|
|
132
|
+
return this._A;
|
|
133
|
+
};
|
|
134
|
+
/**
|
|
135
|
+
* Get the vector for the segment given by name.
|
|
136
|
+
* @param ptName1
|
|
137
|
+
* @param ptName2
|
|
138
|
+
*/
|
|
139
|
+
this.getSegment = (ptName1, ptName2) => {
|
|
140
|
+
return new vector_1.Vector(this.getPointByName(ptName1), this.getPointByName(ptName2));
|
|
141
|
+
};
|
|
142
|
+
this._calculateRemarquableLines = () => {
|
|
143
|
+
let remarquables = {
|
|
144
|
+
'medians': {
|
|
145
|
+
'A': new line_1.Line(this._A, this._middles.BC),
|
|
146
|
+
'B': new line_1.Line(this._B, this._middles.AC),
|
|
147
|
+
'C': new line_1.Line(this._C, this._middles.AB),
|
|
148
|
+
'intersection': null
|
|
149
|
+
},
|
|
150
|
+
'mediators': {
|
|
151
|
+
'AB': new line_1.Line(this._middles.AB, new vector_1.Vector(this._A, this._B).normal()),
|
|
152
|
+
'AC': new line_1.Line(this._middles.AC, new vector_1.Vector(this._A, this._C).normal()),
|
|
153
|
+
'BC': new line_1.Line(this._middles.BC, new vector_1.Vector(this._B, this._C).normal()),
|
|
154
|
+
'intersection': null
|
|
155
|
+
},
|
|
156
|
+
'heights': {
|
|
157
|
+
'A': new line_1.Line(this._A, new vector_1.Vector(this._B, this._C).normal()),
|
|
158
|
+
'B': new line_1.Line(this._B, new vector_1.Vector(this._A, this._C).normal()),
|
|
159
|
+
'C': new line_1.Line(this._C, new vector_1.Vector(this._A, this._B).normal()),
|
|
160
|
+
'intersection': null
|
|
161
|
+
},
|
|
162
|
+
'bisectors': {
|
|
163
|
+
'A': this._calculateBisectors('A'),
|
|
164
|
+
'B': this._calculateBisectors('B'),
|
|
165
|
+
'C': this._calculateBisectors('C'),
|
|
166
|
+
'intersection': null
|
|
167
|
+
}
|
|
168
|
+
};
|
|
169
|
+
// As it's a triangle, we assume the lines are intersecting and aren't parallel or superposed.
|
|
170
|
+
remarquables.medians.intersection = remarquables.medians.A.intersection(remarquables.medians.B).point;
|
|
171
|
+
remarquables.mediators.intersection = remarquables.mediators.AB.intersection(remarquables.mediators.BC).point;
|
|
172
|
+
remarquables.heights.intersection = remarquables.heights.A.intersection(remarquables.heights.B).point;
|
|
173
|
+
remarquables.bisectors.intersection = remarquables.bisectors.A.intersection(remarquables.bisectors.B).point;
|
|
174
|
+
// Everything was calculated for the remarquable lines.
|
|
175
|
+
return remarquables;
|
|
176
|
+
};
|
|
177
|
+
this._calculateBisectors = (pt) => {
|
|
178
|
+
let tlines = this.lines, d1, d2;
|
|
179
|
+
if (pt === 'A') {
|
|
180
|
+
d1 = tlines.AB;
|
|
181
|
+
d2 = tlines.AC;
|
|
182
|
+
}
|
|
183
|
+
else if (pt === 'B') {
|
|
184
|
+
d1 = tlines.AB;
|
|
185
|
+
d2 = tlines.BC;
|
|
186
|
+
}
|
|
187
|
+
else if (pt === 'C') {
|
|
188
|
+
d1 = tlines.BC;
|
|
189
|
+
d2 = tlines.AC;
|
|
190
|
+
}
|
|
191
|
+
let b1 = new line_1.Line(new equation_1.Equation(d1.equation.left.clone().multiply(d2.n.simplify().norm), d2.equation.left.clone().multiply(d1.n.simplify().norm)).reorder(true).simplify()), b2 = new line_1.Line(new equation_1.Equation(d1.equation.left.clone().multiply(d2.n.simplify().norm), d2.equation.left.clone().multiply(d1.n.simplify().norm).opposed()).reorder(true).simplify());
|
|
192
|
+
// Must determine which bisectors is in the triangle
|
|
193
|
+
if (pt === 'A') {
|
|
194
|
+
return b1.hitSegment(this.B, this.C) ? b1 : b2;
|
|
195
|
+
}
|
|
196
|
+
if (pt === 'B') {
|
|
197
|
+
return b1.hitSegment(this.A, this.C) ? b1 : b2;
|
|
198
|
+
}
|
|
199
|
+
if (pt === 'C') {
|
|
200
|
+
return b1.hitSegment(this.B, this.A) ? b1 : b2;
|
|
201
|
+
}
|
|
202
|
+
// Default returns the first bisector
|
|
203
|
+
return b1;
|
|
204
|
+
};
|
|
205
|
+
if (values.length > 0) {
|
|
206
|
+
this.parse(...values);
|
|
207
|
+
}
|
|
208
|
+
return this;
|
|
209
|
+
}
|
|
210
|
+
// ------------------------------------------
|
|
211
|
+
// Getter and setters
|
|
212
|
+
// ------------------------------------------
|
|
213
|
+
get A() {
|
|
214
|
+
return this._A;
|
|
215
|
+
}
|
|
216
|
+
get B() {
|
|
217
|
+
return this._B;
|
|
218
|
+
}
|
|
219
|
+
get C() {
|
|
220
|
+
return this._C;
|
|
221
|
+
}
|
|
222
|
+
get AB() {
|
|
223
|
+
return this.getSegment('A', 'B');
|
|
224
|
+
}
|
|
225
|
+
get BA() {
|
|
226
|
+
return this.getSegment('B', 'A');
|
|
227
|
+
}
|
|
228
|
+
get BC() {
|
|
229
|
+
return this.getSegment('B', 'C');
|
|
230
|
+
}
|
|
231
|
+
get CB() {
|
|
232
|
+
return this.getSegment('C', 'B');
|
|
233
|
+
}
|
|
234
|
+
get AC() {
|
|
235
|
+
return this.getSegment('A', 'C');
|
|
236
|
+
}
|
|
237
|
+
get CA() {
|
|
238
|
+
return this.getSegment('C', 'A');
|
|
239
|
+
}
|
|
240
|
+
get isRectangle() {
|
|
241
|
+
if (this.AB.isNormalTo(this.BC)) {
|
|
242
|
+
return true;
|
|
243
|
+
}
|
|
244
|
+
if (this.AB.isNormalTo(this.AC)) {
|
|
245
|
+
return true;
|
|
246
|
+
}
|
|
247
|
+
if (this.BC.isNormalTo(this.AC)) {
|
|
248
|
+
return true;
|
|
249
|
+
}
|
|
250
|
+
return false;
|
|
251
|
+
}
|
|
252
|
+
get isEquilateral() {
|
|
253
|
+
return this.AB.normSquare.isEqual(this.BC.normSquare) &&
|
|
254
|
+
this.AB.normSquare.isEqual(this.AC.normSquare);
|
|
255
|
+
}
|
|
256
|
+
get isIsocele() {
|
|
257
|
+
return this.AB.normSquare.isEqual(this.BC.normSquare) ||
|
|
258
|
+
this.AB.normSquare.isEqual(this.AC.normSquare) ||
|
|
259
|
+
this.BC.normSquare.isEqual(this.AC.normSquare);
|
|
260
|
+
}
|
|
261
|
+
get lines() {
|
|
262
|
+
return this._lines;
|
|
263
|
+
}
|
|
264
|
+
get remarquables() {
|
|
265
|
+
return this._remarquables;
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
exports.Triangle = Triangle;
|
|
269
269
|
//# sourceMappingURL=triangle.js.map
|
|
@@ -1,41 +1,41 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Vector module contains everything necessary to handle 2d or 3d vectors.
|
|
3
|
-
* @module Vector
|
|
4
|
-
*/
|
|
5
|
-
import { Fraction } from "../coefficients/fraction";
|
|
6
|
-
import { Point } from "./point";
|
|
7
|
-
export declare class Vector {
|
|
8
|
-
private _x;
|
|
9
|
-
private _y;
|
|
10
|
-
constructor(...values: unknown[]);
|
|
11
|
-
get x(): Fraction;
|
|
12
|
-
set x(value: Fraction | number | string);
|
|
13
|
-
get y(): Fraction;
|
|
14
|
-
set y(value: Fraction | number | string);
|
|
15
|
-
get normSquare(): Fraction;
|
|
16
|
-
get norm(): number;
|
|
17
|
-
get tex(): string;
|
|
18
|
-
get asPoint(): Point;
|
|
19
|
-
parse: (...values: any) => Vector;
|
|
20
|
-
clone: () => Vector;
|
|
21
|
-
reset: () => Vector;
|
|
22
|
-
zero: () => Vector;
|
|
23
|
-
one: () => Vector;
|
|
24
|
-
private _parseString;
|
|
25
|
-
opposed: () => Vector;
|
|
26
|
-
add: (V: Vector) => Vector;
|
|
27
|
-
subtract: (V: Vector) => Vector;
|
|
28
|
-
scalarProductWithVector: (V: Vector) => Fraction;
|
|
29
|
-
determinantWithVector: (V: Vector) => Fraction;
|
|
30
|
-
static scalarProduct: (v1: Vector, v2: Vector) => Fraction;
|
|
31
|
-
static determinant: (v1: Vector, v2: Vector) => Fraction;
|
|
32
|
-
normal: () => Vector;
|
|
33
|
-
isColinearTo: (v: Vector) => boolean;
|
|
34
|
-
isNormalTo: (v: Vector) => boolean;
|
|
35
|
-
get isNull(): boolean;
|
|
36
|
-
multiplyByScalar: (k: any) => Vector;
|
|
37
|
-
divideByScalar: (k: any) => Vector;
|
|
38
|
-
simplify: () => Vector;
|
|
39
|
-
simplifyDirection: () => Vector;
|
|
40
|
-
angleWith: (V: Vector, sharp?: Boolean, radian?: Boolean) => number;
|
|
41
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* Vector module contains everything necessary to handle 2d or 3d vectors.
|
|
3
|
+
* @module Vector
|
|
4
|
+
*/
|
|
5
|
+
import { Fraction } from "../coefficients/fraction";
|
|
6
|
+
import { Point } from "./point";
|
|
7
|
+
export declare class Vector {
|
|
8
|
+
private _x;
|
|
9
|
+
private _y;
|
|
10
|
+
constructor(...values: unknown[]);
|
|
11
|
+
get x(): Fraction;
|
|
12
|
+
set x(value: Fraction | number | string);
|
|
13
|
+
get y(): Fraction;
|
|
14
|
+
set y(value: Fraction | number | string);
|
|
15
|
+
get normSquare(): Fraction;
|
|
16
|
+
get norm(): number;
|
|
17
|
+
get tex(): string;
|
|
18
|
+
get asPoint(): Point;
|
|
19
|
+
parse: (...values: any) => Vector;
|
|
20
|
+
clone: () => Vector;
|
|
21
|
+
reset: () => Vector;
|
|
22
|
+
zero: () => Vector;
|
|
23
|
+
one: () => Vector;
|
|
24
|
+
private _parseString;
|
|
25
|
+
opposed: () => Vector;
|
|
26
|
+
add: (V: Vector) => Vector;
|
|
27
|
+
subtract: (V: Vector) => Vector;
|
|
28
|
+
scalarProductWithVector: (V: Vector) => Fraction;
|
|
29
|
+
determinantWithVector: (V: Vector) => Fraction;
|
|
30
|
+
static scalarProduct: (v1: Vector, v2: Vector) => Fraction;
|
|
31
|
+
static determinant: (v1: Vector, v2: Vector) => Fraction;
|
|
32
|
+
normal: () => Vector;
|
|
33
|
+
isColinearTo: (v: Vector) => boolean;
|
|
34
|
+
isNormalTo: (v: Vector) => boolean;
|
|
35
|
+
get isNull(): boolean;
|
|
36
|
+
multiplyByScalar: (k: any) => Vector;
|
|
37
|
+
divideByScalar: (k: any) => Vector;
|
|
38
|
+
simplify: () => Vector;
|
|
39
|
+
simplifyDirection: () => Vector;
|
|
40
|
+
angleWith: (V: Vector, sharp?: Boolean, radian?: Boolean) => number;
|
|
41
|
+
}
|