dsp-collection 0.2.5 → 0.2.7
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/README.md +6 -2
- package/filter/FirFilterWin.d.ts +8 -0
- package/filter/FirFilterWin.d.ts.map +1 -0
- package/filter/FirFilterWin.js +55 -0
- package/filter/FirFilterWin.js.map +1 -0
- package/filter/SpecFilt.d.ts +11 -10
- package/filter/SpecFilt.d.ts.map +1 -0
- package/filter/SpecFilt.js +98 -98
- package/filter/SpecFilt.js.map +1 -1
- package/math/Complex.d.ts +43 -42
- package/math/Complex.d.ts.map +1 -0
- package/math/Complex.js +130 -129
- package/math/Complex.js.map +1 -1
- package/math/ComplexArray.d.ts +37 -36
- package/math/ComplexArray.d.ts.map +1 -0
- package/math/ComplexArray.js +170 -170
- package/math/ComplexArray.js.map +1 -1
- package/math/MathUtils.d.ts +10 -7
- package/math/MathUtils.d.ts.map +1 -0
- package/math/MathUtils.js +116 -81
- package/math/MathUtils.js.map +1 -1
- package/math/MutableComplex.d.ts +24 -22
- package/math/MutableComplex.d.ts.map +1 -0
- package/math/MutableComplex.js +68 -64
- package/math/MutableComplex.js.map +1 -1
- package/math/NumApprox.d.ts +4 -3
- package/math/NumApprox.d.ts.map +1 -0
- package/math/NumApprox.js +67 -67
- package/math/NumApprox.js.map +1 -1
- package/math/PolyReal.d.ts +14 -13
- package/math/PolyReal.d.ts.map +1 -0
- package/math/PolyReal.js +226 -226
- package/math/PolyReal.js.map +1 -1
- package/package.json +11 -3
- package/signal/AdaptiveStft.d.ts +13 -12
- package/signal/AdaptiveStft.d.ts.map +1 -0
- package/signal/AdaptiveStft.js +57 -57
- package/signal/AdaptiveStft.js.map +1 -1
- package/signal/Autocorrelation.d.ts +6 -5
- package/signal/Autocorrelation.d.ts.map +1 -0
- package/signal/Autocorrelation.js +53 -53
- package/signal/Autocorrelation.js.map +1 -1
- package/signal/Dft.d.ts +10 -9
- package/signal/Dft.d.ts.map +1 -0
- package/signal/Dft.js +87 -87
- package/signal/Dft.js.map +1 -1
- package/signal/EnvelopeDetection.d.ts +2 -1
- package/signal/EnvelopeDetection.d.ts.map +1 -0
- package/signal/EnvelopeDetection.js +9 -9
- package/signal/EnvelopeDetection.js.map +1 -1
- package/signal/Fft.d.ts +10 -9
- package/signal/Fft.d.ts.map +1 -0
- package/signal/Fft.js +275 -275
- package/signal/Fft.js.map +1 -1
- package/signal/Goertzel.d.ts +6 -5
- package/signal/Goertzel.d.ts.map +1 -0
- package/signal/Goertzel.js +48 -48
- package/signal/Goertzel.js.map +1 -1
- package/signal/InstFreq.d.ts +9 -8
- package/signal/InstFreq.d.ts.map +1 -0
- package/signal/InstFreq.js +26 -26
- package/signal/InstFreq.js.map +1 -1
- package/signal/PitchDetectionHarm.d.ts +27 -26
- package/signal/PitchDetectionHarm.d.ts.map +1 -0
- package/signal/PitchDetectionHarm.js +72 -68
- package/signal/PitchDetectionHarm.js.map +1 -1
- package/signal/Resampling.d.ts +8 -7
- package/signal/Resampling.d.ts.map +1 -0
- package/signal/Resampling.js +218 -218
- package/signal/Resampling.js.map +1 -1
- package/signal/WindowFunctions.d.ts +42 -40
- package/signal/WindowFunctions.d.ts.map +1 -0
- package/signal/WindowFunctions.js +194 -194
- package/signal/WindowFunctions.js.map +1 -1
- package/utils/ArrayUtils.d.ts +10 -9
- package/utils/ArrayUtils.d.ts.map +1 -0
- package/utils/ArrayUtils.js +68 -68
- package/utils/ArrayUtils.js.map +1 -1
- package/utils/DspUtils.d.ts +5 -2
- package/utils/DspUtils.d.ts.map +1 -0
- package/utils/DspUtils.js +12 -6
- package/utils/DspUtils.js.map +1 -1
- package/utils/MiscUtils.d.ts +7 -6
- package/utils/MiscUtils.d.ts.map +1 -0
- package/utils/MiscUtils.js +20 -20
- package/utils/MiscUtils.js.map +1 -1
package/math/MutableComplex.d.ts
CHANGED
|
@@ -1,22 +1,24 @@
|
|
|
1
|
-
import Complex from "./Complex.
|
|
2
|
-
export default class MutableComplex extends Complex {
|
|
3
|
-
re: number;
|
|
4
|
-
im: number;
|
|
5
|
-
constructor(re?: number, im?: number);
|
|
6
|
-
static fromComplex(x: Complex): MutableComplex;
|
|
7
|
-
static expj(arg: number): MutableComplex;
|
|
8
|
-
static fromPolar(abs: number, arg: number): MutableComplex;
|
|
9
|
-
set(x: Complex): void;
|
|
10
|
-
setReIm(re: number, im?: number): void;
|
|
11
|
-
setExpj(arg: number): void;
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
1
|
+
import Complex from "./Complex.ts";
|
|
2
|
+
export default class MutableComplex extends Complex {
|
|
3
|
+
re: number;
|
|
4
|
+
im: number;
|
|
5
|
+
constructor(re?: number, im?: number);
|
|
6
|
+
static fromComplex(x: Complex): MutableComplex;
|
|
7
|
+
static expj(arg: number): MutableComplex;
|
|
8
|
+
static fromPolar(abs: number, arg: number): MutableComplex;
|
|
9
|
+
set(x: Complex): void;
|
|
10
|
+
setReIm(re: number, im?: number): void;
|
|
11
|
+
setExpj(arg: number): void;
|
|
12
|
+
setPolar(abs: number, arg: number): void;
|
|
13
|
+
addRealTo(x: number): void;
|
|
14
|
+
addTo(x: Complex): void;
|
|
15
|
+
subRealFrom(x: number): void;
|
|
16
|
+
subFrom(x: Complex): void;
|
|
17
|
+
mulByReal(x: number): void;
|
|
18
|
+
mulBy(x: Complex): void;
|
|
19
|
+
divByReal(x: number): void;
|
|
20
|
+
divBy(x: Complex): void;
|
|
21
|
+
setMul(re1: number, im1: number, re2: number, im2: number): void;
|
|
22
|
+
setDiv(re1: number, im1: number, re2: number, im2: number): void;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=MutableComplex.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MutableComplex.d.ts","sourceRoot":"","sources":["../../src/math/MutableComplex.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,cAAc,CAAC;AAUnC,MAAM,CAAC,OAAO,OAAO,cAAe,SAAQ,OAAO;IAKhC,EAAE,EAAE,MAAM,CAAC;IAGX,EAAE,EAAE,MAAM,CAAC;gBAYP,EAAE,GAAE,MAAU,EAAE,EAAE,GAAE,MAAU;WAQpC,WAAW,CAAE,CAAC,EAAE,OAAO,GAAI,cAAc;WAOhC,IAAI,CAAE,GAAG,EAAE,MAAM,GAAI,cAAc;WAOnC,SAAS,CAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAI,cAAc;IAQrE,GAAG,CAAE,CAAC,EAAE,OAAO;IAOf,OAAO,CAAE,EAAE,EAAE,MAAM,EAAE,EAAE,SAAI;IAO3B,OAAO,CAAE,GAAG,EAAE,MAAM;IAOpB,QAAQ,CAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM;IASlC,SAAS,CAAE,CAAC,EAAE,MAAM;IAMpB,KAAK,CAAE,CAAC,EAAE,OAAO;IAOjB,WAAW,CAAE,CAAC,EAAE,MAAM;IAMtB,OAAO,CAAE,CAAC,EAAE,OAAO;IAOnB,SAAS,CAAE,CAAC,EAAE,MAAM;IAOpB,KAAK,CAAE,CAAC,EAAE,OAAO;IAMjB,SAAS,CAAE,CAAC,EAAE,MAAM;IAOpB,KAAK,CAAE,CAAC,EAAE,OAAO;IAQjB,MAAM,CAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM;IAO1D,MAAM,CAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM;CAKhE"}
|
package/math/MutableComplex.js
CHANGED
|
@@ -1,65 +1,69 @@
|
|
|
1
|
-
import Complex from "./Complex.js";
|
|
2
|
-
export default class MutableComplex extends Complex {
|
|
3
|
-
constructor(re = 0, im = 0) {
|
|
4
|
-
super(re, im);
|
|
5
|
-
}
|
|
6
|
-
static fromComplex(x) {
|
|
7
|
-
return new MutableComplex(x.re, x.im);
|
|
8
|
-
}
|
|
9
|
-
static expj(arg) {
|
|
10
|
-
return new MutableComplex(Math.cos(arg), Math.sin(arg));
|
|
11
|
-
}
|
|
12
|
-
static fromPolar(abs, arg) {
|
|
13
|
-
return new MutableComplex(abs * Math.cos(arg), abs * Math.sin(arg));
|
|
14
|
-
}
|
|
15
|
-
set(x) {
|
|
16
|
-
this.re = x.re;
|
|
17
|
-
this.im = x.im;
|
|
18
|
-
}
|
|
19
|
-
setReIm(re, im = 0) {
|
|
20
|
-
this.re = re;
|
|
21
|
-
this.im = im;
|
|
22
|
-
}
|
|
23
|
-
setExpj(arg) {
|
|
24
|
-
this.re = Math.cos(arg);
|
|
25
|
-
this.im = Math.sin(arg);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
this.re
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
this.
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
this.re
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
this.
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
this.re
|
|
43
|
-
this.im
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
this.
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
this.im
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
this.
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
this.im
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
this.
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
1
|
+
import Complex from "./Complex.js";
|
|
2
|
+
export default class MutableComplex extends Complex {
|
|
3
|
+
constructor(re = 0, im = 0) {
|
|
4
|
+
super(re, im);
|
|
5
|
+
}
|
|
6
|
+
static fromComplex(x) {
|
|
7
|
+
return new MutableComplex(x.re, x.im);
|
|
8
|
+
}
|
|
9
|
+
static expj(arg) {
|
|
10
|
+
return new MutableComplex(Math.cos(arg), Math.sin(arg));
|
|
11
|
+
}
|
|
12
|
+
static fromPolar(abs, arg) {
|
|
13
|
+
return new MutableComplex(abs * Math.cos(arg), abs * Math.sin(arg));
|
|
14
|
+
}
|
|
15
|
+
set(x) {
|
|
16
|
+
this.re = x.re;
|
|
17
|
+
this.im = x.im;
|
|
18
|
+
}
|
|
19
|
+
setReIm(re, im = 0) {
|
|
20
|
+
this.re = re;
|
|
21
|
+
this.im = im;
|
|
22
|
+
}
|
|
23
|
+
setExpj(arg) {
|
|
24
|
+
this.re = Math.cos(arg);
|
|
25
|
+
this.im = Math.sin(arg);
|
|
26
|
+
}
|
|
27
|
+
setPolar(abs, arg) {
|
|
28
|
+
this.re = abs * Math.cos(arg);
|
|
29
|
+
this.im = abs * Math.sin(arg);
|
|
30
|
+
}
|
|
31
|
+
addRealTo(x) {
|
|
32
|
+
this.re += x;
|
|
33
|
+
}
|
|
34
|
+
addTo(x) {
|
|
35
|
+
this.re += x.re;
|
|
36
|
+
this.im += x.im;
|
|
37
|
+
}
|
|
38
|
+
subRealFrom(x) {
|
|
39
|
+
this.re -= x;
|
|
40
|
+
}
|
|
41
|
+
subFrom(x) {
|
|
42
|
+
this.re -= x.re;
|
|
43
|
+
this.im -= x.im;
|
|
44
|
+
}
|
|
45
|
+
mulByReal(x) {
|
|
46
|
+
this.re *= x;
|
|
47
|
+
this.im *= x;
|
|
48
|
+
}
|
|
49
|
+
mulBy(x) {
|
|
50
|
+
this.setMul(this.re, this.im, x.re, x.im);
|
|
51
|
+
}
|
|
52
|
+
divByReal(x) {
|
|
53
|
+
this.re /= x;
|
|
54
|
+
this.im /= x;
|
|
55
|
+
}
|
|
56
|
+
divBy(x) {
|
|
57
|
+
this.setDiv(this.re, this.im, x.re, x.im);
|
|
58
|
+
}
|
|
59
|
+
setMul(re1, im1, re2, im2) {
|
|
60
|
+
this.re = re1 * re2 - im1 * im2;
|
|
61
|
+
this.im = re1 * im2 + im1 * re2;
|
|
62
|
+
}
|
|
63
|
+
setDiv(re1, im1, re2, im2) {
|
|
64
|
+
const m = re1 * re1 + im1 * im1;
|
|
65
|
+
this.re = (re1 * re2 + im1 * im2) / m;
|
|
66
|
+
this.im = (im1 * re2 - re1 * im2) / m;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
65
69
|
//# sourceMappingURL=MutableComplex.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MutableComplex.js","sourceRoot":"","sources":["../../src/math/MutableComplex.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,cAAc,CAAC;AAUnC,MAAM,CAAC,OAAO,OAAO,cAAe,SAAQ,OAAO;IAoBhD,YAAoB,KAAa,CAAC,EAAE,KAAa,CAAC;QAC/C,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;IAAC,CAAC;IAOZ,MAAM,CAAC,WAAW,CAAE,CAAU;QAClC,OAAO,IAAI,cAAc,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;IAAC,CAAC;IAMpC,MAAM,CAAU,IAAI,CAAE,GAAW;QACrC,OAAO,IAAI,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;IAAC,CAAC;IAMtD,MAAM,CAAU,SAAS,CAAE,GAAW,EAAE,GAAW;QACvD,OAAO,IAAI,cAAc,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;IAAC,CAAC;IAOlE,GAAG,CAAE,CAAU;QACnB,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC;QACf,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC;IAAC,CAAC;IAKb,OAAO,CAAE,EAAU,EAAE,EAAE,GAAG,CAAC;QAC/B,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;IAAC,CAAC;IAKX,OAAO,CAAE,GAAW;QACxB,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACxB,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"MutableComplex.js","sourceRoot":"","sources":["../../src/math/MutableComplex.ts"],"names":[],"mappings":"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"}
|
package/math/NumApprox.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
export declare function argMax_scanArith(f: (x: number) => number, argLo: number, argHi: number, argIncr: number): number;
|
|
2
|
-
export declare function argMax_scanGeom(f: (x: number) => number, argLo: number, argHi: number, argFactor: number): number;
|
|
3
|
-
export declare function argMax_goldenSectionSearch(f: (x: number) => number, argLo: number, argHi: number, tolerance: number): number;
|
|
1
|
+
export declare function argMax_scanArith(f: (x: number) => number, argLo: number, argHi: number, argIncr: number): number;
|
|
2
|
+
export declare function argMax_scanGeom(f: (x: number) => number, argLo: number, argHi: number, argFactor: number): number;
|
|
3
|
+
export declare function argMax_goldenSectionSearch(f: (x: number) => number, argLo: number, argHi: number, tolerance: number): number;
|
|
4
|
+
//# sourceMappingURL=NumApprox.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NumApprox.d.ts","sourceRoot":"","sources":["../../src/math/NumApprox.ts"],"names":[],"mappings":"AAiBA,wBAAgB,gBAAgB,CAAE,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAI,MAAM,CAYhG;AAiBnB,wBAAgB,eAAe,CAAE,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAI,MAAM,CAYjG;AAiBnB,wBAAgB,0BAA0B,CAAE,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAI,MAAM,CA2BxE"}
|
package/math/NumApprox.js
CHANGED
|
@@ -1,68 +1,68 @@
|
|
|
1
|
-
export function argMax_scanArith(f, argLo, argHi, argIncr) {
|
|
2
|
-
let maxArg = NaN;
|
|
3
|
-
let maxVal = -Infinity;
|
|
4
|
-
let lastArg = NaN;
|
|
5
|
-
for (let x = argLo; x < argHi; x += argIncr) {
|
|
6
|
-
const v = f(x);
|
|
7
|
-
if (v > maxVal) {
|
|
8
|
-
maxArg = x;
|
|
9
|
-
maxVal = v;
|
|
10
|
-
}
|
|
11
|
-
lastArg = x;
|
|
12
|
-
}
|
|
13
|
-
if (lastArg != argHi && argHi > argLo && f(argHi) > maxVal) {
|
|
14
|
-
maxArg = argHi;
|
|
15
|
-
}
|
|
16
|
-
return maxArg;
|
|
17
|
-
}
|
|
18
|
-
export function argMax_scanGeom(f, argLo, argHi, argFactor) {
|
|
19
|
-
let maxArg = NaN;
|
|
20
|
-
let maxVal = -Infinity;
|
|
21
|
-
let lastArg = NaN;
|
|
22
|
-
for (let x = argLo; x < argHi; x *= argFactor) {
|
|
23
|
-
const v = f(x);
|
|
24
|
-
if (v > maxVal) {
|
|
25
|
-
maxArg = x;
|
|
26
|
-
maxVal = v;
|
|
27
|
-
}
|
|
28
|
-
lastArg = x;
|
|
29
|
-
}
|
|
30
|
-
if (lastArg != argHi && argHi > argLo && f(argHi) > maxVal) {
|
|
31
|
-
maxArg = argHi;
|
|
32
|
-
}
|
|
33
|
-
return maxArg;
|
|
34
|
-
}
|
|
35
|
-
export function argMax_goldenSectionSearch(f, argLo, argHi, tolerance) {
|
|
36
|
-
const invPhi = (Math.sqrt(5) - 1) / 2;
|
|
37
|
-
const invPhi2 = 1 - invPhi;
|
|
38
|
-
let lo = argLo;
|
|
39
|
-
let hi = argHi;
|
|
40
|
-
let width = hi - lo;
|
|
41
|
-
let x1 = lo + width * invPhi2;
|
|
42
|
-
let x2 = lo + width * invPhi;
|
|
43
|
-
let y1 = f(x1);
|
|
44
|
-
let y2 = f(x2);
|
|
45
|
-
if (width <= tolerance) {
|
|
46
|
-
return (lo + hi) / 2;
|
|
47
|
-
}
|
|
48
|
-
const n = Math.ceil(Math.log(tolerance / width) / Math.log(invPhi));
|
|
49
|
-
for (let i = 0; i < n; i++) {
|
|
50
|
-
width *= invPhi;
|
|
51
|
-
if (y1 >= y2) {
|
|
52
|
-
hi = x2;
|
|
53
|
-
x2 = x1;
|
|
54
|
-
y2 = y1;
|
|
55
|
-
x1 = lo + width * invPhi2;
|
|
56
|
-
y1 = f(x1);
|
|
57
|
-
}
|
|
58
|
-
else {
|
|
59
|
-
lo = x1;
|
|
60
|
-
x1 = x2;
|
|
61
|
-
y1 = y2;
|
|
62
|
-
x2 = lo + width * invPhi;
|
|
63
|
-
y2 = f(x2);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
return (y1 >= y2) ? (lo + x2) / 2 : (x1 + hi) / 2;
|
|
67
|
-
}
|
|
1
|
+
export function argMax_scanArith(f, argLo, argHi, argIncr) {
|
|
2
|
+
let maxArg = NaN;
|
|
3
|
+
let maxVal = -Infinity;
|
|
4
|
+
let lastArg = NaN;
|
|
5
|
+
for (let x = argLo; x < argHi; x += argIncr) {
|
|
6
|
+
const v = f(x);
|
|
7
|
+
if (v > maxVal) {
|
|
8
|
+
maxArg = x;
|
|
9
|
+
maxVal = v;
|
|
10
|
+
}
|
|
11
|
+
lastArg = x;
|
|
12
|
+
}
|
|
13
|
+
if (lastArg != argHi && argHi > argLo && f(argHi) > maxVal) {
|
|
14
|
+
maxArg = argHi;
|
|
15
|
+
}
|
|
16
|
+
return maxArg;
|
|
17
|
+
}
|
|
18
|
+
export function argMax_scanGeom(f, argLo, argHi, argFactor) {
|
|
19
|
+
let maxArg = NaN;
|
|
20
|
+
let maxVal = -Infinity;
|
|
21
|
+
let lastArg = NaN;
|
|
22
|
+
for (let x = argLo; x < argHi; x *= argFactor) {
|
|
23
|
+
const v = f(x);
|
|
24
|
+
if (v > maxVal) {
|
|
25
|
+
maxArg = x;
|
|
26
|
+
maxVal = v;
|
|
27
|
+
}
|
|
28
|
+
lastArg = x;
|
|
29
|
+
}
|
|
30
|
+
if (lastArg != argHi && argHi > argLo && f(argHi) > maxVal) {
|
|
31
|
+
maxArg = argHi;
|
|
32
|
+
}
|
|
33
|
+
return maxArg;
|
|
34
|
+
}
|
|
35
|
+
export function argMax_goldenSectionSearch(f, argLo, argHi, tolerance) {
|
|
36
|
+
const invPhi = (Math.sqrt(5) - 1) / 2;
|
|
37
|
+
const invPhi2 = 1 - invPhi;
|
|
38
|
+
let lo = argLo;
|
|
39
|
+
let hi = argHi;
|
|
40
|
+
let width = hi - lo;
|
|
41
|
+
let x1 = lo + width * invPhi2;
|
|
42
|
+
let x2 = lo + width * invPhi;
|
|
43
|
+
let y1 = f(x1);
|
|
44
|
+
let y2 = f(x2);
|
|
45
|
+
if (width <= tolerance) {
|
|
46
|
+
return (lo + hi) / 2;
|
|
47
|
+
}
|
|
48
|
+
const n = Math.ceil(Math.log(tolerance / width) / Math.log(invPhi));
|
|
49
|
+
for (let i = 0; i < n; i++) {
|
|
50
|
+
width *= invPhi;
|
|
51
|
+
if (y1 >= y2) {
|
|
52
|
+
hi = x2;
|
|
53
|
+
x2 = x1;
|
|
54
|
+
y2 = y1;
|
|
55
|
+
x1 = lo + width * invPhi2;
|
|
56
|
+
y1 = f(x1);
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
lo = x1;
|
|
60
|
+
x1 = x2;
|
|
61
|
+
y1 = y2;
|
|
62
|
+
x2 = lo + width * invPhi;
|
|
63
|
+
y2 = f(x2);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
return (y1 >= y2) ? (lo + x2) / 2 : (x1 + hi) / 2;
|
|
67
|
+
}
|
|
68
68
|
//# sourceMappingURL=NumApprox.js.map
|
package/math/NumApprox.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NumApprox.js","sourceRoot":"","sources":["../../src/math/NumApprox.ts"],"names":[],"mappings":"AAiBA,MAAM,UAAU,gBAAgB,CAAE,CAAwB,EAAE,KAAa,EAAE,KAAa,EAAE,OAAe;IACtG,IAAI,MAAM,GAAW,GAAG,CAAC;IACzB,IAAI,MAAM,GAAW,CAAC,QAAQ,CAAC;IAC/B,IAAI,OAAO,GAAW,GAAG,CAAC;IAC1B,KAAK,IAAI,CAAC,GAAG,KAAK,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,IAAI,OAAO,EAAE;
|
|
1
|
+
{"version":3,"file":"NumApprox.js","sourceRoot":"","sources":["../../src/math/NumApprox.ts"],"names":[],"mappings":"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"}
|
package/math/PolyReal.d.ts
CHANGED
|
@@ -1,13 +1,14 @@
|
|
|
1
|
-
import Complex from "./Complex.
|
|
2
|
-
export declare function evaluateReal(a: ArrayLike<number>, x: number): number;
|
|
3
|
-
export declare function evaluateComplex(a: ArrayLike<number>, x: Complex): Complex;
|
|
4
|
-
export declare function expand(zeros: ArrayLike<number>): Float64Array;
|
|
5
|
-
export declare function compareEqual(a1: ArrayLike<number>, a2: ArrayLike<number>, eps?: number): boolean;
|
|
6
|
-
export declare function add(a1: ArrayLike<number>, a2: ArrayLike<number>, eps?: number): Float64Array;
|
|
7
|
-
export declare function multiply(a1: ArrayLike<number>, a2: ArrayLike<number>, eps?: number): Float64Array;
|
|
8
|
-
export declare function divide(a1r: ArrayLike<number>, a2r: ArrayLike<number>, eps?: number): Float64Array[];
|
|
9
|
-
export declare function gcd(a1: ArrayLike<number>, a2: ArrayLike<number>, eps?: number): Float64Array;
|
|
10
|
-
export declare function evaluateFractionComplex(f: ArrayLike<number>[], x: Complex): Complex;
|
|
11
|
-
export declare function addFractions(f1: ArrayLike<number>[], f2: ArrayLike<number>[], eps?: number): Float64Array[];
|
|
12
|
-
export declare function multiplyFractions(f1: ArrayLike<number>[], f2: ArrayLike<number>[], eps?: number): Float64Array[];
|
|
13
|
-
export declare function normalizeFraction(f: ArrayLike<number>[], eps?: number): Float64Array[];
|
|
1
|
+
import Complex from "./Complex.ts";
|
|
2
|
+
export declare function evaluateReal(a: ArrayLike<number>, x: number): number;
|
|
3
|
+
export declare function evaluateComplex(a: ArrayLike<number>, x: Complex): Complex;
|
|
4
|
+
export declare function expand(zeros: ArrayLike<number>): Float64Array;
|
|
5
|
+
export declare function compareEqual(a1: ArrayLike<number>, a2: ArrayLike<number>, eps?: number): boolean;
|
|
6
|
+
export declare function add(a1: ArrayLike<number>, a2: ArrayLike<number>, eps?: number): Float64Array;
|
|
7
|
+
export declare function multiply(a1: ArrayLike<number>, a2: ArrayLike<number>, eps?: number): Float64Array;
|
|
8
|
+
export declare function divide(a1r: ArrayLike<number>, a2r: ArrayLike<number>, eps?: number): Float64Array[];
|
|
9
|
+
export declare function gcd(a1: ArrayLike<number>, a2: ArrayLike<number>, eps?: number): Float64Array;
|
|
10
|
+
export declare function evaluateFractionComplex(f: ArrayLike<number>[], x: Complex): Complex;
|
|
11
|
+
export declare function addFractions(f1: ArrayLike<number>[], f2: ArrayLike<number>[], eps?: number): Float64Array[];
|
|
12
|
+
export declare function multiplyFractions(f1: ArrayLike<number>[], f2: ArrayLike<number>[], eps?: number): Float64Array[];
|
|
13
|
+
export declare function normalizeFraction(f: ArrayLike<number>[], eps?: number): Float64Array[];
|
|
14
|
+
//# sourceMappingURL=PolyReal.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PolyReal.d.ts","sourceRoot":"","sources":["../../src/math/PolyReal.ts"],"names":[],"mappings":"AAgBA,OAAO,OAAO,MAAM,cAAc,CAAC;AAanC,wBAAgB,YAAY,CAAE,CAAC,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,MAAM,GAAI,MAAM,CAQzD;AAYd,wBAAgB,eAAe,CAAE,CAAC,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,OAAO,GAAI,OAAO,CAQ9D;AAKd,wBAAgB,MAAM,CAAE,KAAK,EAAE,SAAS,CAAC,MAAM,CAAC,GAAI,YAAY,CAQlD;AAKd,wBAAgB,YAAY,CAAE,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,SAAI,GAAI,OAAO,CAS7E;AAKjB,wBAAgB,GAAG,CAAE,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,SAAI,GAAI,YAAY,CAShE;AAK1B,wBAAgB,QAAQ,CAAE,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,SAAI,GAAI,YAAY,CAgBrE;AAM1B,wBAAgB,MAAM,CAAE,GAAG,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,SAAI,GAAI,YAAY,EAAE,CAwB/D;AAKlC,wBAAgB,GAAG,CAAE,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,SAAI,GAAI,YAAY,CAe1E;AA+ChB,wBAAgB,uBAAuB,CAAE,CAAC,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,EAAE,OAAO,GAAI,OAAO,CAG/D;AAKvB,wBAAgB,YAAY,CAAE,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,SAAI,GAAI,YAAY,EAAE,CAkB/E;AAK1B,wBAAgB,iBAAiB,CAAE,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,SAAI,GAAI,YAAY,EAAE,CAGpF;AAK1B,wBAAgB,iBAAiB,CAAE,CAAC,EAAE,SAAS,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,SAAI,GAAI,YAAY,EAAE,CAQ1D"}
|