@jtarrio/webrtlsdr 1.1.1 → 2.0.0-pre1

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 (49) hide show
  1. package/dist/demod/demod-am.d.ts +45 -0
  2. package/dist/demod/demod-am.d.ts.map +1 -0
  3. package/dist/demod/{scheme-am.js → demod-am.js} +36 -3
  4. package/dist/demod/demod-am.js.map +1 -0
  5. package/dist/demod/demod-cw.d.ts +36 -0
  6. package/dist/demod/demod-cw.d.ts.map +1 -0
  7. package/dist/demod/{scheme-cw.js → demod-cw.js} +30 -2
  8. package/dist/demod/demod-cw.js.map +1 -0
  9. package/dist/demod/demod-nbfm.d.ts +45 -0
  10. package/dist/demod/demod-nbfm.d.ts.map +1 -0
  11. package/dist/demod/{scheme-nbfm.js → demod-nbfm.js} +36 -3
  12. package/dist/demod/demod-nbfm.js.map +1 -0
  13. package/dist/demod/demod-ssb.d.ts +45 -0
  14. package/dist/demod/demod-ssb.d.ts.map +1 -0
  15. package/dist/demod/{scheme-ssb.js → demod-ssb.js} +36 -4
  16. package/dist/demod/demod-ssb.js.map +1 -0
  17. package/dist/demod/demod-wbfm.d.ts +95 -0
  18. package/dist/demod/demod-wbfm.d.ts.map +1 -0
  19. package/dist/demod/demod-wbfm.js +205 -0
  20. package/dist/demod/demod-wbfm.js.map +1 -0
  21. package/dist/demod/demodulator.d.ts +2 -62
  22. package/dist/demod/demodulator.d.ts.map +1 -1
  23. package/dist/demod/demodulator.js +15 -137
  24. package/dist/demod/demodulator.js.map +1 -1
  25. package/dist/demod/empty-demodulator.d.ts +62 -0
  26. package/dist/demod/empty-demodulator.d.ts.map +1 -0
  27. package/dist/demod/empty-demodulator.js +145 -0
  28. package/dist/demod/empty-demodulator.js.map +1 -0
  29. package/dist/demod/modes.d.ts +76 -65
  30. package/dist/demod/modes.d.ts.map +1 -1
  31. package/dist/demod/modes.js +59 -99
  32. package/dist/demod/modes.js.map +1 -1
  33. package/package.json +1 -1
  34. package/dist/demod/scheme-am.d.ts +0 -32
  35. package/dist/demod/scheme-am.d.ts.map +0 -1
  36. package/dist/demod/scheme-am.js.map +0 -1
  37. package/dist/demod/scheme-cw.d.ts +0 -22
  38. package/dist/demod/scheme-cw.d.ts.map +0 -1
  39. package/dist/demod/scheme-cw.js.map +0 -1
  40. package/dist/demod/scheme-nbfm.d.ts +0 -32
  41. package/dist/demod/scheme-nbfm.d.ts.map +0 -1
  42. package/dist/demod/scheme-nbfm.js.map +0 -1
  43. package/dist/demod/scheme-ssb.d.ts +0 -33
  44. package/dist/demod/scheme-ssb.d.ts.map +0 -1
  45. package/dist/demod/scheme-ssb.js.map +0 -1
  46. package/dist/demod/scheme-wbfm.d.ts +0 -38
  47. package/dist/demod/scheme-wbfm.d.ts.map +0 -1
  48. package/dist/demod/scheme-wbfm.js +0 -106
  49. package/dist/demod/scheme-wbfm.js.map +0 -1
