pimath 0.0.126 → 0.0.128

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 (121) hide show
  1. package/.idea/jsLibraryMappings.xml +6 -0
  2. package/{public/index.html → dist/demo/exercises.html} +2 -2
  3. package/dist/demo/matrices.html +39 -0
  4. package/dist/demo/playground.html +20 -0
  5. package/dist/demo.css +3 -0
  6. package/dist/pimath.js +4239 -7819
  7. package/dist/pimath.umd.cjs +15 -0
  8. package/index.html +15 -0
  9. package/package.json +16 -8
  10. package/public/demo/exercises.html +283 -0
  11. package/public/demo/matrices.html +39 -0
  12. package/public/demo/playground.html +20 -0
  13. package/src/demo/exercises.ts +0 -0
  14. package/src/demo/matrices.ts +61 -0
  15. package/src/demo/playground.ts +153 -0
  16. package/src/{index.ts → main.ts} +1 -1
  17. package/src/maths/algebra/polynom.ts +9 -16
  18. package/src/maths/algebra/rational.ts +8 -4
  19. package/src/maths/geometry/line.ts +22 -25
  20. package/src/maths/geometry/point.ts +43 -29
  21. package/src/maths/randomization/random.ts +7 -0
  22. package/src/maths/randomization/rndGeometryCircle.ts +50 -0
  23. package/src/maths/randomization/rndTypes.ts +10 -4
  24. package/tests/algebra/polynom.test.ts +10 -0
  25. package/tests/geometry/circle.test.ts +222 -1
  26. package/tests/numeric.test.ts +19 -3
  27. package/tsconfig.json +15 -4
  28. package/vite.config.js +23 -0
  29. package/webpack-production.config.js +22 -22
  30. package/webpack.config.js +22 -22
  31. package/dev/pimath.js +0 -7945
  32. package/dev/pimath.js.map +0 -1
  33. package/dist/pimath.js.map +0 -1
  34. package/dist/pimath.min.js +0 -2
  35. package/dist/pimath.min.js.map +0 -1
  36. package/esm/index.d.ts +0 -38
  37. package/esm/index.js +0 -44
  38. package/esm/index.js.map +0 -1
  39. package/esm/maths/algebra/equation.d.ts +0 -119
  40. package/esm/maths/algebra/equation.js +0 -797
  41. package/esm/maths/algebra/equation.js.map +0 -1
  42. package/esm/maths/algebra/linearSystem.d.ts +0 -39
  43. package/esm/maths/algebra/linearSystem.js +0 -279
  44. package/esm/maths/algebra/linearSystem.js.map +0 -1
  45. package/esm/maths/algebra/logicalset.d.ts +0 -28
  46. package/esm/maths/algebra/logicalset.js +0 -158
  47. package/esm/maths/algebra/logicalset.js.map +0 -1
  48. package/esm/maths/algebra/monom.d.ts +0 -206
  49. package/esm/maths/algebra/monom.js +0 -909
  50. package/esm/maths/algebra/monom.js.map +0 -1
  51. package/esm/maths/algebra/polynom.d.ts +0 -157
  52. package/esm/maths/algebra/polynom.js +0 -1305
  53. package/esm/maths/algebra/polynom.js.map +0 -1
  54. package/esm/maths/algebra/rational.d.ts +0 -46
  55. package/esm/maths/algebra/rational.js +0 -195
  56. package/esm/maths/algebra/rational.js.map +0 -1
  57. package/esm/maths/algebra/study/rationalStudy.d.ts +0 -28
  58. package/esm/maths/algebra/study/rationalStudy.js +0 -244
  59. package/esm/maths/algebra/study/rationalStudy.js.map +0 -1
  60. package/esm/maths/algebra/study.d.ts +0 -143
  61. package/esm/maths/algebra/study.js +0 -380
  62. package/esm/maths/algebra/study.js.map +0 -1
  63. package/esm/maths/coefficients/fraction.d.ts +0 -90
  64. package/esm/maths/coefficients/fraction.js +0 -517
  65. package/esm/maths/coefficients/fraction.js.map +0 -1
  66. package/esm/maths/coefficients/nthRoot.d.ts +0 -23
  67. package/esm/maths/coefficients/nthRoot.js +0 -137
  68. package/esm/maths/coefficients/nthRoot.js.map +0 -1
  69. package/esm/maths/geometry/circle.d.ts +0 -45
  70. package/esm/maths/geometry/circle.js +0 -324
  71. package/esm/maths/geometry/circle.js.map +0 -1
  72. package/esm/maths/geometry/line.d.ts +0 -99
  73. package/esm/maths/geometry/line.js +0 -485
  74. package/esm/maths/geometry/line.js.map +0 -1
  75. package/esm/maths/geometry/point.d.ts +0 -34
  76. package/esm/maths/geometry/point.js +0 -167
  77. package/esm/maths/geometry/point.js.map +0 -1
  78. package/esm/maths/geometry/triangle.d.ts +0 -91
  79. package/esm/maths/geometry/triangle.js +0 -276
  80. package/esm/maths/geometry/triangle.js.map +0 -1
  81. package/esm/maths/geometry/vector.d.ts +0 -41
  82. package/esm/maths/geometry/vector.js +0 -198
  83. package/esm/maths/geometry/vector.js.map +0 -1
  84. package/esm/maths/numeric.d.ts +0 -28
  85. package/esm/maths/numeric.js +0 -136
  86. package/esm/maths/numeric.js.map +0 -1
  87. package/esm/maths/numexp.d.ts +0 -19
  88. package/esm/maths/numexp.js +0 -186
  89. package/esm/maths/numexp.js.map +0 -1
  90. package/esm/maths/randomization/random.d.ts +0 -23
  91. package/esm/maths/randomization/random.js +0 -79
  92. package/esm/maths/randomization/random.js.map +0 -1
  93. package/esm/maths/randomization/randomCore.d.ts +0 -7
  94. package/esm/maths/randomization/randomCore.js +0 -22
  95. package/esm/maths/randomization/randomCore.js.map +0 -1
  96. package/esm/maths/randomization/rndFraction.d.ts +0 -12
  97. package/esm/maths/randomization/rndFraction.js +0 -44
  98. package/esm/maths/randomization/rndFraction.js.map +0 -1
  99. package/esm/maths/randomization/rndGeometryLine.d.ts +0 -12
  100. package/esm/maths/randomization/rndGeometryLine.js +0 -46
  101. package/esm/maths/randomization/rndGeometryLine.js.map +0 -1
  102. package/esm/maths/randomization/rndGeometryPoint.d.ts +0 -12
  103. package/esm/maths/randomization/rndGeometryPoint.js +0 -61
  104. package/esm/maths/randomization/rndGeometryPoint.js.map +0 -1
  105. package/esm/maths/randomization/rndHelpers.d.ts +0 -23
  106. package/esm/maths/randomization/rndHelpers.js +0 -98
  107. package/esm/maths/randomization/rndHelpers.js.map +0 -1
  108. package/esm/maths/randomization/rndMonom.d.ts +0 -12
  109. package/esm/maths/randomization/rndMonom.js +0 -53
  110. package/esm/maths/randomization/rndMonom.js.map +0 -1
  111. package/esm/maths/randomization/rndPolynom.d.ts +0 -13
  112. package/esm/maths/randomization/rndPolynom.js +0 -75
  113. package/esm/maths/randomization/rndPolynom.js.map +0 -1
  114. package/esm/maths/randomization/rndTypes.d.ts +0 -34
  115. package/esm/maths/randomization/rndTypes.js +0 -3
  116. package/esm/maths/randomization/rndTypes.js.map +0 -1
  117. package/esm/maths/shutingyard.d.ts +0 -59
  118. package/esm/maths/shutingyard.js +0 -443
  119. package/esm/maths/shutingyard.js.map +0 -1
  120. package/public/matrices.html +0 -100
  121. package/public/playground.html +0 -168
