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.
Files changed (175) hide show
  1. package/.idea/PI.iml +7 -1
  2. package/.idea/shelf/Uncommitted_changes_before_Update_at_24_07_2023_15_31_[Default_Changelist]/shelved.patch +90 -0
  3. package/.idea/shelf/Uncommitted_changes_before_Update_at_24_07_2023_15_31_[Default_Changelist]1/shelved.patch +107 -0
  4. package/.idea/shelf/Uncommitted_changes_before_Update_at_24_07_2023_15_31__Default_Changelist_.xml +4 -0
  5. package/.idea/shelf/Uncommitted_changes_before_Update_at_24_07_2023_15_31__Default_Changelist_1.xml +4 -0
  6. package/LICENSE.md +1 -1
  7. package/dev/pimath.js +7929 -0
  8. package/dev/pimath.js.map +1 -0
  9. package/dist/{pi.js → pimath.js} +7613 -7840
  10. package/dist/pimath.js.map +1 -0
  11. package/dist/pimath.min.js +2 -0
  12. package/dist/pimath.min.js.map +1 -0
  13. package/docs/assets/main.js +58 -58
  14. package/docs/assets/search.js +1 -1
  15. package/docs/assets/style.css +1367 -1280
  16. package/docs/classes/Logicalset.Logicalset.html +221 -212
  17. package/docs/classes/Polynom.Rational.html +391 -388
  18. package/docs/classes/Vector-1.Vector.html +494 -448
  19. package/docs/classes/Vector.Point.html +341 -342
  20. package/docs/classes/algebra_equation.Equation.html +796 -753
  21. package/docs/classes/algebra_linearSystem.LinearSystem.html +408 -397
  22. package/docs/classes/algebra_monom.Monom.html +967 -910
  23. package/docs/classes/algebra_polynom.Polynom.html +1281 -1260
  24. package/docs/classes/coefficients_fraction.Fraction.html +939 -931
  25. package/docs/classes/geometry_circle.Circle.html +476 -476
  26. package/docs/classes/geometry_line.Line.html +779 -719
  27. package/docs/classes/geometry_triangle.Triangle.html +429 -420
  28. package/docs/classes/numeric.Numeric.html +269 -263
  29. package/docs/classes/shutingyard.Shutingyard.html +259 -248
  30. package/docs/enums/algebra_equation.PARTICULAR_SOLUTION.html +89 -88
  31. package/docs/enums/geometry_line.LinePropriety.html +102 -102
  32. package/docs/enums/shutingyard.ShutingyardMode.html +106 -102
  33. package/docs/enums/shutingyard.ShutingyardType.html +120 -116
  34. package/docs/index.html +63 -65
  35. package/docs/interfaces/algebra_equation.ISolution.html +111 -109
  36. package/docs/interfaces/algebra_polynom.IEuclidian.html +93 -92
  37. package/docs/interfaces/geometry_triangle.remarquableLines.html +150 -150
  38. package/docs/modules/Logicalset.html +69 -74
  39. package/docs/modules/Polynom.html +69 -74
  40. package/docs/modules/Vector-1.html +69 -74
  41. package/docs/modules/Vector.html +69 -74
  42. package/docs/modules/algebra_equation.html +75 -81
  43. package/docs/modules/algebra_linearSystem.html +65 -71
  44. package/docs/modules/algebra_monom.html +70 -76
  45. package/docs/modules/algebra_polynom.html +75 -81
  46. package/docs/modules/coefficients_fraction.html +70 -76
  47. package/docs/modules/geometry_circle.html +65 -71
  48. package/docs/modules/geometry_line.html +70 -76
  49. package/docs/modules/geometry_triangle.html +70 -76
  50. package/docs/modules/numeric.html +65 -71
  51. package/docs/modules/shutingyard.html +84 -90
  52. package/docs/types/algebra_monom.literalType.html +66 -70
  53. package/docs/types/algebra_polynom.PolynomParsingType.html +62 -66
  54. package/docs/types/coefficients_fraction.FractionParsingType.html +61 -65
  55. package/docs/types/shutingyard.Token.html +72 -76
  56. package/docs/types/shutingyard.tokenType.html +77 -81
  57. package/docs/variables/shutingyard.tokenConstant.html +70 -74
  58. package/esm/index.d.ts +38 -41
  59. package/esm/index.js +43 -46
  60. package/esm/index.js.map +1 -1
  61. package/esm/maths/algebra/equation.d.ts +119 -117
  62. package/esm/maths/algebra/equation.js +796 -785
  63. package/esm/maths/algebra/equation.js.map +1 -1
  64. package/esm/maths/algebra/linearSystem.d.ts +39 -38
  65. package/esm/maths/algebra/linearSystem.js +278 -262
  66. package/esm/maths/algebra/linearSystem.js.map +1 -1
  67. package/esm/maths/algebra/logicalset.d.ts +28 -28
  68. package/esm/maths/algebra/logicalset.js +157 -157
  69. package/esm/maths/algebra/monom.d.ts +206 -206
  70. package/esm/maths/algebra/monom.js +908 -908
  71. package/esm/maths/algebra/monom.js.map +1 -1
  72. package/esm/maths/algebra/polynom.d.ts +157 -157
  73. package/esm/maths/algebra/polynom.js +1277 -1277
  74. package/esm/maths/algebra/rational.d.ts +45 -45
  75. package/esm/maths/algebra/rational.js +183 -183
  76. package/esm/maths/algebra/study/rationalStudy.d.ts +28 -28
  77. package/esm/maths/algebra/study/rationalStudy.js +243 -243
  78. package/esm/maths/algebra/study.d.ts +143 -142
  79. package/esm/maths/algebra/study.js +378 -377
  80. package/esm/maths/algebra/study.js.map +1 -1
  81. package/esm/maths/coefficients/fraction.d.ts +90 -90
  82. package/esm/maths/coefficients/fraction.js +516 -516
  83. package/esm/maths/coefficients/fraction.js.map +1 -1
  84. package/esm/maths/coefficients/nthRoot.d.ts +23 -23
  85. package/esm/maths/coefficients/nthRoot.js +136 -136
  86. package/esm/maths/geometry/circle.d.ts +45 -45
  87. package/esm/maths/geometry/circle.js +323 -323
  88. package/esm/maths/geometry/line.d.ts +99 -99
  89. package/esm/maths/geometry/line.js +481 -481
  90. package/esm/maths/geometry/line.js.map +1 -1
  91. package/esm/maths/geometry/point.d.ts +34 -34
  92. package/esm/maths/geometry/point.js +166 -166
  93. package/esm/maths/geometry/point.js.map +1 -1
  94. package/esm/maths/geometry/triangle.d.ts +85 -85
  95. package/esm/maths/geometry/triangle.js +268 -268
  96. package/esm/maths/geometry/vector.d.ts +41 -41
  97. package/esm/maths/geometry/vector.js +197 -197
  98. package/esm/maths/geometry/vector.js.map +1 -1
  99. package/esm/maths/numeric.d.ts +28 -28
  100. package/esm/maths/numeric.js +180 -180
  101. package/esm/maths/numexp.d.ts +19 -0
  102. package/esm/maths/numexp.js +186 -0
  103. package/esm/maths/numexp.js.map +1 -0
  104. package/esm/maths/randomization/random.d.ts +23 -23
  105. package/esm/maths/randomization/random.js +78 -78
  106. package/esm/maths/randomization/random.js.map +1 -1
  107. package/esm/maths/randomization/randomCore.d.ts +7 -7
  108. package/esm/maths/randomization/randomCore.js +21 -21
  109. package/esm/maths/randomization/rndFraction.d.ts +12 -12
  110. package/esm/maths/randomization/rndFraction.js +43 -43
  111. package/esm/maths/randomization/rndGeometryLine.d.ts +12 -12
  112. package/esm/maths/randomization/rndGeometryLine.js +45 -45
  113. package/esm/maths/randomization/rndGeometryPoint.d.ts +12 -12
  114. package/esm/maths/randomization/rndGeometryPoint.js +60 -60
  115. package/esm/maths/randomization/rndHelpers.d.ts +23 -23
  116. package/esm/maths/randomization/rndHelpers.js +76 -76
  117. package/esm/maths/randomization/rndMonom.d.ts +12 -12
  118. package/esm/maths/randomization/rndMonom.js +52 -52
  119. package/esm/maths/randomization/rndPolynom.d.ts +13 -13
  120. package/esm/maths/randomization/rndPolynom.js +74 -74
  121. package/esm/maths/randomization/rndTypes.d.ts +34 -34
  122. package/esm/maths/randomization/rndTypes.js +2 -2
  123. package/esm/maths/shutingyard.d.ts +59 -59
  124. package/esm/maths/shutingyard.js +442 -442
  125. package/esm/maths/shutingyard.js.map +1 -1
  126. package/package.json +11 -11
  127. package/public/index.html +50 -81
  128. package/public/playground.html +7 -8
  129. package/src/index.ts +1 -4
  130. package/src/maths/algebra/equation.ts +16 -0
  131. package/src/maths/algebra/linearSystem.ts +20 -0
  132. package/src/maths/algebra/study.ts +12 -10
  133. package/src/maths/{expressions/numexp.ts → numexp.ts} +2 -2
  134. package/tests/algebra/equation.test.ts +19 -5
  135. package/tests/algebra/linear.test.ts +3 -11
  136. package/tests/algebra/polynom.test.ts +7 -8
  137. package/tests/algebra/rationnal.test.ts +1 -1
  138. package/tests/algebra/study.test.ts +2 -9
  139. package/tests/coefficients/fraction.test.ts +8 -8
  140. package/tests/custom.test.ts +33 -37
  141. package/tests/numeric.test.ts +1 -2
  142. package/tests/numexp.test.ts +13 -5
  143. package/tests/shutingyard.test.ts +3 -3
  144. package/webpack-production-min.config.js +1 -1
  145. package/webpack-production.config.js +1 -1
  146. package/webpack.config.js +1 -1
  147. package/dist/pi.js.map +0 -1
  148. package/dist/pi.min.js +0 -2
  149. package/dist/pi.min.js.map +0 -1
  150. package/docs/classes/expressions_numexp.NumExp.html +0 -236
  151. package/docs/classes/expressions_polynomexp.PolynomExpFactor.html +0 -317
  152. package/docs/classes/expressions_polynomexp.PolynomExpProduct.html +0 -285
  153. package/docs/modules/expressions_numexp.html +0 -71
  154. package/docs/modules/expressions_polynomexp.html +0 -73
  155. package/docs/modules.html +0 -76
  156. package/graph.svg +0 -1033
  157. package/src/maths/expressions/ExpressionTree.ts +0 -172
  158. package/src/maths/expressions/expression.ts +0 -286
  159. package/src/maths/expressions/expressionFactor.ts +0 -190
  160. package/src/maths/expressions/expressionMember.ts +0 -233
  161. package/src/maths/expressions/expressionOperators.ts +0 -49
  162. package/src/maths/expressions/expressionParser.ts +0 -295
  163. package/src/maths/expressions/factors/ExpFactor.ts +0 -39
  164. package/src/maths/expressions/factors/ExpFactorConstant.ts +0 -60
  165. package/src/maths/expressions/factors/ExpFactorExponential.ts +0 -26
  166. package/src/maths/expressions/factors/ExpFactorNumber.ts +0 -72
  167. package/src/maths/expressions/factors/ExpFactorPower.ts +0 -42
  168. package/src/maths/expressions/factors/ExpFactorTrigo.ts +0 -53
  169. package/src/maths/expressions/factors/ExpFactorVariable.ts +0 -45
  170. package/src/maths/expressions/internals.ts +0 -14
  171. package/src/maths/expressions/polynomexp.bkp.ts +0 -221
  172. package/src/maths/expressions/polynomexp.ts +0 -310
  173. package/tests/expressions/expressions.test.ts +0 -145
  174. package/tests/expressions/expressiontree.test.ts +0 -11
  175. 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
+ }