@@ -1,32 +0,0 @@
1
- import { Demodulated, Mode, ModulationScheme } from "./modes";
2
- /** A demodulator for narrowband FM signals. */
3
- export declare class SchemeNBFM implements ModulationScheme {
4
- private outRate;
5
- private mode;
6
- /**
7
- * @param inRate The sample rate of the input samples.
8
- * @param outRate The sample rate of the output audio.
9
- * @param maxF The frequency shift for maximum amplitude.
10
- */
11
- constructor(inRate: number, outRate: number, mode: Mode & {
12
- scheme: "NBFM";
13
- });
14
- private shifter;
15
- private downsampler;
16
- private filterI;
17
- private filterQ;
18
- private demodulator;
19
- getMode(): Mode;
20
- setMode(mode: Mode & {
21
- scheme: "NBFM";
22
- }): void;
23
- /**
24
- * Demodulates the signal.
25
- * @param samplesI The I components of the samples.
26
- * @param samplesQ The Q components of the samples.
27
- * @param freqOffset The offset of the signal in the samples.
28
- * @returns The demodulated audio signal.
29
- */
30
- demodulate(samplesI: Float32Array, samplesQ: Float32Array, freqOffset: number): Demodulated;
31
- }
32
- //# sourceMappingURL=scheme-nbfm.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"scheme-nbfm.d.ts","sourceRoot":"","sources":["../../src/demod/scheme-nbfm.ts"],"names":[],"mappings":"AAmBA,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE9D,+CAA+C;AAC/C,qBAAa,UAAW,YAAW,gBAAgB;IAQ/C,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,IAAI;IARd;;;;OAIG;gBAED,MAAM,EAAE,MAAM,EACN,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,IAAI,GAAG;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE;IAUzC,OAAO,CAAC,OAAO,CAAmB;IAClC,OAAO,CAAC,WAAW,CAAqB;IACxC,OAAO,CAAC,OAAO,CAAY;IAC3B,OAAO,CAAC,OAAO,CAAY;IAC3B,OAAO,CAAC,WAAW,CAAgB;IAEnC,OAAO,IAAI,IAAI;IAIf,OAAO,CAAC,IAAI,EAAE,IAAI,GAAG;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE;IAQvC;;;;;;OAMG;IACH,UAAU,CACR,QAAQ,EAAE,YAAY,EACtB,QAAQ,EAAE,YAAY,EACtB,UAAU,EAAE,MAAM,GACjB,WAAW;CAef"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"scheme-nbfm.js","sourceRoot":"","sources":["../../src/demod/scheme-nbfm.ts"],"names":[],"mappings":"AAAA,kDAAkD;AAClD,EAAE;AACF,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,iDAAiD;AACjD,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;AAEjC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAC7D,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAGvD,+CAA+C;AAC/C,MAAM,OAAO,UAAU;IAQX;IACA;IARV;;;;OAIG;IACH,YACE,MAAc,EACN,OAAe,EACf,IAA+B;QAD/B,YAAO,GAAP,OAAO,CAAQ;QACf,SAAI,GAAJ,IAAI,CAA2B;QAEvC,IAAI,CAAC,OAAO,GAAG,IAAI,gBAAgB,CAAC,MAAM,CAAC,CAAC;QAC5C,IAAI,CAAC,WAAW,GAAG,IAAI,kBAAkB,CAAC,MAAM,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC;QAChE,MAAM,MAAM,GAAG,iBAAiB,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC1D,IAAI,CAAC,OAAO,GAAG,IAAI,SAAS,CAAC,MAAM,CAAC,CAAC;QACrC,IAAI,CAAC,OAAO,GAAG,IAAI,SAAS,CAAC,MAAM,CAAC,CAAC;QACrC,IAAI,CAAC,WAAW,GAAG,IAAI,aAAa,CAAC,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,CAAC;IAC5D,CAAC;IAEO,OAAO,CAAmB;IAC1B,WAAW,CAAqB;IAChC,OAAO,CAAY;IACnB,OAAO,CAAY;IACnB,WAAW,CAAgB;IAEnC,OAAO;QACL,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,OAAO,CAAC,IAA+B;QACrC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,MAAM,MAAM,GAAG,iBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC/D,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;QACrC,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;QACrC,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC;IAC7D,CAAC;IAED;;;;;;OAMG;IACH,UAAU,CACR,QAAsB,EACtB,QAAsB,EACtB,UAAkB;QAElB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE,QAAQ,EAAE,CAAC,UAAU,CAAC,CAAC;QACtD,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAC/D,IAAI,QAAQ,GAAG,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QACxB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QACxB,IAAI,WAAW,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;QACzE,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACrC,OAAO;YACL,IAAI,EAAE,CAAC;YACP,KAAK,EAAE,IAAI,YAAY,CAAC,CAAC,CAAC;YAC1B,MAAM,EAAE,KAAK;YACb,GAAG,EAAE,WAAW,GAAG,QAAQ;SAC5B,CAAC;IACJ,CAAC;CACF"}
@@ -1,33 +0,0 @@
1
- import { Demodulated, Mode, ModulationScheme } from "./modes";
2
- /** A demodulator for single-sideband modulated signals. */
3
- export declare class SchemeSSB implements ModulationScheme {
4
- private outRate;
5
- private mode;
6
- /**
7
- * @param inRate The sample rate of the input samples.
8
- * @param outRate The sample rate of the output audio.
9
- * @param bandwidth The bandwidth of the input signal.
10
- * @param upper Whether to demodulate the upper sideband (lower otherwise).
11
- */
12
- constructor(inRate: number, outRate: number, mode: Mode & {
13
- scheme: "USB" | "LSB";
14
- });
15
- private shifter;
16
- private downsampler;
17
- private filter;
18
- private demodulator;
19
- private agc;
20
- getMode(): Mode;
21
- setMode(mode: Mode & {
22
- scheme: "USB" | "LSB";
23
- }): void;
24
- /**
25
- * Demodulates the signal.
26
- * @param samplesI The I components of the samples.
27
- * @param samplesQ The Q components of the samples.
28
- * @param freqOffset The offset of the signal in the samples.
29
- * @returns The demodulated audio signal.
30
- */
31
- demodulate(samplesI: Float32Array, samplesQ: Float32Array, freqOffset: number): Demodulated;
32
- }
33
- //# sourceMappingURL=scheme-ssb.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"scheme-ssb.d.ts","sourceRoot":"","sources":["../../src/demod/scheme-ssb.ts"],"names":[],"mappings":"AAmBA,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE9D,2DAA2D;AAC3D,qBAAa,SAAU,YAAW,gBAAgB;IAS9C,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,IAAI;IATd;;;;;OAKG;gBAED,MAAM,EAAE,MAAM,EACN,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,IAAI,GAAG;QAAE,MAAM,EAAE,KAAK,GAAG,KAAK,CAAA;KAAE;IAYhD,OAAO,CAAC,OAAO,CAAmB;IAClC,OAAO,CAAC,WAAW,CAAqB;IACxC,OAAO,CAAC,MAAM,CAAY;IAC1B,OAAO,CAAC,WAAW,CAAiB;IACpC,OAAO,CAAC,GAAG,CAAM;IAEjB,OAAO,IAAI,IAAI;IAIf,OAAO,CAAC,IAAI,EAAE,IAAI,GAAG;QAAE,MAAM,EAAE,KAAK,GAAG,KAAK,CAAA;KAAE;IAM9C;;;;;;OAMG;IACH,UAAU,CACR,QAAQ,EAAE,YAAY,EACtB,QAAQ,EAAE,YAAY,EACtB,UAAU,EAAE,MAAM,GACjB,WAAW;CAgBf"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"scheme-ssb.js","sourceRoot":"","sources":["../../src/demod/scheme-ssb.ts"],"names":[],"mappings":"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"}
@@ -1,38 +0,0 @@
1
- import { Demodulated, Mode, ModulationScheme } from "./modes";
2
- /** A demodulator for wideband FM signals. */
3
- export declare class SchemeWBFM implements ModulationScheme {
4
- private mode;
5
- /**
6
- * @param inRate The sample rate of the input samples.
7
- * @param outRate The sample rate of the output audio.
8
- * @param stereo Whether to try to demodulate a stereo signal, if present.
9
- */
10
- constructor(inRate: number, outRate: number, mode: Mode & {
11
- scheme: "WBFM";
12
- });
13
- private interRate;
14
- private shifter;
15
- private downsampler?;
16
- private filterI;
17
- private filterQ;
18
- private demodulator;
19
- private monoSampler;
20
- private stereoSampler;
21
- private stereoSeparator;
22
- private leftDeemph;
23
- private rightDeemph;
24
- getMode(): Mode;
25
- setMode(mode: Mode & {
26
- scheme: "WBFM";
27
- }): void;
28
- /**
29
- * Demodulates the signal.
30
- * @param samplesI The I components of the samples.
31
- * @param samplesQ The Q components of the samples.
32
- * @param freqOffset The offset of the signal in the samples.
33
- * @param inStereo Whether to try decoding the stereo signal.
34
- * @returns The demodulated audio signal.
35
- */
36
- demodulate(samplesI: Float32Array, samplesQ: Float32Array, freqOffset: number): Demodulated;
37
- }
38
- //# sourceMappingURL=scheme-wbfm.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"scheme-wbfm.d.ts","sourceRoot":"","sources":["../../src/demod/scheme-wbfm.ts"],"names":[],"mappings":"AAmBA,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE9D,6CAA6C;AAC7C,qBAAa,UAAW,YAAW,gBAAgB;IAS/C,OAAO,CAAC,IAAI;IARd;;;;OAIG;gBAED,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,MAAM,EACP,IAAI,EAAE,IAAI,GAAG;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE;IAqBzC,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,OAAO,CAAmB;IAClC,OAAO,CAAC,WAAW,CAAC,CAAqB;IACzC,OAAO,CAAC,OAAO,CAAY;IAC3B,OAAO,CAAC,OAAO,CAAY;IAC3B,OAAO,CAAC,WAAW,CAAgB;IACnC,OAAO,CAAC,WAAW,CAAkB;IACrC,OAAO,CAAC,aAAa,CAAkB;IACvC,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,UAAU,CAAe;IACjC,OAAO,CAAC,WAAW,CAAe;IAElC,OAAO,IAAI,IAAI;IAIf,OAAO,CAAC,IAAI,EAAE,IAAI,GAAG;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE;IAIvC;;;;;;;OAOG;IACH,UAAU,CACR,QAAQ,EAAE,YAAY,EACtB,QAAQ,EAAE,YAAY,EACtB,UAAU,EAAE,MAAM,GACjB,WAAW;CAmCf"}
@@ -1,106 +0,0 @@
1
- // Copyright 2013 Google Inc. All rights reserved.
2
- //
3
- // Licensed under the Apache License, Version 2.0 (the "License");
4
- // you may not use this file except in compliance with the License.
5
- // You may obtain a copy of the License at
6
- //
7
- // http://www.apache.org/licenses/LICENSE-2.0
8
- //
9
- // Unless required by applicable law or agreed to in writing, software
10
- // distributed under the License is distributed on an "AS IS" BASIS,
11
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
- // See the License for the specific language governing permissions and
13
- // limitations under the License.
14
- import { makeLowPassKernel } from "../dsp/coefficients";
15
- import { FMDemodulator, StereoSeparator } from "../dsp/demodulators";
16
- import { FrequencyShifter, Deemphasizer, FIRFilter } from "../dsp/filters";
17
- import { getPower } from "../dsp/power";
18
- import { ComplexDownsampler, RealDownsampler } from "../dsp/resamplers";
19
- /** A demodulator for wideband FM signals. */
20
- export class SchemeWBFM {
21
- mode;
22
- /**
23
- * @param inRate The sample rate of the input samples.
24
- * @param outRate The sample rate of the output audio.
25
- * @param stereo Whether to try to demodulate a stereo signal, if present.
26
- */
27
- constructor(inRate, outRate, mode) {
28
- this.mode = mode;
29
- const maxF = 75000;
30
- const pilotF = 19000;
31
- const deemphTc = 50;
32
- this.interRate = Math.min(inRate, 336000);
33
- this.shifter = new FrequencyShifter(inRate);
34
- if (this.interRate != inRate) {
35
- this.downsampler = new ComplexDownsampler(inRate, this.interRate, 151);
36
- }
37
- const kernel = makeLowPassKernel(this.interRate, maxF, 151);
38
- this.filterI = new FIRFilter(kernel);
39
- this.filterQ = new FIRFilter(kernel);
40
- this.demodulator = new FMDemodulator(maxF / this.interRate);
41
- this.monoSampler = new RealDownsampler(this.interRate, outRate, 41);
42
- this.stereoSampler = new RealDownsampler(this.interRate, outRate, 41);
43
- this.stereoSeparator = new StereoSeparator(this.interRate, pilotF);
44
- this.leftDeemph = new Deemphasizer(outRate, deemphTc);
45
- this.rightDeemph = new Deemphasizer(outRate, deemphTc);
46
- }
47
- interRate;
48
- shifter;
49
- downsampler;
50
- filterI;
51
- filterQ;
52
- demodulator;
53
- monoSampler;
54
- stereoSampler;
55
- stereoSeparator;
56
- leftDeemph;
57
- rightDeemph;
58
- getMode() {
59
- return this.mode;
60
- }
61
- setMode(mode) {
62
- this.mode = mode;
63
- }
64
- /**
65
- * Demodulates the signal.
66
- * @param samplesI The I components of the samples.
67
- * @param samplesQ The Q components of the samples.
68
- * @param freqOffset The offset of the signal in the samples.
69
- * @param inStereo Whether to try decoding the stereo signal.
70
- * @returns The demodulated audio signal.
71
- */
72
- demodulate(samplesI, samplesQ, freqOffset) {
73
- this.shifter.inPlace(samplesI, samplesQ, -freqOffset);
74
- let [I, Q] = this.downsampler
75
- ? this.downsampler.downsample(samplesI, samplesQ)
76
- : [samplesI, samplesQ];
77
- let allPower = getPower(I, Q);
78
- this.filterI.inPlace(I);
79
- this.filterQ.inPlace(Q);
80
- let signalPower = (getPower(I, Q) * this.interRate) / 150000;
81
- this.demodulator.demodulate(I, Q, I);
82
- const leftAudio = this.monoSampler.downsample(I);
83
- const rightAudio = new Float32Array(leftAudio);
84
- let stereoOut = false;
85
- if (this.mode.stereo) {
86
- const stereo = this.stereoSeparator.separate(I);
87
- if (stereo.found) {
88
- stereoOut = true;
89
- const diffAudio = this.stereoSampler.downsample(stereo.diff);
90
- for (let i = 0; i < diffAudio.length; ++i) {
91
- rightAudio[i] -= diffAudio[i];
92
- leftAudio[i] += diffAudio[i];
93
- }
94
- }
95
- }
96
- this.leftDeemph.inPlace(leftAudio);
97
- this.rightDeemph.inPlace(rightAudio);
98
- return {
99
- left: leftAudio,
100
- right: rightAudio,
101
- stereo: stereoOut,
102
- snr: signalPower / allPower,
103
- };
104
- }
105
- }
106
- //# sourceMappingURL=scheme-wbfm.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"scheme-wbfm.js","sourceRoot":"","sources":["../../src/demod/scheme-wbfm.ts"],"names":[],"mappings":"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"}