@@ -1,143 +0,0 @@
1
- /**
2
- * Rational polynom module contains everything necessary to handle rational polynoms.
3
- * @module Polynom
4
- */
5
- import { Rational } from "./rational";
6
- import { ISolution } from "./equation";
7
- import { Polynom } from "./polynom";
8
- export type StudyableFunction = Rational;
9
- export declare enum ZEROTYPE {
10
- ZERO = "z",
11
- DEFENCE = "d",
12
- NOTHING = "t"
13
- }
14
- export interface IZero extends ISolution {
15
- extrema: FUNCTION_EXTREMA;
16
- type: ZEROTYPE;
17
- }
18
- export declare enum ASYMPTOTE {
19
- VERTICAL = "av",
20
- HORIZONTAL = "ah",
21
- SLOPE = "ao",
22
- HOLE = "hole"
23
- }
24
- export declare enum ASYMPTOTE_POSITION {
25
- "LT" = "LT",
26
- "RT" = "RT",
27
- "LB" = "LB",
28
- "RB" = "RB"
29
- }
30
- export interface IAsymptote {
31
- deltaX: StudyableFunction;
32
- display: string;
33
- fx: Polynom;
34
- limits: string;
35
- position: ASYMPTOTE_POSITION[];
36
- tableOfSign: ITableOfSigns;
37
- tex: string;
38
- type: ASYMPTOTE;
39
- zero: IZero;
40
- }
41
- export declare enum FUNCTION_EXTREMA {
42
- MIN = "min",
43
- MAX = "max",
44
- FLAT = "flat",
45
- NOTHING = ""
46
- }
47
- export interface IExtrema {
48
- tex: {
49
- x: string;
50
- y: string;
51
- };
52
- type: FUNCTION_EXTREMA;
53
- value: {
54
- x: number;
55
- y: number;
56
- };
57
- }
58
- export interface ITableOfSigns {
59
- extremes: {
60
- [Key: string]: IExtrema;
61
- };
62
- factors: Polynom[];
63
- fx: StudyableFunction;
64
- signs: (string[])[];
65
- tex: string;
66
- type: TABLE_OF_SIGNS;
67
- zeroes: IZero[];
68
- }
69
- export declare enum TABLE_OF_SIGNS {
70
- SIGNS = "signs",
71
- GROWS = "grows",
72
- VARIATIONS = "variatins"
73
- }
74
- export interface StudyConfig {
75
- asymptotes?: boolean;
76
- derivative?: boolean;
77
- domain?: boolean;
78
- name?: string;
79
- variable?: string;
80
- signs?: boolean;
81
- variations?: boolean;
82
- }
83
- /**
84
- * The study class is a "function study" class that will get:
85
- * fx : get the function
86
- * domain : string
87
- * zeroes : Object (tex, IZero)
88
- * signs : table of signs + tex output using tkz-tab
89
- * av : vertical asymptotic
90
- * ah : horizontal asymptotic
91
- * ao : obliques
92
- * deltaX : position relative
93
- * dx : derivative
94
- * grows : growing table + tex output using tkz-tab
95
- * ddx : dérivée seconde
96
- * variations : variation table + tex output using tkz-tab
97
- */
98
- export declare class Study {
99
- fx: StudyableFunction;
100
- private _asymptotes;
101
- private _derivative;
102
- private _signs;
103
- private _variations;
104
- private _zeroes;
105
- private _config;
106
- private _name;
107
- constructor(fx: StudyableFunction, config?: StudyConfig | string);
108
- get name(): string;
109
- set name(value: string);
110
- get config(): StudyConfig;
111
- set config(value: StudyConfig);
112
- get zeroes(): IZero[];
113
- get domain(): string;
114
- get signs(): ITableOfSigns;
115
- get asymptotes(): IAsymptote[];
116
- get derivative(): ITableOfSigns;
117
- get texSigns(): string;
118
- get texGrows(): string;
119
- get texVariations(): string;
120
- makeStudy: () => void;
121
- indexOfZero: (zeroes: IZero[], zero: IZero | ISolution) => number;
122
- makeOneLineForSigns: (factor: Polynom, zeroes: IZero[], zeroSign: ZEROTYPE) => string[];
123
- makeSignsResult: (signs: (string[])[]) => string[];
124
- makeGrowsResult: (tos: ITableOfSigns) => {
125
- growsLine: string[];
126
- extremes: {
127
- [Key: string]: IExtrema;
128
- };
129
- };
130
- makeVariationsResult: (tos: ITableOfSigns) => {
131
- varsLine: string[];
132
- extremes: {
133
- [Key: string]: IExtrema;
134
- };
135
- };
136
- makeZeroes(): IZero[];
137
- makeSigns(): ITableOfSigns;
138
- makeAsymptotes(): IAsymptote[];
139
- makeDerivative(): ITableOfSigns;
140
- makeVariation(): ITableOfSigns;
141
- drawCode: () => string;
142
- private _makeTexFromTableOfSigns;
143
- }
@@ -1,380 +0,0 @@
1
- "use strict";
2
- /**
3
- * Rational polynom module contains everything necessary to handle rational polynoms.
4
- * @module Polynom
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.Study = exports.TABLE_OF_SIGNS = exports.FUNCTION_EXTREMA = exports.ASYMPTOTE_POSITION = exports.ASYMPTOTE = exports.ZEROTYPE = void 0;
8
- const fraction_1 = require("../coefficients/fraction");
9
- const numexp_1 = require("../numexp");
10
- var ZEROTYPE;
11
- (function (ZEROTYPE) {
12
- ZEROTYPE["ZERO"] = "z";
13
- ZEROTYPE["DEFENCE"] = "d";
14
- ZEROTYPE["NOTHING"] = "t";
15
- })(ZEROTYPE || (exports.ZEROTYPE = ZEROTYPE = {}));
16
- var ASYMPTOTE;
17
- (function (ASYMPTOTE) {
18
- ASYMPTOTE["VERTICAL"] = "av";
19
- ASYMPTOTE["HORIZONTAL"] = "ah";
20
- ASYMPTOTE["SLOPE"] = "ao";
21
- ASYMPTOTE["HOLE"] = "hole";
22
- })(ASYMPTOTE || (exports.ASYMPTOTE = ASYMPTOTE = {}));
23
- var ASYMPTOTE_POSITION;
24
- (function (ASYMPTOTE_POSITION) {
25
- ASYMPTOTE_POSITION["LT"] = "LT";
26
- ASYMPTOTE_POSITION["RT"] = "RT";
27
- ASYMPTOTE_POSITION["LB"] = "LB";
28
- ASYMPTOTE_POSITION["RB"] = "RB";
29
- })(ASYMPTOTE_POSITION || (exports.ASYMPTOTE_POSITION = ASYMPTOTE_POSITION = {}));
30
- var FUNCTION_EXTREMA;
31
- (function (FUNCTION_EXTREMA) {
32
- FUNCTION_EXTREMA["MIN"] = "min";
33
- FUNCTION_EXTREMA["MAX"] = "max";
34
- FUNCTION_EXTREMA["FLAT"] = "flat";
35
- FUNCTION_EXTREMA["NOTHING"] = "";
36
- })(FUNCTION_EXTREMA || (exports.FUNCTION_EXTREMA = FUNCTION_EXTREMA = {}));
37
- var TABLE_OF_SIGNS;
38
- (function (TABLE_OF_SIGNS) {
39
- TABLE_OF_SIGNS["SIGNS"] = "signs";
40
- TABLE_OF_SIGNS["GROWS"] = "grows";
41
- TABLE_OF_SIGNS["VARIATIONS"] = "variatins";
42
- })(TABLE_OF_SIGNS || (exports.TABLE_OF_SIGNS = TABLE_OF_SIGNS = {}));
43
- /**
44
- * The study class is a "function study" class that will get:
45
- * fx : get the function
46
- * domain : string
47
- * zeroes : Object (tex, IZero)
48
- * signs : table of signs + tex output using tkz-tab
49
- * av : vertical asymptotic
50
- * ah : horizontal asymptotic
51
- * ao : obliques
52
- * deltaX : position relative
53
- * dx : derivative
54
- * grows : growing table + tex output using tkz-tab
55
- * ddx : dérivée seconde
56
- * variations : variation table + tex output using tkz-tab
57
- */
58
- class Study {
59
- constructor(fx, config) {
60
- this.makeStudy = () => {
61
- this._zeroes = this.makeZeroes();
62
- if (this._config.signs)
63
- this._signs = this.makeSigns();
64
- if (this._config.asymptotes)
65
- this._asymptotes = this.makeAsymptotes();
66
- if (this._config.derivative)
67
- this._derivative = this.makeDerivative();
68
- if (this._config.variations)
69
- this._variations = this.makeVariation();
70
- // Table of signs / derivative / variation
71
- if (this._config.signs)
72
- this._signs.tex = this.texSigns;
73
- if (this._config.derivative)
74
- this._derivative.tex = this.texGrows;
75
- if (this._config.variations)
76
- this._variations.tex = this.texVariations;
77
- };
78
- this.indexOfZero = (zeroes, zero) => {
79
- for (let i = 0; i < zeroes.length; i++) {
80
- if (zeroes[i].tex === zero.tex) {
81
- return i;
82
- }
83
- }
84
- return -1;
85
- };
86
- this.makeOneLineForSigns = (factor, zeroes, zeroSign) => {
87
- let oneLine = [], currentZero = factor.getZeroes().map(x => x.tex);
88
- // First +/- sign, before the first zero
89
- oneLine.push('');
90
- if (factor.degree().isZero()) {
91
- oneLine.push(factor.monoms[0].coefficient.sign() === 1 ? '+' : '-');
92
- }
93
- else {
94
- oneLine.push(factor.evaluate(zeroes[0].value - 1).sign() === 1 ? '+' : '-');
95
- }
96
- for (let i = 0; i < zeroes.length; i++) {
97
- // Add the zero if it's the current one
98
- oneLine.push(currentZero.includes(zeroes[i].tex) ? zeroSign : ZEROTYPE.NOTHING);
99
- // + / - sign after the current zero
100
- if (i < zeroes.length - 1) {
101
- oneLine.push(factor.evaluate((zeroes[i].value + zeroes[i + 1].value) / 2).sign() === 1 ? '+' : '-');
102
- }
103
- else if (i === zeroes.length - 1) {
104
- oneLine.push(factor.evaluate(zeroes[i].value + 1).sign() === 1 ? '+' : '-');
105
- }
106
- }
107
- oneLine.push('');
108
- return oneLine;
109
- };
110
- this.makeSignsResult = (signs) => {
111
- // Initialize the result line with the first line of the signs table
112
- let resultLine = signs[0].map((x, index) => {
113
- if (index === 0 || index === signs[0].length - 1) {
114
- return '';
115
- }
116
- if (index % 2 === 0) {
117
- return 't';
118
- }
119
- return '+';
120
- });
121
- // Go through each lines (except the first)
122
- for (let current of signs) {
123
- for (let i = 0; i < current.length; i++) {
124
- if (i % 2 === 0) {
125
- // t, z or d
126
- if (resultLine[i] === 'd') {
127
- continue;
128
- }
129
- if (current[i] !== 't') {
130
- resultLine[i] = current[i];
131
- }
132
- }
133
- else {
134
- // + or -
135
- if (current[i] === '-') {
136
- resultLine[i] = resultLine[i] === '+' ? '-' : '+';
137
- }
138
- }
139
- }
140
- }
141
- return resultLine;
142
- };
143
- this.makeGrowsResult = (tos) => {
144
- // Use the last line (=> resultLine) to grab the necessary information
145
- let signsAsArray = Object.values(tos.signs), resultLine = signsAsArray[signsAsArray.length - 1], growsLine = [], extremes = {}, zeroes = tos.zeroes;
146
- // Get the extremes
147
- for (let i = 0; i < zeroes.length; i++) {
148
- // Get the corresponding item in the resultLine.
149
- let pos = 2 * i + 2;
150
- if (resultLine[pos] === 'z') {
151
- // It's a zero. Get the coordinates
152
- let x, y, zero = zeroes[i].exact, pt, xTex, yTex, pointType;
153
- // TODO: NumExp should parse something that isn't yet plotFunction
154
- let exp = new numexp_1.NumExp(this.fx.plotFunction);
155
- if (zero instanceof fraction_1.Fraction) {
156
- let value = zero, evalY = this.fx.evaluate(value);
157
- x = zero.value;
158
- y = evalY.value;
159
- xTex = zero.tex;
160
- yTex = evalY.tex;
161
- }
162
- else {
163
- x = zeroes[i].value;
164
- y = exp.evaluate({ x });
165
- xTex = x.toFixed(2);
166
- yTex = y.toFixed(2);
167
- }
168
- // Determine the type of the zero.
169
- if (resultLine[pos - 1] === resultLine[pos + 1]) {
170
- pointType = FUNCTION_EXTREMA.FLAT;
171
- }
172
- else if (resultLine[pos - 1] === '+') {
173
- pointType = FUNCTION_EXTREMA.MAX;
174
- }
175
- else {
176
- pointType = FUNCTION_EXTREMA.MIN;
177
- }
178
- // Add the point to the list
179
- extremes[zeroes[i].tex] = {
180
- type: pointType,
181
- tex: { x: xTex, y: yTex },
182
- value: { x, y }
183
- };
184
- }
185
- }
186
- // Create the grows line, based on tkz-tab
187
- // \tkzTabLine{ , + , z , - , d , - , z , + , }
188
- // \tkzTabVar{ -/ , +/$3$ , -D+/ , -/$1$ , +/ }
189
- growsLine.push(resultLine[1] === '+' ? '-/' : '+/');
190
- for (let i = 1; i < resultLine.length - 1; i++) {
191
- if (resultLine[i] === "z") {
192
- let extr = extremes[zeroes[(i - 2) / 2].tex];
193
- growsLine.push(`${resultLine[i - 1]}/\\(${extr.type}(${extr.tex.x};${extr.tex.y})\\)`);
194
- }
195
- else if (resultLine[i] === 'd') {
196
- growsLine.push(`${resultLine[i - 1]}D${resultLine[i + 1] === '+' ? '-' : '+'}/`);
197
- }
198
- }
199
- growsLine.push(`${resultLine[resultLine.length - 2]}/`);
200
- return { growsLine, extremes };
201
- };
202
- this.makeVariationsResult = (tos) => {
203
- // TODO: make variations result is not yet implemented.
204
- let extremes = {}, varsLine = [];
205
- return { varsLine, extremes };
206
- };
207
- this.drawCode = () => {
208
- // Function as string
209
- let code = `f(x)=${this.fx.plotFunction}`;
210
- // Asymptotes
211
- let i = 1;
212
- this.asymptotes.forEach(asymptote => {
213
- if (asymptote.type === ASYMPTOTE.VERTICAL) {
214
- code += `\nav_${i}=line x=${asymptote.zero.value}->red,dash`;
215
- i++;
216
- }
217
- else if (asymptote.type === ASYMPTOTE.HORIZONTAL) {
218
- code += `\nah=line y=${asymptote.fx.monoms[0].coefficient.value}->orange,dash`;
219
- }
220
- else if (asymptote.type === ASYMPTOTE.SLOPE) {
221
- code += `\nao=line y=${asymptote.fx.plotFunction}->red,dash`;
222
- }
223
- i++;
224
- });
225
- // Extremes
226
- for (let zero in this.derivative.extremes) {
227
- let extreme = this.derivative.extremes[zero];
228
- code += `\nM_${i}(${extreme.value.x},${extreme.value.y})*`;
229
- i++;
230
- }
231
- // Zeroes
232
- this.zeroes.forEach(zero => {
233
- if (zero.type === ZEROTYPE.ZERO) {
234
- code += `\nZ_${i}(${zero.value},0)*`;
235
- i++;
236
- }
237
- });
238
- return code;
239
- };
240
- this._makeTexFromTableOfSigns = (tos) => {
241
- let factors = tos.factors.map(x => `\\(${x.tex}\\)/1`), factorsFx = `\\(${this._config.name}(${this._config.variable})\\)/1.2`, zeroes = tos.zeroes;
242
- // Add the last lines "label"
243
- if (tos.type === TABLE_OF_SIGNS.GROWS) {
244
- factorsFx = `\\(${this._config.name}'(${this._config.variable})\\)/1.2,\\(f(x${this._config.variable})\\)/2`;
245
- }
246
- else if (tos.type === TABLE_OF_SIGNS.VARIATIONS) {
247
- factorsFx = `\\(${this._config.name}''(${this._config.variable})\\)/1.2,\\(f(${this._config.variable})\\)/2`;
248
- }
249
- // Create the tikzPicture header
250
- let tex = `\\begin{tikzpicture}
251
- \\tkzTabInit[lgt=3,espcl=2,deltacl=0]{/1.2,${factors.join(',')},/.1,${factorsFx} }{{\\scriptsize \\hspace{1cm} \\(-\\infty\\)},\\(${zeroes.map(x => x.tex).join('\\),\\(')}\\),{\\scriptsize \\hspace{-1cm} \\(+\\infty\\)}}`;
252
- let pos;
253
- for (pos = 0; pos < tos.factors.length; pos++) {
254
- tex += (`\n\\tkzTabLine{${tos.signs[pos].join(',')}}`);
255
- }
256
- // Add the result line
257
- tex += (`\n\\tkzTabLine{${tos.signs[pos].join(',')}}`);
258
- // Add the grows / vars line
259
- if (tos.type === TABLE_OF_SIGNS.GROWS) {
260
- tex += (`\n\\tkzTabVar{${tos.signs[pos + 1].join(',')}}`);
261
- }
262
- else if (tos.type === TABLE_OF_SIGNS.VARIATIONS) {
263
- // TODO: Check variations table for as tex
264
- tex += (`\n\\tkzTabVar{${tos.signs[pos + 1].join(',')}}`);
265
- }
266
- tex += `\n\\end{tikzpicture}`;
267
- return tex;
268
- };
269
- this.fx = fx;
270
- this._config = {
271
- name: 'f',
272
- variable: 'x',
273
- domain: true,
274
- asymptotes: true,
275
- signs: true,
276
- derivative: true,
277
- variations: true,
278
- };
279
- if (config) {
280
- if (typeof config === 'string') {
281
- const d = config.split(',');
282
- this._config = {};
283
- let n = d.filter(x => x.includes('(') && x.includes(')'));
284
- if (n.length === 1) {
285
- this._config.name = n[0].split('(')[0];
286
- this._config.variable = n[0].split('(')[1].split(')')[0];
287
- }
288
- this._config.domain = d.includes('d');
289
- this._config.asymptotes = d.includes('a');
290
- this._config.signs = d.includes('signs');
291
- this._config.derivative = d.includes('dx');
292
- this._config.variations = d.includes('ddx');
293
- }
294
- else {
295
- this._config = config;
296
- }
297
- }
298
- this.makeStudy();
299
- return this;
300
- }
301
- get name() {
302
- return this._config.name;
303
- }
304
- set name(value) {
305
- this._config.name = value;
306
- }
307
- get config() {
308
- return this._config;
309
- }
310
- set config(value) {
311
- this._config = value;
312
- }
313
- get zeroes() {
314
- return this._zeroes;
315
- }
316
- get domain() {
317
- return this.fx.domain();
318
- }
319
- get signs() {
320
- return this._signs;
321
- }
322
- get asymptotes() {
323
- return this._asymptotes;
324
- }
325
- get derivative() {
326
- return this._derivative;
327
- }
328
- get texSigns() {
329
- return this._makeTexFromTableOfSigns(this._signs);
330
- }
331
- get texGrows() {
332
- return this._makeTexFromTableOfSigns(this._derivative);
333
- }
334
- get texVariations() {
335
- return this._makeTexFromTableOfSigns(this._variations);
336
- }
337
- makeZeroes() {
338
- return [];
339
- }
340
- ;
341
- makeSigns() {
342
- return {
343
- type: TABLE_OF_SIGNS.SIGNS,
344
- fx: null,
345
- factors: [],
346
- zeroes: [],
347
- signs: [],
348
- extremes: {},
349
- tex: ''
350
- };
351
- }
352
- ;
353
- makeAsymptotes() {
354
- return [];
355
- }
356
- makeDerivative() {
357
- return {
358
- type: TABLE_OF_SIGNS.GROWS,
359
- fx: null,
360
- factors: [],
361
- zeroes: [],
362
- signs: [],
363
- extremes: {},
364
- tex: ''
365
- };
366
- }
367
- makeVariation() {
368
- return {
369
- type: TABLE_OF_SIGNS.VARIATIONS,
370
- fx: null,
371
- factors: [],
372
- zeroes: [],
373
- signs: [],
374
- extremes: {},
375
- tex: ''
376
- };
377
- }
378
- }
379
- exports.Study = Study;
380
- //# sourceMappingURL=study.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"study.js","sourceRoot":"","sources":["../../../src/maths/algebra/study.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAKH,uDAAkD;AAElD,sCAAiC;AAKjC,IAAY,QAIX;AAJD,WAAY,QAAQ;IAChB,sBAAU,CAAA;IACV,yBAAa,CAAA;IACb,yBAAa,CAAA;AACjB,CAAC,EAJW,QAAQ,wBAAR,QAAQ,QAInB;AAOD,IAAY,SAKX;AALD,WAAY,SAAS;IACjB,4BAAe,CAAA;IACf,8BAAiB,CAAA;IACjB,yBAAY,CAAA;IACZ,0BAAa,CAAA;AACjB,CAAC,EALW,SAAS,yBAAT,SAAS,QAKpB;AAED,IAAY,kBAKX;AALD,WAAY,kBAAkB;IAC1B,+BAAW,CAAA;IACX,+BAAW,CAAA;IACX,+BAAW,CAAA;IACX,+BAAW,CAAA;AACf,CAAC,EALW,kBAAkB,kCAAlB,kBAAkB,QAK7B;AAcD,IAAY,gBAKX;AALD,WAAY,gBAAgB;IACxB,+BAAW,CAAA;IACX,+BAAW,CAAA;IACX,iCAAa,CAAA;IACb,gCAAY,CAAA;AAChB,CAAC,EALW,gBAAgB,gCAAhB,gBAAgB,QAK3B;AAyBD,IAAY,cAIX;AAJD,WAAY,cAAc;IACtB,iCAAe,CAAA;IACf,iCAAe,CAAA;IACf,0CAAwB,CAAA;AAC5B,CAAC,EAJW,cAAc,8BAAd,cAAc,QAIzB;AAYD;;;;;;;;;;;;;;GAcG;AACH,MAAa,KAAK;IAUd,YAAY,EAAqB,EAAE,MAA6B;QAqFhE,cAAS,GAAG,GAAS,EAAE;YACnB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAA;YAEhC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK;gBAAE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE,CAAA;YAEtD,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU;gBAAE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,EAAE,CAAA;YAErE,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU;gBAAE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,EAAE,CAAA;YAErE,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU;gBAAE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,EAAE,CAAA;YAEpE,0CAA0C;YAC1C,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK;gBAAE,IAAI,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAA;YAEvD,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU;gBAAE,IAAI,CAAC,WAAW,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAA;YAEjE,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU;gBAAE,IAAI,CAAC,WAAW,CAAC,GAAG,GAAG,IAAI,CAAC,aAAa,CAAA;QAC1E,CAAC,CAAC;QAEF,gBAAW,GAAG,CAAC,MAAe,EAAE,IAAuB,EAAU,EAAE;YAC/D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACpC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,GAAG,EAAE;oBAC5B,OAAO,CAAC,CAAA;iBACX;aACJ;YACD,OAAO,CAAC,CAAC,CAAA;QACb,CAAC,CAAC;QAEF,wBAAmB,GAAG,CAAC,MAAe,EAAE,MAAe,EAAE,QAAkB,EAAY,EAAE;YACrF,IAAI,OAAO,GAAa,EAAE,EACtB,WAAW,GAAG,MAAM,CAAC,SAAS,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAA;YAEpD,wCAAwC;YACxC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YAChB,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,EAAE;gBAC1B,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAA;aACtE;iBAAM;gBACH,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAA;aAC9E;YAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACpC,uCAAuC;gBACvC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAA;gBAE/E,oCAAoC;gBACpC,IAAI,CAAC,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;oBACvB,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAA;iBACtG;qBAAM,IAAI,CAAC,KAAK,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;oBAChC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAA;iBAC9E;aAEJ;YACD,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YAEhB,OAAO,OAAO,CAAA;QAClB,CAAC,CAAA;QAED,oBAAe,GAAG,CAAC,KAAmB,EAAY,EAAE;YAEhD,oEAAoE;YACpE,IAAI,UAAU,GAAa,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;gBACjD,IAAI,KAAK,KAAK,CAAC,IAAI,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;oBAC9C,OAAO,EAAE,CAAA;iBACZ;gBAED,IAAI,KAAK,GAAG,CAAC,KAAK,CAAC,EAAE;oBACjB,OAAO,GAAG,CAAA;iBACb;gBAED,OAAO,GAAG,CAAA;YACd,CAAC,CAAC,CAAA;YAEF,2CAA2C;YAC3C,KAAK,IAAI,OAAO,IAAI,KAAK,EAAE;gBAEvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBACrC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;wBACb,YAAY;wBACZ,IAAI,UAAU,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;4BACvB,SAAQ;yBACX;wBACD,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;4BACpB,UAAU,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAA;yBAC7B;qBACJ;yBAAM;wBACH,SAAS;wBACT,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;4BACpB,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAA;yBACpD;qBACJ;iBACJ;aACJ;YAED,OAAO,UAAU,CAAA;QACrB,CAAC,CAAA;QAED,oBAAe,GAAG,CAAC,GAAkB,EAAkE,EAAE;YAErG,sEAAsE;YACtE,IAAI,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EACvC,UAAU,GAAG,YAAY,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,EAClD,SAAS,GAAa,EAAE,EACxB,QAAQ,GAAgC,EAAE,EAC1C,MAAM,GAAG,GAAG,CAAC,MAAM,CAAA;YAEvB,mBAAmB;YACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAEpC,gDAAgD;gBAChD,IAAI,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;gBACnB,IAAI,UAAU,CAAC,GAAG,CAAC,KAAK,GAAG,EAAE;oBAEzB,mCAAmC;oBACnC,IAAI,CAAS,EAAE,CAAS,EAAE,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,EAC5C,EAAS,EACT,IAAY,EAAE,IAAY,EAC1B,SAA2B,CAAA;oBAE/B,kEAAkE;oBAClE,IAAI,GAAG,GAAG,IAAI,eAAM,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,CAAA;oBAE1C,IAAI,IAAI,YAAY,mBAAQ,EAAE;wBAC1B,IAAI,KAAK,GAAa,IAAI,EACtB,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;wBAEnC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAA;wBACd,CAAC,GAAG,KAAK,CAAC,KAAK,CAAA;wBACf,IAAI,GAAG,IAAI,CAAC,GAAG,CAAA;wBACf,IAAI,GAAG,KAAK,CAAC,GAAG,CAAA;qBACnB;yBAAM;wBACH,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;wBACnB,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC,EAAC,CAAC,EAAC,CAAC,CAAA;wBAErB,IAAI,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;wBACnB,IAAI,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;qBACtB;oBAED,kCAAkC;oBAClC,IAAI,UAAU,CAAC,GAAG,GAAG,CAAC,CAAC,KAAK,UAAU,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE;wBAC7C,SAAS,GAAG,gBAAgB,CAAC,IAAI,CAAA;qBACpC;yBAAM,IAAI,UAAU,CAAC,GAAG,GAAG,CAAC,CAAC,KAAK,GAAG,EAAE;wBACpC,SAAS,GAAG,gBAAgB,CAAC,GAAG,CAAA;qBACnC;yBAAM;wBACH,SAAS,GAAG,gBAAgB,CAAC,GAAG,CAAA;qBAEnC;oBAED,4BAA4B;oBAC5B,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG;wBACtB,IAAI,EAAE,SAAS;wBACf,GAAG,EAAE,EAAC,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAC;wBACvB,KAAK,EAAE,EAAC,CAAC,EAAE,CAAC,EAAC;qBAChB,CAAA;iBACJ;aACJ;YAED,0CAA0C;YAC1C,iEAAiE;YACjE,4DAA4D;YAC5D,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;YACnD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC5C,IAAI,UAAU,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;oBACvB,IAAI,IAAI,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAA;oBAE5C,SAAS,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAA;iBACzF;qBAAM,IAAI,UAAU,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;oBAC9B,SAAS,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAA;iBACnF;aACJ;YACD,SAAS,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,CAAA;YAEvD,OAAO,EAAC,SAAS,EAAE,QAAQ,EAAC,CAAA;QAChC,CAAC,CAAA;QAED,yBAAoB,GAAG,CAAC,GAAkB,EAAiE,EAAE;YACzG,uDAAuD;YACvD,IAAI,QAAQ,GAAG,EAAE,EACb,QAAQ,GAAa,EAAE,CAAA;YAC3B,OAAO,EAAC,QAAQ,EAAE,QAAQ,EAAC,CAAA;QAC/B,CAAC,CAAA;QA8CD,aAAQ,GAAG,GAAW,EAAE;YACpB,qBAAqB;YACrB,IAAI,IAAI,GAAG,QAAQ,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAA;YAEzC,aAAa;YACb,IAAI,CAAC,GAAW,CAAC,CAAA;YACjB,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;gBAChC,IAAI,SAAS,CAAC,IAAI,KAAK,SAAS,CAAC,QAAQ,EAAE;oBACvC,IAAI,IAAI,QAAQ,CAAC,WAAW,SAAS,CAAC,IAAI,CAAC,KAAK,YAAY,CAAA;oBAC5D,CAAC,EAAE,CAAA;iBACN;qBAAM,IAAI,SAAS,CAAC,IAAI,KAAK,SAAS,CAAC,UAAU,EAAE;oBAChD,IAAI,IAAI,eAAe,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,KAAK,eAAe,CAAA;iBACjF;qBAAM,IAAI,SAAS,CAAC,IAAI,KAAK,SAAS,CAAC,KAAK,EAAE;oBAC3C,IAAI,IAAI,eAAe,SAAS,CAAC,EAAE,CAAC,YAAY,YAAY,CAAA;iBAC/D;gBACD,CAAC,EAAE,CAAA;YACP,CAAC,CAAC,CAAA;YAEF,WAAW;YACX,KAAK,IAAI,IAAI,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;gBACvC,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;gBAE5C,IAAI,IAAI,OAAO,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAA;gBAC1D,CAAC,EAAE,CAAA;aACN;YAED,SAAS;YACT,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBACvB,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,IAAI,EAAE;oBAC7B,IAAI,IAAI,OAAO,CAAC,IAAI,IAAI,CAAC,KAAK,MAAM,CAAA;oBACpC,CAAC,EAAE,CAAA;iBACN;YACL,CAAC,CAAC,CAAA;YAEF,OAAO,IAAI,CAAA;QACf,CAAC,CAAA;QAEO,6BAAwB,GAAG,CAAC,GAAkB,EAAU,EAAE;YAC9D,IAAI,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,OAAO,CAAC,EAClD,SAAS,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,UAAU,EACtE,MAAM,GAAG,GAAG,CAAC,MAAM,CAAA;YAEvB,6BAA6B;YAC7B,IAAI,GAAG,CAAC,IAAI,KAAK,cAAc,CAAC,KAAK,EAAE;gBACnC,SAAS,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,KAAK,IAAI,CAAC,OAAO,CAAC,QAAQ,kBAAkB,IAAI,CAAC,OAAO,CAAC,QAAQ,QAAQ,CAAA;aAC/G;iBAAM,IAAI,GAAG,CAAC,IAAI,KAAK,cAAc,CAAC,UAAU,EAAE;gBAC/C,SAAS,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,iBAAiB,IAAI,CAAC,OAAO,CAAC,QAAQ,QAAQ,CAAA;aAC/G;YAED,gCAAgC;YAChC,IAAI,GAAG,GAAG;6CAC2B,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,SAAS,qDAAqD,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,mDAAmD,CAAA;YAErN,IAAI,GAAG,CAAA;YACP,KAAK,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE;gBAC3C,GAAG,IAAI,CAAC,kBAAkB,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;aACzD;YAED,sBAAsB;YACtB,GAAG,IAAI,CAAC,kBAAkB,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;YACtD,4BAA4B;YAC5B,IAAI,GAAG,CAAC,IAAI,KAAK,cAAc,CAAC,KAAK,EAAE;gBACnC,GAAG,IAAI,CAAC,iBAAiB,GAAG,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;aAC5D;iBAAM,IAAI,GAAG,CAAC,IAAI,KAAK,cAAc,CAAC,UAAU,EAAE;gBAC/C,0CAA0C;gBAC1C,GAAG,IAAI,CAAC,iBAAiB,GAAG,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;aAC5D;YAED,GAAG,IAAI,sBAAsB,CAAA;YAE7B,OAAO,GAAG,CAAA;QACd,CAAC,CAAA;QA5XG,IAAI,CAAC,EAAE,GAAG,EAAE,CAAA;QAEZ,IAAI,CAAC,OAAO,GAAG;YACX,IAAI,EAAE,GAAG;YACT,QAAQ,EAAE,GAAG;YACb,MAAM,EAAE,IAAI;YACZ,UAAU,EAAE,IAAI;YAChB,KAAK,EAAE,IAAI;YACX,UAAU,EAAE,IAAI;YAChB,UAAU,EAAE,IAAI;SACnB,CAAA;QAED,IAAI,MAAM,EAAE;YACR,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE;gBAC5B,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;gBAC3B,IAAI,CAAC,OAAO,GAAG,EAAE,CAAA;gBACjB,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAA,EAAE,CAAA,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAA;gBAEvD,IAAG,CAAC,CAAC,MAAM,KAAG,CAAC,EAAC;oBACZ,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;oBACtC,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;iBAC3D;gBACD,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAA;gBACrC,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAA;gBACzC,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAA;gBACxC,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;gBAC1C,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;aAC9C;iBAAM;gBACH,IAAI,CAAC,OAAO,GAAG,MAAM,CAAA;aACxB;SACJ;QAED,IAAI,CAAC,SAAS,EAAE,CAAA;QAChB,OAAO,IAAI,CAAA;IACf,CAAC;IAED,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;IAC7B,CAAC;IAED,IAAI,IAAI,CAAC,KAAa;QAClB,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,KAAK,CAAC;IAC9B,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,IAAI,MAAM,CAAC,KAAkB;QACzB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACzB,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,EAAE,CAAC,MAAM,EAAE,CAAA;IAC3B,CAAC;IAED,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,WAAW,CAAC;IAC5B,CAAC;IAED,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,WAAW,CAAC;IAC5B,CAAC;IAED,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IACrD,CAAC;IAED,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;IAC1D,CAAC;IAED,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;IAC1D,CAAC;IAuLD,UAAU;QACN,OAAO,EAAE,CAAA;IACb,CAAC;IAAA,CAAC;IAEF,SAAS;QACL,OAAO;YACH,IAAI,EAAE,cAAc,CAAC,KAAK;YAC1B,EAAE,EAAE,IAAI;YACR,OAAO,EAAE,EAAE;YACX,MAAM,EAAE,EAAE;YACV,KAAK,EAAE,EAAE;YACT,QAAQ,EAAE,EAAE;YACZ,GAAG,EAAE,EAAE;SACV,CAAA;IACL,CAAC;IAAA,CAAC;IAEF,cAAc;QACV,OAAO,EAAE,CAAA;IACb,CAAC;IAED,cAAc;QACV,OAAO;YACH,IAAI,EAAE,cAAc,CAAC,KAAK;YAC1B,EAAE,EAAE,IAAI;YACR,OAAO,EAAE,EAAE;YACX,MAAM,EAAE,EAAE;YACV,KAAK,EAAE,EAAE;YACT,QAAQ,EAAE,EAAE;YACZ,GAAG,EAAE,EAAE;SACV,CAAA;IACL,CAAC;IAED,aAAa;QACT,OAAO;YACH,IAAI,EAAE,cAAc,CAAC,UAAU;YAC/B,EAAE,EAAE,IAAI;YACR,OAAO,EAAE,EAAE;YACX,MAAM,EAAE,EAAE;YACV,KAAK,EAAE,EAAE;YACT,QAAQ,EAAE,EAAE;YACZ,GAAG,EAAE,EAAE;SACV,CAAA;IACL,CAAC;CA0EJ;AAxYD,sBAwYC"}
@@ -1,90 +0,0 @@
1
- export type FractionParsingType = number | string | Fraction;
2
- /**
3
- * The fraction class make possible to handle
4
- * TODO: Write the documentation correctly.
5
- * \\(\frac{a}{b}\\) or \\[\frac{a}{b}\\] values.
6
- */
7
- export declare class Fraction {
8
- private _denominator;
9
- private _numerator;
10
- constructor(value?: unknown, denominatorOrPeriodic?: number);
11
- get numerator(): number;
12
- set numerator(value: number);
13
- get denominator(): number;
14
- set denominator(value: number);
15
- get value(): number;
16
- get tex(): string;
17
- get texWithSign(): string;
18
- get display(): string;
19
- get frac(): string;
20
- get dfrac(): string;
21
- get tfrac(): string;
22
- static max: (...fractions: (Fraction | number)[]) => Fraction;
23
- static min: (...fractions: (Fraction | number)[]) => Fraction;
24
- static average: (...fractions: (Fraction | number)[]) => Fraction;
25
- static unique: (fractions: Fraction[], sorted?: boolean) => Fraction[];
26
- static sort: (fractions: Fraction[], reverse?: boolean) => Fraction[];
27
- isApproximative: () => boolean;
28
- isExact: () => boolean;
29
- /**
30
- * Parse the value to get the numerator and denominator
31
- * @param value : number or string to parse to get the fraction
32
- * @param denominatorOrPeriodic (optional|number) : length of the periodic part: 2.333333 => 1 or denominator value
33
- */
34
- parse: (value: unknown, denominatorOrPeriodic?: number) => Fraction;
35
- clone: () => Fraction;
36
- zero: () => Fraction;
37
- one: () => Fraction;
38
- infinite: () => Fraction;
39
- invalid: () => Fraction;
40
- opposed: () => Fraction;
41
- add: (F: Fraction | number) => Fraction;
42
- subtract: (F: Fraction | number) => Fraction;
43
- multiply: (F: Fraction | number) => Fraction;
44
- xMultiply: (...values: (Fraction | number)[]) => Fraction;
45
- divide: (F: Fraction | number) => Fraction;
46
- invert: () => Fraction;
47
- pow: (p: number | Fraction) => Fraction;
48
- root: (p: number) => Fraction;
49
- sqrt: () => Fraction;
50
- abs: () => Fraction;
51
- reduce: () => Fraction;
52
- amplify: (k: number) => Fraction;
53
- /**
54
- * Compare the current coefficient with another coefficient
55
- * @param F (Coefficient) The coefficient to compare
56
- * @param sign (string| default is =): authorized values: =, <, <=, >, >= with some variations.
57
- */
58
- compare: (F: unknown, sign?: string) => boolean;
59
- lesser: (than: Fraction | number) => Boolean;
60
- leq: (than: Fraction | number) => Boolean;
61
- greater: (than: Fraction | number) => Boolean;
62
- geq: (than: Fraction | number) => Boolean;
63
- isEqual: (than: Fraction | number) => boolean;
64
- isNotEqual: (than: Fraction | number) => boolean;
65
- isOpposed: (p: Fraction) => boolean;
66
- isInverted: (p: Fraction) => boolean;
67
- isZero: () => boolean;
68
- isNotZero: () => boolean;
69
- isOne: () => boolean;
70
- isNegativeOne: () => boolean;
71
- isPositive: () => boolean;
72
- isNegative: () => boolean;
73
- isStrictlyPositive: () => boolean;
74
- isStrictlyNegative: () => Boolean;
75
- isNaN: () => boolean;
76
- isInfinity: () => boolean;
77
- isFinite: () => boolean;
78
- isSquare: () => boolean;
79
- isReduced: () => boolean;
80
- isNatural: () => boolean;
81
- isRelative: () => boolean;
82
- isRational: () => boolean;
83
- isEven: () => boolean;
84
- isOdd: () => boolean;
85
- sign: () => number;
86
- /**
87
- * Simple function to determine if it's a fraction
88
- */
89
- areEquals: (...F: Fraction[]) => boolean;
90
- }