speechrecorderng 3.10.13 → 3.11.0

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 (99) hide show
  1. package/README.md +1 -1
  2. package/fesm2022/speechrecorderng.mjs +204 -201
  3. package/fesm2022/speechrecorderng.mjs.map +1 -1
  4. package/lib/audio/ui/audio_canvas_layer_comp.d.ts +2 -2
  5. package/lib/spr.module.version.d.ts +1 -1
  6. package/lib/ui/canvas_layer_comp.d.ts +1 -1
  7. package/lib/ui/responsive_component.d.ts +1 -1
  8. package/package.json +13 -15
  9. package/esm2022/lib/action/action.mjs +0 -73
  10. package/esm2022/lib/audio/array_audio_buffer.mjs +0 -164
  11. package/esm2022/lib/audio/array_audio_buffer_input_stream.mjs +0 -86
  12. package/esm2022/lib/audio/array_audio_buffer_random_access_stream.mjs +0 -16
  13. package/esm2022/lib/audio/audio_data_holder.mjs +0 -264
  14. package/esm2022/lib/audio/audio_display.mjs +0 -118
  15. package/esm2022/lib/audio/audio_player.mjs +0 -238
  16. package/esm2022/lib/audio/capture/capture.mjs +0 -855
  17. package/esm2022/lib/audio/context.mjs +0 -79
  18. package/esm2022/lib/audio/dsp/level_measure.mjs +0 -517
  19. package/esm2022/lib/audio/format.mjs +0 -20
  20. package/esm2022/lib/audio/impl/wavformat.mjs +0 -7
  21. package/esm2022/lib/audio/impl/wavreader.mjs +0 -144
  22. package/esm2022/lib/audio/impl/wavwriter.mjs +0 -191
  23. package/esm2022/lib/audio/inddb_audio_buffer.mjs +0 -508
  24. package/esm2022/lib/audio/io/stream.mjs +0 -59
  25. package/esm2022/lib/audio/net_audio_buffer.mjs +0 -293
  26. package/esm2022/lib/audio/persistor.mjs +0 -81
  27. package/esm2022/lib/audio/playback/array_audio_buffer_source_node.mjs +0 -126
  28. package/esm2022/lib/audio/playback/audio_source_node.mjs +0 -18
  29. package/esm2022/lib/audio/playback/audio_source_worklet_module_loader.mjs +0 -167
  30. package/esm2022/lib/audio/playback/inddb_audio_buffer_source_node.mjs +0 -167
  31. package/esm2022/lib/audio/playback/net_audio_buffer_source_node.mjs +0 -218
  32. package/esm2022/lib/audio/playback/player.mjs +0 -402
  33. package/esm2022/lib/audio/ui/audio_canvas_layer_comp.mjs +0 -347
  34. package/esm2022/lib/audio/ui/audio_display_control.mjs +0 -150
  35. package/esm2022/lib/audio/ui/audio_display_scroll_pane.mjs +0 -146
  36. package/esm2022/lib/audio/ui/audiosignal.mjs +0 -533
  37. package/esm2022/lib/audio/ui/common.mjs +0 -19
  38. package/esm2022/lib/audio/ui/container.mjs +0 -414
  39. package/esm2022/lib/audio/ui/livelevel.mjs +0 -361
  40. package/esm2022/lib/audio/ui/scroll_pane_horizontal.mjs +0 -11
  41. package/esm2022/lib/audio/ui/sonagram.mjs +0 -900
  42. package/esm2022/lib/db/inddb.mjs +0 -120
  43. package/esm2022/lib/dsp/utils.mjs +0 -48
  44. package/esm2022/lib/environment/environment.defaults.mjs +0 -9
  45. package/esm2022/lib/io/BinaryReader.mjs +0 -93
  46. package/esm2022/lib/io/BinaryWriter.mjs +0 -80
  47. package/esm2022/lib/io/stream.mjs +0 -259
  48. package/esm2022/lib/math/2d/geometry.mjs +0 -28
  49. package/esm2022/lib/math/complex.mjs +0 -58
  50. package/esm2022/lib/math/dft.mjs +0 -196
  51. package/esm2022/lib/media/utils.mjs +0 -14
  52. package/esm2022/lib/net/uploader.mjs +0 -367
  53. package/esm2022/lib/recorder_component.mjs +0 -65
  54. package/esm2022/lib/speechrecorder/project/project.mjs +0 -54
  55. package/esm2022/lib/speechrecorder/project/project.service.mjs +0 -64
  56. package/esm2022/lib/speechrecorder/recording.mjs +0 -124
  57. package/esm2022/lib/speechrecorder/recordings/basic_recording.service.mjs +0 -221
  58. package/esm2022/lib/speechrecorder/recordings/recordings.service.mjs +0 -1014
  59. package/esm2022/lib/speechrecorder/script/script.mjs +0 -114
  60. package/esm2022/lib/speechrecorder/script/script.service.mjs +0 -47
  61. package/esm2022/lib/speechrecorder/session/audiorecorder.mjs +0 -1179
  62. package/esm2022/lib/speechrecorder/session/basicrecorder.mjs +0 -676
  63. package/esm2022/lib/speechrecorder/session/controlpanel.mjs +0 -416
  64. package/esm2022/lib/speechrecorder/session/item.mjs +0 -30
  65. package/esm2022/lib/speechrecorder/session/progress.mjs +0 -135
  66. package/esm2022/lib/speechrecorder/session/prompting.mjs +0 -639
  67. package/esm2022/lib/speechrecorder/session/recorder_combi_pane.mjs +0 -88
  68. package/esm2022/lib/speechrecorder/session/recording_file_cache.mjs +0 -195
  69. package/esm2022/lib/speechrecorder/session/recording_list.mjs +0 -188
  70. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +0 -128
  71. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-navi.component.mjs +0 -114
  72. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +0 -146
  73. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +0 -424
  74. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file.mjs +0 -68
  75. package/esm2022/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +0 -288
  76. package/esm2022/lib/speechrecorder/session/session.mjs +0 -2
  77. package/esm2022/lib/speechrecorder/session/session.service.mjs +0 -69
  78. package/esm2022/lib/speechrecorder/session/session_finished_dialog.mjs +0 -46
  79. package/esm2022/lib/speechrecorder/session/sessionmanager.mjs +0 -1385
  80. package/esm2022/lib/speechrecorder/session/warning_bar.mjs +0 -33
  81. package/esm2022/lib/speechrecorder/spruploader.mjs +0 -22
  82. package/esm2022/lib/speechrecorder/startstopsignal/startstopsignal.mjs +0 -2
  83. package/esm2022/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.mjs +0 -57
  84. package/esm2022/lib/speechrecorderng.component.mjs +0 -392
  85. package/esm2022/lib/speechrecorderng.module.mjs +0 -97
  86. package/esm2022/lib/spr.config.mjs +0 -27
  87. package/esm2022/lib/spr.module.version.mjs +0 -2
  88. package/esm2022/lib/ui/canvas_layer_comp.mjs +0 -38
  89. package/esm2022/lib/ui/intersection-observer.directive.mjs +0 -32
  90. package/esm2022/lib/ui/message_dialog.mjs +0 -51
  91. package/esm2022/lib/ui/recordingitem_display.mjs +0 -253
  92. package/esm2022/lib/ui/responsive_component.mjs +0 -24
  93. package/esm2022/lib/utils/scrollIntoViewToBottom.mjs +0 -23
  94. package/esm2022/lib/utils/ua-parser.mjs +0 -190
  95. package/esm2022/lib/utils/utils.mjs +0 -132
  96. package/esm2022/lib/utils/wake_lock.mjs +0 -114
  97. package/esm2022/lib/utils/wake_lock_media.mjs +0 -2
  98. package/esm2022/public-api.mjs +0 -35
  99. package/esm2022/speechrecorderng.mjs +0 -5
@@ -1,259 +0,0 @@
1
- import { Observable } from "rxjs";
2
- export class EditFloat32ArrayInputStream {
3
- constructor(_srcInputStream, offset = 0, length) {
4
- this._srcInputStream = _srcInputStream;
5
- this.offset = offset;
6
- this.length = length;
7
- this.framePos = 0;
8
- this.readFrames = 0;
9
- if (this.offset < 0) {
10
- throw Error('Parameter offset must be undefined or greater or equal zero.');
11
- }
12
- if (this.length !== undefined && this.length < 0) {
13
- throw Error('Parameter length must be undefined or greater or equal zero.');
14
- }
15
- }
16
- skipToOffset() {
17
- if (this.framePos == 0 && this.offset > 0) {
18
- this._srcInputStream.skipFrames(this.offset);
19
- this.framePos += this.offset;
20
- }
21
- }
22
- read(buffers) {
23
- this.skipToOffset();
24
- let read = 0;
25
- if (this.length === undefined) {
26
- read = this._srcInputStream.read(buffers);
27
- }
28
- else {
29
- if (buffers.length > 0) {
30
- let bufsCh0 = buffers[0];
31
- let bufsLen = bufsCh0.length;
32
- let avail = this.length - this.readFrames;
33
- if (avail > 0) {
34
- if (avail > bufsLen) {
35
- read = this._srcInputStream.read(buffers);
36
- }
37
- else {
38
- // temporary buffers required
39
- let tmpBufs = new Array(buffers.length);
40
- for (let ch = 0; ch < buffers.length; ch++) {
41
- tmpBufs[ch] = new Float32Array(avail);
42
- }
43
- read = this._srcInputStream.read(tmpBufs);
44
- for (let ch = 0; ch < buffers.length; ch++) {
45
- buffers[ch].set(tmpBufs[ch]);
46
- }
47
- }
48
- }
49
- }
50
- }
51
- this.readFrames += read;
52
- this.framePos += read;
53
- return read;
54
- }
55
- skipFrames(n) {
56
- this.skipToOffset();
57
- if (this.length === undefined) {
58
- this._srcInputStream.skipFrames(n);
59
- }
60
- else {
61
- let avail = this.length - this.readFrames;
62
- if (avail > 0) {
63
- if (avail >= n) {
64
- this._srcInputStream.skipFrames(n);
65
- this.readFrames += n;
66
- this.framePos += n;
67
- }
68
- else {
69
- throw Error('Tried to skip out of bounds.');
70
- }
71
- }
72
- }
73
- }
74
- close() {
75
- this._srcInputStream.close();
76
- }
77
- }
78
- export class AsyncEditFloat32ArrayInputStream {
79
- constructor(_srcInputStream, offset = 0, length) {
80
- this._srcInputStream = _srcInputStream;
81
- this.offset = offset;
82
- this.length = length;
83
- this.framePos = 0;
84
- this.readFrames = 0;
85
- if (this.offset < 0) {
86
- throw Error('Parameter offset must be undefined or greater or equal zero.');
87
- }
88
- if (this.length !== undefined && this.length < 0) {
89
- throw Error('Parameter length must be undefined or greater or equal zero.');
90
- }
91
- }
92
- skipToOffset() {
93
- if (this.framePos == 0 && this.offset > 0) {
94
- this._srcInputStream.skipFrames(this.offset);
95
- this.framePos += this.offset;
96
- }
97
- }
98
- readObs(buffers) {
99
- return new Observable(subscriber => {
100
- this.skipToOffset();
101
- if (this.length === undefined) {
102
- this._srcInputStream.readObs(buffers).subscribe(subscriber);
103
- }
104
- else {
105
- if (buffers.length > 0) {
106
- let bufsCh0 = buffers[0];
107
- let bufsLen = bufsCh0.length;
108
- let avail = this.length - this.readFrames;
109
- if (avail > 0) {
110
- if (avail > bufsLen) {
111
- this._srcInputStream.readObs(buffers).subscribe({
112
- next: (read) => {
113
- this.readFrames += read;
114
- this.framePos += read;
115
- subscriber.next(read);
116
- }, complete: () => {
117
- subscriber.complete();
118
- }
119
- });
120
- }
121
- else {
122
- // temporary buffers required
123
- let tmpBufs = new Array(buffers.length);
124
- for (let ch = 0; ch < buffers.length; ch++) {
125
- tmpBufs[ch] = new Float32Array(avail);
126
- }
127
- this._srcInputStream.readObs(tmpBufs).subscribe({
128
- next: (read) => {
129
- for (let ch = 0; ch < buffers.length; ch++) {
130
- buffers[ch].set(tmpBufs[ch]);
131
- }
132
- this.readFrames += read;
133
- this.framePos += read;
134
- subscriber.next(read);
135
- }, complete: () => {
136
- subscriber.complete();
137
- }
138
- });
139
- }
140
- }
141
- else {
142
- // end of stream
143
- subscriber.next(0);
144
- subscriber.complete();
145
- }
146
- }
147
- else {
148
- subscriber.next(0);
149
- subscriber.complete();
150
- }
151
- }
152
- });
153
- }
154
- skipFrames(n) {
155
- this.skipToOffset();
156
- if (this.length === undefined) {
157
- this._srcInputStream.skipFrames(n);
158
- }
159
- else {
160
- let avail = this.length - this.readFrames;
161
- if (avail > 0) {
162
- if (avail >= n) {
163
- this._srcInputStream.skipFrames(n);
164
- this.readFrames += n;
165
- this.framePos += n;
166
- }
167
- else {
168
- throw Error('Tried to skip out of bounds.');
169
- }
170
- }
171
- }
172
- }
173
- close() {
174
- this._srcInputStream.close();
175
- }
176
- }
177
- export class Float32ArrayChunkerOutStream {
178
- constructor(outStream) {
179
- this.outStream = outStream;
180
- this.bufs = new Array();
181
- this._channels = 0;
182
- this._chunkSize = 0;
183
- this.filled = 0;
184
- this.receivedFrames = 0;
185
- this.sentFrames = 0;
186
- }
187
- createBuffers() {
188
- this.bufs = new Array(this._channels);
189
- for (let ch = 0; ch < this._channels; ch++) {
190
- this.bufs[ch] = new Float32Array(this._chunkSize);
191
- }
192
- }
193
- set chunkSize(chunkSize) {
194
- this._chunkSize = chunkSize;
195
- this.createBuffers();
196
- }
197
- get chunkSize() {
198
- return this._chunkSize;
199
- }
200
- set channels(channels) {
201
- this._channels = channels;
202
- this.createBuffers();
203
- }
204
- get channels() {
205
- return this._channels;
206
- }
207
- available() {
208
- return this._chunkSize - this.filled;
209
- }
210
- write(buffers) {
211
- let copied = 0;
212
- if (buffers.length > 0) {
213
- let buffersLen = buffers[0].length;
214
- this.receivedFrames += buffersLen;
215
- let avail = buffersLen;
216
- // Fill out buffers until all values copied
217
- while (avail > 0) {
218
- let toFill = this._chunkSize - this.filled;
219
- if (toFill > avail) {
220
- toFill = avail;
221
- }
222
- let sliceEnd = copied + toFill;
223
- // Firefox on Android sends only the first channel
224
- for (let ch = 0; ch < buffersLen; ch++) {
225
- if (buffers[ch]) {
226
- let cpPrt = buffers[ch].slice(copied, sliceEnd);
227
- let buf = this.bufs[ch];
228
- buf.set(cpPrt, this.filled);
229
- }
230
- }
231
- copied += toFill;
232
- avail -= toFill;
233
- this.filled += toFill;
234
- if (this.filled == this._chunkSize) {
235
- this.outStream.write(this.bufs);
236
- this.sentFrames += this.filled;
237
- this.filled = 0;
238
- }
239
- }
240
- }
241
- return copied;
242
- }
243
- flush() {
244
- if (this.filled > 0) {
245
- let restBufs = new Array(this._channels);
246
- for (let ch = 0; ch < this._channels; ch++) {
247
- restBufs[ch] = this.bufs[ch].slice(0, this.filled);
248
- }
249
- this.outStream.write(restBufs);
250
- this.outStream.flush();
251
- this.sentFrames += this.filled;
252
- this.filled = 0;
253
- }
254
- }
255
- close() {
256
- this.outStream.close();
257
- }
258
- }
259
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stream.js","sourceRoot":"","sources":["../../../../../projects/speechrecorderng/src/lib/io/stream.ts"],"names":[],"mappings":"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","sourcesContent":["import {Observable} from \"rxjs\";\r\n\r\nexport interface Float32ArrayInputStream{\r\n  read(buffers: Array<Float32Array>): number;\r\n  skipFrames(n:number):void;\r\n  close():void;\r\n}\r\n\r\nexport interface AsyncFloat32ArrayInputStream{\r\n  readObs(buffers: Array<Float32Array>):Observable<number>;\r\n  skipFrames(n:number):void;\r\n  close():void;\r\n}\r\n\r\nexport class EditFloat32ArrayInputStream implements Float32ArrayInputStream{\r\n  private framePos=0;\r\n  private readFrames=0;\r\n  constructor(private _srcInputStream:Float32ArrayInputStream,private offset:number=0,private length?:number|undefined) {\r\n    if (this.offset<0){\r\n        throw Error('Parameter offset must be undefined or greater or equal zero.');\r\n    }\r\n    if (this.length!==undefined && this.length<0){\r\n      throw Error('Parameter length must be undefined or greater or equal zero.');\r\n    }\r\n  }\r\n\r\n  private skipToOffset(){\r\n    if(this.framePos==0 && this.offset>0){\r\n      this._srcInputStream.skipFrames(this.offset);\r\n      this.framePos+=this.offset;\r\n    }\r\n  }\r\n\r\n  read(buffers: Array<Float32Array>): number{\r\n    this.skipToOffset();\r\n    let read=0;\r\n    if(this.length===undefined){\r\n      read = this._srcInputStream.read(buffers);\r\n    }else {\r\n      if (buffers.length > 0) {\r\n        let bufsCh0 = buffers[0];\r\n        let bufsLen = bufsCh0.length;\r\n        let avail = this.length - this.readFrames;\r\n        if (avail > 0) {\r\n          if (avail > bufsLen) {\r\n            read = this._srcInputStream.read(buffers);\r\n          } else {\r\n            // temporary buffers required\r\n            let tmpBufs = new Array<Float32Array>(buffers.length);\r\n            for (let ch = 0; ch < buffers.length; ch++) {\r\n              tmpBufs[ch] = new Float32Array(avail);\r\n            }\r\n            read = this._srcInputStream.read(tmpBufs);\r\n            for (let ch = 0; ch < buffers.length; ch++) {\r\n              buffers[ch].set(tmpBufs[ch]);\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n    this.readFrames+=read;\r\n    this.framePos+=read;\r\n    return read;\r\n  }\r\n\r\n  skipFrames(n:number):void{\r\n    this.skipToOffset();\r\n    if(this.length===undefined){\r\n      this._srcInputStream.skipFrames(n);\r\n    }else {\r\n      let avail = this.length - this.readFrames;\r\n      if (avail > 0) {\r\n        if (avail >= n) {\r\n          this._srcInputStream.skipFrames(n);\r\n          this.readFrames += n;\r\n          this.framePos += n;\r\n        } else {\r\n          throw Error('Tried to skip out of bounds.')\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  close():void{\r\n    this._srcInputStream.close();\r\n  }\r\n}\r\n\r\n\r\nexport class AsyncEditFloat32ArrayInputStream implements AsyncFloat32ArrayInputStream{\r\n  private framePos=0;\r\n  private readFrames=0;\r\n  constructor(private _srcInputStream:AsyncFloat32ArrayInputStream,private offset:number=0,private length?:number|undefined) {\r\n    if (this.offset<0){\r\n      throw Error('Parameter offset must be undefined or greater or equal zero.');\r\n    }\r\n    if (this.length!==undefined && this.length<0){\r\n      throw Error('Parameter length must be undefined or greater or equal zero.');\r\n    }\r\n  }\r\n\r\n  private skipToOffset(){\r\n    if(this.framePos==0 && this.offset>0){\r\n      this._srcInputStream.skipFrames(this.offset);\r\n      this.framePos+=this.offset;\r\n    }\r\n  }\r\n\r\n  readObs(buffers: Array<Float32Array>): Observable<number> {\r\n    return new Observable<number>(subscriber=>{\r\n      this.skipToOffset();\r\n      if(this.length===undefined){\r\n        this._srcInputStream.readObs(buffers).subscribe(subscriber);\r\n      }else {\r\n        if (buffers.length > 0) {\r\n          let bufsCh0 = buffers[0];\r\n          let bufsLen = bufsCh0.length;\r\n          let avail = this.length - this.readFrames;\r\n          if (avail > 0) {\r\n            if (avail > bufsLen) {\r\n              this._srcInputStream.readObs(buffers).subscribe({\r\n                next: (read)=>{\r\n                  this.readFrames+=read;\r\n                  this.framePos+=read;\r\n                  subscriber.next(read);\r\n                },complete:()=>{\r\n                  subscriber.complete();\r\n               }\r\n              });\r\n            } else {\r\n              // temporary buffers required\r\n              let tmpBufs = new Array<Float32Array>(buffers.length);\r\n              for (let ch = 0; ch < buffers.length; ch++) {\r\n                tmpBufs[ch] = new Float32Array(avail);\r\n              }\r\n              this._srcInputStream.readObs(tmpBufs).subscribe({\r\n                next:(read)=>{\r\n                for (let ch = 0; ch < buffers.length; ch++) {\r\n                  buffers[ch].set(tmpBufs[ch]);\r\n                }\r\n                this.readFrames+=read;\r\n                this.framePos+=read;\r\n                subscriber.next(read);\r\n              },complete:()=>{\r\n                  subscriber.complete();\r\n                }\r\n              }\r\n              );\r\n            }\r\n          }else{\r\n            // end of stream\r\n            subscriber.next(0);\r\n            subscriber.complete();\r\n          }\r\n        }else{\r\n          subscriber.next(0);\r\n          subscriber.complete();\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  skipFrames(n:number):void{\r\n    this.skipToOffset();\r\n    if(this.length===undefined){\r\n      this._srcInputStream.skipFrames(n);\r\n    }else {\r\n      let avail = this.length - this.readFrames;\r\n      if (avail > 0) {\r\n        if (avail >= n) {\r\n          this._srcInputStream.skipFrames(n);\r\n          this.readFrames += n;\r\n          this.framePos += n;\r\n        } else {\r\n          throw Error('Tried to skip out of bounds.')\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  close():void{\r\n    this._srcInputStream.close();\r\n  }\r\n\r\n}\r\n\r\n\r\nexport interface Float32ArrayOutStream {\r\n\r\n  write(buffers: Array<Float32Array>): number;\r\n\r\n  flush(): void;\r\n\r\n  close(): void;\r\n}\r\n\r\nexport class Float32ArrayChunkerOutStream implements Float32ArrayOutStream {\r\n\r\n  private bufs = new Array<Float32Array>();\r\n  private filled: number;\r\n\r\n  private _channels: number=0;\r\n  private _chunkSize: number=0;\r\n\r\n  private receivedFrames: number;\r\n  private sentFrames: number;\r\n\r\n  constructor(private outStream: Float32ArrayOutStream) {\r\n    this.filled = 0;\r\n    this.receivedFrames = 0;\r\n    this.sentFrames = 0;\r\n  }\r\n\r\n  private createBuffers() {\r\n    this.bufs = new Array<Float32Array>(this._channels);\r\n    for (let ch = 0; ch < this._channels; ch++) {\r\n      this.bufs[ch] = new Float32Array(this._chunkSize);\r\n    }\r\n  }\r\n\r\n  set chunkSize(chunkSize: number) {\r\n    this._chunkSize = chunkSize;\r\n    this.createBuffers();\r\n  }\r\n\r\n  get chunkSize(): number {\r\n    return this._chunkSize;\r\n  }\r\n\r\n  set channels(channels: number) {\r\n    this._channels = channels;\r\n    this.createBuffers();\r\n  }\r\n\r\n  get channels(): number {\r\n    return this._channels;\r\n  }\r\n\r\n\r\n  available(): number {\r\n    return this._chunkSize-this.filled;\r\n  }\r\n\r\n  write(buffers: Array<Float32Array>): number {\r\n\r\n    let copied = 0;\r\n    if(buffers.length>0) {\r\n      let buffersLen = buffers[0].length;\r\n      this.receivedFrames += buffersLen;\r\n      let avail = buffersLen;\r\n      // Fill out buffers until all values copied\r\n\r\n      while (avail > 0) {\r\n        let toFill = this._chunkSize - this.filled;\r\n        if (toFill > avail) {\r\n          toFill = avail;\r\n        }\r\n        let sliceEnd = copied + toFill;\r\n\r\n        // Firefox on Android sends only the first channel\r\n        for (let ch = 0; ch < buffersLen; ch++) {\r\n          if(buffers[ch]) {\r\n            let cpPrt = buffers[ch].slice(copied, sliceEnd);\r\n            let buf = this.bufs[ch];\r\n            buf.set(cpPrt, this.filled);\r\n          }\r\n        }\r\n        copied += toFill;\r\n        avail -= toFill;\r\n        this.filled += toFill;\r\n        if (this.filled == this._chunkSize) {\r\n          this.outStream.write(this.bufs);\r\n          this.sentFrames += this.filled;\r\n          this.filled = 0;\r\n\r\n        }\r\n      }\r\n    }\r\n    return copied;\r\n  }\r\n\r\n  flush(): void {\r\n    if (this.filled > 0) {\r\n      let restBufs = new Array<Float32Array>(this._channels);\r\n      for (let ch = 0; ch < this._channels; ch++) {\r\n        restBufs[ch] = this.bufs[ch].slice(0, this.filled);\r\n      }\r\n      this.outStream.write(restBufs);\r\n      this.outStream.flush();\r\n      this.sentFrames += this.filled;\r\n      this.filled = 0;\r\n    }\r\n  }\r\n\r\n\r\n  close(): void {\r\n    this.outStream.close();\r\n  }\r\n\r\n\r\n}\r\n"]}
@@ -1,28 +0,0 @@
1
- export class Position {
2
- constructor(left, top) {
3
- this.left = left;
4
- this.top = top;
5
- }
6
- toString() {
7
- return this.left + "," + this.top;
8
- }
9
- }
10
- export class Dimension {
11
- constructor(width, height) {
12
- this.width = width;
13
- this.height = height;
14
- }
15
- toString() {
16
- return this.width + "x" + this.height;
17
- }
18
- }
19
- export class Rectangle {
20
- constructor(position, dimension) {
21
- this.position = position;
22
- this.dimension = dimension;
23
- }
24
- toString() {
25
- return this.position + ":" + this.dimension;
26
- }
27
- }
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VvbWV0cnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zcGVlY2hyZWNvcmRlcm5nL3NyYy9saWIvbWF0aC8yZC9nZW9tZXRyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sUUFBUTtJQUNuQixZQUFtQixJQUFXLEVBQVEsR0FBVTtRQUE3QixTQUFJLEdBQUosSUFBSSxDQUFPO1FBQVEsUUFBRyxHQUFILEdBQUcsQ0FBTztJQUVoRCxDQUFDO0lBQ0QsUUFBUTtRQUNOLE9BQU8sSUFBSSxDQUFDLElBQUksR0FBQyxHQUFHLEdBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQTtJQUMvQixDQUFDO0NBQ0Y7QUFHRCxNQUFNLE9BQU8sU0FBUztJQUNwQixZQUFtQixLQUFZLEVBQVEsTUFBYTtRQUFqQyxVQUFLLEdBQUwsS0FBSyxDQUFPO1FBQVEsV0FBTSxHQUFOLE1BQU0sQ0FBTztJQUVwRCxDQUFDO0lBQ0QsUUFBUTtRQUNOLE9BQU8sSUFBSSxDQUFDLEtBQUssR0FBQyxHQUFHLEdBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQTtJQUNuQyxDQUFDO0NBQ0Y7QUFHRCxNQUFNLE9BQU8sU0FBUztJQUVwQixZQUFtQixRQUFpQixFQUFRLFNBQW1CO1FBQTVDLGFBQVEsR0FBUixRQUFRLENBQVM7UUFBUSxjQUFTLEdBQVQsU0FBUyxDQUFVO0lBRS9ELENBQUM7SUFDRCxRQUFRO1FBQ04sT0FBTyxJQUFJLENBQUMsUUFBUSxHQUFDLEdBQUcsR0FBQyxJQUFJLENBQUMsU0FBUyxDQUFBO0lBQ3pDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBQb3NpdGlvbntcclxuICBjb25zdHJ1Y3RvcihwdWJsaWMgbGVmdDpudW1iZXIscHVibGljIHRvcDpudW1iZXIpe1xyXG5cclxuICB9XHJcbiAgdG9TdHJpbmcoKTpzdHJpbmd7XHJcbiAgICByZXR1cm4gdGhpcy5sZWZ0K1wiLFwiK3RoaXMudG9wXHJcbiAgfVxyXG59XHJcblxyXG5cclxuZXhwb3J0IGNsYXNzIERpbWVuc2lvbiB7XHJcbiAgY29uc3RydWN0b3IocHVibGljIHdpZHRoOm51bWJlcixwdWJsaWMgaGVpZ2h0Om51bWJlcil7XHJcblxyXG4gIH1cclxuICB0b1N0cmluZygpOnN0cmluZ3tcclxuICAgIHJldHVybiB0aGlzLndpZHRoK1wieFwiK3RoaXMuaGVpZ2h0XHJcbiAgfVxyXG59XHJcblxyXG5cclxuZXhwb3J0IGNsYXNzIFJlY3RhbmdsZXtcclxuXHJcbiAgY29uc3RydWN0b3IocHVibGljIHBvc2l0aW9uOlBvc2l0aW9uLHB1YmxpYyBkaW1lbnNpb246RGltZW5zaW9uKXtcclxuXHJcbiAgfVxyXG4gIHRvU3RyaW5nKCk6c3RyaW5ne1xyXG4gICAgcmV0dXJuIHRoaXMucG9zaXRpb24rXCI6XCIrdGhpcy5kaW1lbnNpb25cclxuICB9XHJcbn1cclxuIl19
@@ -1,58 +0,0 @@
1
- export class Complex {
2
- static fromPolarForm(magnitude, argument) {
3
- const r = Math.cos(argument) * magnitude;
4
- const i = Math.sin(argument) * magnitude;
5
- return new Complex(r, i);
6
- }
7
- constructor(real, img) {
8
- this.real = real;
9
- this.img = img;
10
- }
11
- magnitude() {
12
- return Math.sqrt((this.real * this.real) + (this.img * this.img));
13
- }
14
- argument() {
15
- return Math.atan2(this.img, this.real);
16
- }
17
- add(addC) {
18
- return new Complex(this.real + addC.real, this.img + addC.img);
19
- }
20
- sub(subC) {
21
- return new Complex(this.real - subC.real, this.img - subC.img);
22
- }
23
- mult(multC) {
24
- const multR = (this.real * multC.real) - (this.img * multC.img);
25
- const multI = (this.real * multC.img) + (multC.real * this.img);
26
- return new Complex(multR, multI);
27
- }
28
- multReal(multF) {
29
- return new Complex(this.real * multF, this.img * multF);
30
- }
31
- div(divisor) {
32
- const divReal = divisor.real;
33
- const divImg = divisor.img;
34
- const div = (divReal * divReal) + (divImg * divImg);
35
- const divisionReal = ((this.real * divReal) + (this.img * divImg)) / div;
36
- const divisionImg = ((divReal * this.img) - (this.real * divImg)) / div;
37
- return new Complex(divisionReal, divisionImg);
38
- }
39
- divReal(divisor) {
40
- const div = divisor * divisor;
41
- const divsionReal = (this.real * divisor) / div;
42
- const divsionImg = (divisor * this.img) / div;
43
- return new Complex(divsionReal, divsionImg);
44
- }
45
- conjugate() {
46
- return new Complex(this.real, -this.img);
47
- }
48
- equals(c) {
49
- if (c === null) {
50
- return false;
51
- }
52
- return (this.real === c.real && this.img === c.img);
53
- }
54
- toString() {
55
- return 'Real: ' + this.real + ', Img: ' + this.img;
56
- }
57
- }
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcGxleC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NwZWVjaHJlY29yZGVybmcvc3JjL2xpYi9tYXRoL2NvbXBsZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0ksTUFBTSxPQUFPLE9BQU87SUFLVCxNQUFNLENBQUMsYUFBYSxDQUFDLFNBQWlCLEVBQUUsUUFBZ0I7UUFDM0QsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsR0FBRyxTQUFTLENBQUM7UUFDekMsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsR0FBRyxTQUFTLENBQUM7UUFDekMsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUNELFlBQVksSUFBWSxFQUFFLEdBQVc7UUFDakMsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7SUFDbkIsQ0FBQztJQUNNLFNBQVM7UUFDWixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDdEUsQ0FBQztJQUVNLFFBQVE7UUFDWCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVNLEdBQUcsQ0FBQyxJQUFhO1FBQ3BCLE9BQU8sSUFBSSxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lB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ICAgICAgcmVhbDogbnVtYmVyO1xyXG4gICAgICAgIGltZzogbnVtYmVyO1xyXG5cclxuICAgICAgICBwdWJsaWMgc3RhdGljIGZyb21Qb2xhckZvcm0obWFnbml0dWRlOiBudW1iZXIsIGFyZ3VtZW50OiBudW1iZXIpOiBDb21wbGV4IHtcclxuICAgICAgICAgICAgY29uc3QgciA9IE1hdGguY29zKGFyZ3VtZW50KSAqIG1hZ25pdHVkZTtcclxuICAgICAgICAgICAgY29uc3QgaSA9IE1hdGguc2luKGFyZ3VtZW50KSAqIG1hZ25pdHVkZTtcclxuICAgICAgICAgICAgcmV0dXJuIG5ldyBDb21wbGV4KHIsIGkpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBjb25zdHJ1Y3RvcihyZWFsOiBudW1iZXIsIGltZzogbnVtYmVyKSB7XHJcbiAgICAgICAgICAgIHRoaXMucmVhbCA9IHJlYWw7XHJcbiAgICAgICAgICAgIHRoaXMuaW1nID0gaW1nO1xyXG4gICAgICAgIH1cclxuICAgICAgICBwdWJsaWMgbWFnbml0dWRlKCk6IG51bWJlciB7XHJcbiAgICAgICAgICAgIHJldHVybiBNYXRoLnNxcnQoKHRoaXMucmVhbCAqIHRoaXMucmVhbCkgKyAodGhpcy5pbWcgKiB0aGlzLmltZykpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcHVibGljIGFyZ3VtZW50KCk6IG51bWJlciB7XHJcbiAgICAgICAgICAgIHJldHVybiBNYXRoLmF0YW4yKHRoaXMuaW1nLCB0aGlzLnJlYWwpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcHVibGljIGFkZChhZGRDOiBDb21wbGV4KTogQ29tcGxleCB7XHJcbiAgICAgICAgICAgIHJldHVybiBuZXcgQ29tcGxleCh0aGlzLnJlYWwgKyBhZGRDLnJlYWwsIHRoaXMuaW1nICsgYWRkQy5pbWcpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcHVibGljIHN1YihzdWJDOiBDb21wbGV4KTogQ29tcGxleCB7XHJcbiAgICAgICAgICAgIHJldHVybiBuZXcgQ29tcGxleCh0aGlzLnJlYWwgLSBzdWJDLnJlYWwsIHRoaXMuaW1nIC0gc3ViQy5pbWcpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcHVibGljIG11bHQobXVsdEM6IENvbXBsZXgpOiBDb21wbGV4IHtcclxuICAgICAgICAgICAgY29uc3QgbXVsdFIgPSAodGhpcy5yZWFsICogbXVsdEMucmVhbCkgLSAodGhpcy5pbWcgKiBtdWx0Qy5pbWcpO1xyXG4gICAgICAgICAgICBjb25zdCBtdWx0SSA9ICh0aGlzLnJlYWwgKiBtdWx0Qy5pbWcpICsgKG11bHRDLnJlYWwgKiB0aGlzLmltZyk7XHJcbiAgICAgICAgICAgIHJldHVybiBuZXcgQ29tcGxleChtdWx0UiwgbXVsdEkpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcHVibGljIG11bHRSZWFsKG11bHRGOiBudW1iZXIpOiBDb21wbGV4IHtcclxuICAgICAgICAgICAgcmV0dXJuIG5ldyBDb21wbGV4KHRoaXMucmVhbCAqIG11bHRGLCB0aGlzLmltZyAqIG11bHRGKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHB1YmxpYyBkaXYoZGl2aXNvcjogQ29tcGxleCk6IENvbXBsZXgge1xyXG4gICAgICAgICAgICBjb25zdCBkaXZSZWFsID0gZGl2aXNvci5yZWFsO1xyXG4gICAgICAgICAgICBjb25zdCBkaXZJbWcgPSBkaXZpc29yLmltZztcclxuICAgICAgICAgICAgY29uc3QgZGl2ID0gKGRpdlJlYWwgKiBkaXZSZWFsKSArIChkaXZJbWcgKiBkaXZJbWcpO1xyXG4gICAgICAgICAgICBjb25zdCBkaXZpc2lvblJlYWwgPSAoKHRoaXMucmVhbCAqIGRpdlJlYWwpICsgKHRoaXMuaW1nICogZGl2SW1nKSkgLyBkaXY7XHJcbiAgICAgICAgICAgIGNvbnN0IGRpdmlzaW9uSW1nID0gKChkaXZSZWFsICogdGhpcy5pbWcpIC0gKHRoaXMucmVhbCAqIGRpdkltZykpIC8gZGl2O1xyXG5cclxuICAgICAgICAgICAgcmV0dXJuIG5ldyBDb21wbGV4KGRpdmlzaW9uUmVhbCwgZGl2aXNpb25JbWcpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcHVibGljIGRpdlJlYWwoZGl2aXNvcjogbnVtYmVyKTogQ29tcGxleCB7XHJcbiAgICAgICAgICAgIGNvbnN0IGRpdiA9IGRpdmlzb3IgKiBkaXZpc29yO1xyXG4gICAgICAgICAgICBjb25zdCBkaXZzaW9uUmVhbCA9ICh0aGlzLnJlYWwgKiBkaXZpc29yKSAvIGRpdjtcclxuICAgICAgICAgICAgY29uc3QgZGl2c2lvbkltZyA9IChkaXZpc29yICogdGhpcy5pbWcpIC8gZGl2O1xyXG5cclxuICAgICAgICAgICAgcmV0dXJuIG5ldyBDb21wbGV4KGRpdnNpb25SZWFsLCBkaXZzaW9uSW1nKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHB1YmxpYyBjb25qdWdhdGUoKTogQ29tcGxleCB7XHJcbiAgICAgICAgICAgIHJldHVybiBuZXcgQ29tcGxleCh0aGlzLnJlYWwsIC10aGlzLmltZyk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBwdWJsaWMgZXF1YWxzKGM6IENvbXBsZXgpOiBib29sZWFuIHtcclxuICAgICAgICAgICAgaWYgKGMgPT09IG51bGwpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICByZXR1cm4gKHRoaXMucmVhbCA9PT0gYy5yZWFsICYmIHRoaXMuaW1nID09PSBjLmltZyk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBwdWJsaWMgdG9TdHJpbmcoKTogc3RyaW5nIHtcclxuICAgICAgICAgICAgcmV0dXJuICdSZWFsOiAnICsgdGhpcy5yZWFsICsgJywgSW1nOiAnICsgdGhpcy5pbWc7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4iXX0=
@@ -1,196 +0,0 @@
1
- import { Complex } from './complex';
2
- export class DFTFloat32 {
3
- constructor(n) {
4
- this.n = n;
5
- this.m = Math.log(n) / Math.log(2);
6
- // if(n != (1 << m))throw new RuntimeException("length N must be power of 2");
7
- // lookup tables
8
- this.cosLookup = new Float32Array(n / 2);
9
- this.sinLookup = new Float32Array(n / 2);
10
- for (let i = 0; i < n / 2; i++) {
11
- const arc = (-2 * Math.PI * i) / n;
12
- this.cosLookup[i] = Math.cos(arc);
13
- this.sinLookup[i] = Math.sin(arc);
14
- }
15
- }
16
- processReal(srcBuf) {
17
- const x = srcBuf.slice();
18
- const y = new Float32Array(srcBuf.length);
19
- for (let yi = 0; yi < y.length; yi++) {
20
- y[yi] = 0.0;
21
- }
22
- this.fftCooleyTukey(x, y);
23
- const rc = new Array(x.length);
24
- for (let i = 0; i < x.length; i++) {
25
- rc[i] = new Complex(x[i], y[i]);
26
- }
27
- return rc;
28
- }
29
- processRealMagnitude(srcBuf) {
30
- const x = srcBuf.slice();
31
- const y = new Float32Array(srcBuf.length);
32
- for (let yi = 0; yi < y.length; yi++) {
33
- y[yi] = 0.0;
34
- }
35
- this.fftCooleyTukey(x, y);
36
- const rc = new Float32Array(x.length);
37
- for (let i = 0; i < x.length; i++) {
38
- const rcc = new Complex(x[i], y[i]);
39
- rc[i] = rcc.magnitude();
40
- }
41
- return rc;
42
- }
43
- fftCooleyTukey(real, img) {
44
- let i;
45
- let j = 0;
46
- let k;
47
- let n1;
48
- let n2 = this.n / 2;
49
- let a;
50
- let c;
51
- let s;
52
- let t1;
53
- let t2;
54
- for (i = 1; i < this.n - 1; i++) {
55
- n1 = n2;
56
- while (j >= n1) {
57
- j = j - n1;
58
- n1 = n1 / 2;
59
- }
60
- j = j + n1;
61
- if (i < j) {
62
- t1 = real[i];
63
- real[i] = real[j];
64
- real[j] = t1;
65
- t1 = img[i];
66
- img[i] = img[j];
67
- img[j] = t1;
68
- }
69
- }
70
- n1 = 0;
71
- n2 = 1;
72
- for (i = 0; i < this.m; i++) {
73
- n1 = n2;
74
- n2 = n2 + n2;
75
- a = 0;
76
- for (j = 0; j < n1; j++) {
77
- c = this.cosLookup[a];
78
- s = this.sinLookup[a];
79
- a += (1 << (this.m - i - 1));
80
- for (k = j; k < this.n; k = k + n2) {
81
- t1 = c * real[k + n1] - s * img[k + n1];
82
- t2 = s * real[k + n1] + c * img[k + n1];
83
- real[k + n1] = real[k] - t1;
84
- img[k + n1] = img[k] - t2;
85
- real[k] = real[k] + t1;
86
- img[k] = img[k] + t2;
87
- }
88
- }
89
- }
90
- }
91
- process(t) {
92
- const reals = new Float32Array(this.n);
93
- const imgs = new Float32Array(this.n);
94
- const trans = new Array(this.n);
95
- for (let i = 0; i < this.n; i++) {
96
- reals[i] = t[i].real;
97
- imgs[i] = t[i].img;
98
- }
99
- this.fftCooleyTukey(reals, imgs);
100
- for (let i = 0; i < this.n; i++) {
101
- trans[i] = new Complex(reals[i], imgs[i]);
102
- }
103
- return trans;
104
- }
105
- }
106
- export class DFT {
107
- constructor(n) {
108
- this.n = n;
109
- this.m = Math.log(n) / Math.log(2);
110
- // if(n != (1 << m))throw new RuntimeException("length N must be power of 2");
111
- // lookup tables
112
- this.cosLookup = new Array(n / 2);
113
- this.sinLookup = new Array(n / 2);
114
- for (let i = 0; i < n / 2; i++) {
115
- const arc = (-2 * Math.PI * i) / n;
116
- this.cosLookup[i] = Math.cos(arc);
117
- this.sinLookup[i] = Math.sin(arc);
118
- }
119
- }
120
- processReal(srcBuf) {
121
- const x = srcBuf.slice();
122
- const y = new Array(srcBuf.length);
123
- for (let yi = 0; yi < y.length; yi++) {
124
- y[yi] = 0.0;
125
- }
126
- this.fftCooleyTukey(x, y);
127
- const rc = new Array(x.length);
128
- for (let i = 0; i < x.length; i++) {
129
- rc[i] = new Complex(x[i], y[i]);
130
- }
131
- return rc;
132
- }
133
- fftCooleyTukey(real, img) {
134
- let i;
135
- let j = 0;
136
- let k;
137
- let n1;
138
- let n2 = this.n / 2;
139
- let a;
140
- let c;
141
- let s;
142
- let t1;
143
- let t2;
144
- for (i = 1; i < this.n - 1; i++) {
145
- n1 = n2;
146
- while (j >= n1) {
147
- j = j - n1;
148
- n1 = n1 / 2;
149
- }
150
- j = j + n1;
151
- if (i < j) {
152
- t1 = real[i];
153
- real[i] = real[j];
154
- real[j] = t1;
155
- t1 = img[i];
156
- img[i] = img[j];
157
- img[j] = t1;
158
- }
159
- }
160
- n1 = 0;
161
- n2 = 1;
162
- for (i = 0; i < this.m; i++) {
163
- n1 = n2;
164
- n2 = n2 + n2;
165
- a = 0;
166
- for (j = 0; j < n1; j++) {
167
- c = this.cosLookup[a];
168
- s = this.sinLookup[a];
169
- a += 1 << (this.m - i - 1);
170
- for (k = j; k < this.n; k = k + n2) {
171
- t1 = c * real[k + n1] - s * img[k + n1];
172
- t2 = s * real[k + n1] + c * img[k + n1];
173
- real[k + n1] = real[k] - t1;
174
- img[k + n1] = img[k] - t2;
175
- real[k] = real[k] + t1;
176
- img[k] = img[k] + t2;
177
- }
178
- }
179
- }
180
- }
181
- process(t) {
182
- const reals = new Array(this.n);
183
- const imgs = new Array(this.n);
184
- const trans = new Array(this.n);
185
- for (let i = 0; i < this.n; i++) {
186
- reals[i] = t[i].real;
187
- imgs[i] = t[i].img;
188
- }
189
- this.fftCooleyTukey(reals, imgs);
190
- for (let i = 0; i < this.n; i++) {
191
- trans[i] = new Complex(reals[i], imgs[i]);
192
- }
193
- return trans;
194
- }
195
- }
196
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dft.js","sourceRoot":"","sources":["../../../../../projects/speechrecorderng/src/lib/math/dft.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEhC,MAAM,OAAO,UAAU;IAQnB,YAAY,CAAS;QACjB,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QACX,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAEnC,8EAA8E;QAE9E,gBAAgB;QAChB,IAAI,CAAC,SAAS,GAAG,IAAI,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACzC,IAAI,CAAC,SAAS,GAAG,IAAI,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAEzC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC7B,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;YACnC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAClC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACtC,CAAC;IACL,CAAC;IAEM,WAAW,CAAC,MAAoB;QACnC,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC;QACzB,MAAM,CAAC,GAAG,IAAI,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC1C,KAAK,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC;YACnC,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;QAChB,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1B,MAAM,EAAE,GAAG,IAAI,KAAK,CAAU,CAAC,CAAC,MAAM,CAAC,CAAC;QACxC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAChC,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACpC,CAAC;QACD,OAAO,EAAE,CAAC;IACd,CAAC;IAEM,oBAAoB,CAAC,MAAoB;QAC5C,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC;QACzB,MAAM,CAAC,GAAG,IAAI,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC1C,KAAK,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC;YACnC,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;QAChB,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1B,MAAM,EAAE,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QACtC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAChC,MAAM,GAAG,GAAG,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACpC,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,SAAS,EAAE,CAAC;QAC5B,CAAC;QACD,OAAO,EAAE,CAAC;IACd,CAAC;IAEM,cAAc,CAAC,IAAkB,EAAE,GAAiB;QACvD,IAAI,CAAS,CAAC;QACd,IAAI,CAAC,GAAG,CAAC,CAAC;QACV,IAAI,CAAS,CAAC;QACd,IAAI,EAAU,CAAC;QACf,IAAI,EAAE,GAAW,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QAC5B,IAAI,CAAS,CAAC;QACd,IAAI,CAAS,CAAC;QACd,IAAI,CAAS,CAAC;QACd,IAAI,EAAU,CAAC;QACf,IAAI,EAAU,CAAC;QAEf,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC9B,EAAE,GAAG,EAAE,CAAC;YACR,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC;gBACb,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;gBACX,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;YAChB,CAAC;YACD,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;YAEX,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;gBACR,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACb,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClB,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;gBACb,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;gBACZ,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;gBAChB,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;YAChB,CAAC;QACL,CAAC;QAED,EAAE,GAAG,CAAC,CAAC;QACP,EAAE,GAAG,CAAC,CAAC;QACP,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC1B,EAAE,GAAG,EAAE,CAAC;YACR,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACb,CAAC,GAAG,CAAC,CAAC;YACN,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;gBACtB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBACtB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBACtB,CAAC,IAAI,CAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBAE9B,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC;oBACjC,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;oBACxC,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;oBACxC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;oBAC5B,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;oBAC1B,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;oBACvB,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;gBACzB,CAAC;YACL,CAAC;QACL,CAAC;IACL,CAAC;IAGM,OAAO,CAAC,CAAiB;QAC5B,MAAM,KAAK,GAAiB,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACrD,MAAM,IAAI,GAAiB,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpD,MAAM,KAAK,GAAmB,IAAI,KAAK,CAAU,IAAI,CAAC,CAAC,CAAC,CAAC;QACzD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC9B,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YACrB,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;QACvB,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC9B,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9C,CAAC;QACD,OAAO,KAAK,CAAC;IAGjB,CAAC;CAEJ;AACD,MAAM,OAAO,GAAG;IAQZ,YAAY,CAAS;QACjB,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QACX,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAEnC,8EAA8E;QAE9E,gBAAgB;QAChB,IAAI,CAAC,SAAS,GAAG,IAAI,KAAK,CAAS,CAAC,GAAG,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,SAAS,GAAG,IAAI,KAAK,CAAS,CAAC,GAAG,CAAC,CAAC,CAAC;QAE1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC7B,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;YACnC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAClC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACtC,CAAC;IACL,CAAC;IAEM,WAAW,CAAC,MAAqB;QACpC,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC;QACzB,MAAM,CAAC,GAAG,IAAI,KAAK,CAAS,MAAM,CAAC,MAAM,CAAC,CAAC;QAC3C,KAAK,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC;YACnC,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;QAChB,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1B,MAAM,EAAE,GAAG,IAAI,KAAK,CAAU,CAAC,CAAC,MAAM,CAAC,CAAC;QACxC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAChC,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACpC,CAAC;QACD,OAAO,EAAE,CAAC;IACd,CAAC;IAEM,cAAc,CAAC,IAAmB,EAAE,GAAkB;QACzD,IAAI,CAAS,CAAC;QACd,IAAI,CAAC,GAAG,CAAC,CAAC;QACV,IAAI,CAAS,CAAC;QACd,IAAI,EAAU,CAAC;QACf,IAAI,EAAE,GAAW,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QAC5B,IAAI,CAAS,CAAC;QACd,IAAI,CAAS,CAAC;QACd,IAAI,CAAS,CAAC;QACd,IAAI,EAAU,CAAC;QACf,IAAI,EAAU,CAAC;QAEf,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC9B,EAAE,GAAG,EAAE,CAAC;YACR,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC;gBACb,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;gBACX,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;YAChB,CAAC;YACD,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;YAEX,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;gBACR,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBACb,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClB,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;gBACb,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;gBACZ,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;gBAChB,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;YAChB,CAAC;QACL,CAAC;QAED,EAAE,GAAG,CAAC,CAAC;QACP,EAAE,GAAG,CAAC,CAAC;QACP,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC1B,EAAE,GAAG,EAAE,CAAC;YACR,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACb,CAAC,GAAG,CAAC,CAAC;YACN,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;gBACtB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBACtB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBACtB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;gBAE3B,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC;oBACjC,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;oBACxC,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;oBACxC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;oBAC5B,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;oBAC1B,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;oBACvB,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;gBACzB,CAAC;YACL,CAAC;QACL,CAAC;IACL,CAAC;IAGM,OAAO,CAAC,CAAiB;QAC5B,MAAM,KAAK,GAAkB,IAAI,KAAK,CAAS,IAAI,CAAC,CAAC,CAAC,CAAC;QACvD,MAAM,IAAI,GAAkB,IAAI,KAAK,CAAS,IAAI,CAAC,CAAC,CAAC,CAAC;QACtD,MAAM,KAAK,GAAmB,IAAI,KAAK,CAAU,IAAI,CAAC,CAAC,CAAC,CAAC;QACzD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC9B,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YACrB,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;QACvB,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC9B,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9C,CAAC;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;CAEJ","sourcesContent":["import { Complex } from './complex';\r\n\r\n    export class DFTFloat32 {\r\n\r\n        private n: number;\r\n        private m: number;\r\n\r\n        private cosLookup: Float32Array;\r\n        private sinLookup: Float32Array;\r\n\r\n        constructor(n: number) {\r\n            this.n = n;\r\n            this.m = Math.log(n) / Math.log(2);\r\n\r\n            // if(n != (1 << m))throw new RuntimeException(\"length N must be power of 2\");\r\n\r\n            // lookup tables\r\n            this.cosLookup = new Float32Array(n / 2);\r\n            this.sinLookup = new Float32Array(n / 2);\r\n\r\n            for (let i = 0; i < n / 2; i++) {\r\n                const arc = (-2 * Math.PI * i) / n;\r\n                this.cosLookup[i] = Math.cos(arc);\r\n                this.sinLookup[i] = Math.sin(arc);\r\n            }\r\n        }\r\n\r\n        public processReal(srcBuf: Float32Array): Array<Complex> {\r\n            const x = srcBuf.slice();\r\n            const y = new Float32Array(srcBuf.length);\r\n            for (let yi = 0; yi < y.length; yi++) {\r\n                y[yi] = 0.0;\r\n            }\r\n            this.fftCooleyTukey(x, y);\r\n            const rc = new Array<Complex>(x.length);\r\n            for (let i = 0; i < x.length; i++) {\r\n                rc[i] = new Complex(x[i], y[i]);\r\n            }\r\n            return rc;\r\n        }\r\n\r\n        public processRealMagnitude(srcBuf: Float32Array): Float32Array {\r\n            const x = srcBuf.slice();\r\n            const y = new Float32Array(srcBuf.length);\r\n            for (let yi = 0; yi < y.length; yi++) {\r\n                y[yi] = 0.0;\r\n            }\r\n            this.fftCooleyTukey(x, y);\r\n            const rc = new Float32Array(x.length);\r\n            for (let i = 0; i < x.length; i++) {\r\n                const rcc = new Complex(x[i], y[i]);\r\n                rc[i] = rcc.magnitude();\r\n            }\r\n            return rc;\r\n        }\r\n\r\n        public fftCooleyTukey(real: Float32Array, img: Float32Array): void {\r\n            let i: number;\r\n            let j = 0;\r\n            let k: number;\r\n            let n1: number;\r\n            let n2: number = this.n / 2;\r\n            let a: number;\r\n            let c: number;\r\n            let s: number;\r\n            let t1: number;\r\n            let t2: number;\r\n\r\n            for (i = 1; i < this.n - 1; i++) {\r\n                n1 = n2;\r\n                while (j >= n1) {\r\n                    j = j - n1;\r\n                    n1 = n1 / 2;\r\n                }\r\n                j = j + n1;\r\n\r\n                if (i < j) {\r\n                    t1 = real[i];\r\n                    real[i] = real[j];\r\n                    real[j] = t1;\r\n                    t1 = img[i];\r\n                    img[i] = img[j];\r\n                    img[j] = t1;\r\n                }\r\n            }\r\n\r\n            n1 = 0;\r\n            n2 = 1;\r\n            for (i = 0; i < this.m; i++) {\r\n                n1 = n2;\r\n                n2 = n2 + n2;\r\n                a = 0;\r\n                for (j = 0; j < n1; j++) {\r\n                    c = this.cosLookup[a];\r\n                    s = this.sinLookup[a];\r\n                    a += ( 1 << (this.m - i - 1));\r\n\r\n                    for (k = j; k < this.n; k = k + n2) {\r\n                        t1 = c * real[k + n1] - s * img[k + n1];\r\n                        t2 = s * real[k + n1] + c * img[k + n1];\r\n                        real[k + n1] = real[k] - t1;\r\n                        img[k + n1] = img[k] - t2;\r\n                        real[k] = real[k] + t1;\r\n                        img[k] = img[k] + t2;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n\r\n\r\n        public process(t: Array<Complex>): Array<Complex> {\r\n            const reals: Float32Array = new Float32Array(this.n);\r\n            const imgs: Float32Array = new Float32Array(this.n);\r\n            const trans: Array<Complex> = new Array<Complex>(this.n);\r\n            for (let i = 0; i < this.n; i++) {\r\n                reals[i] = t[i].real;\r\n                imgs[i] = t[i].img;\r\n            }\r\n            this.fftCooleyTukey(reals, imgs);\r\n            for (let i = 0; i < this.n; i++) {\r\n                trans[i] = new Complex(reals[i], imgs[i]);\r\n            }\r\n            return trans;\r\n\r\n\r\n        }\r\n\r\n    }\r\n    export class DFT {\r\n\r\n        private n: number;\r\n        private m: number;\r\n\r\n        private cosLookup: Array<number>;\r\n        private sinLookup: Array<number>;\r\n\r\n        constructor(n: number) {\r\n            this.n = n;\r\n            this.m = Math.log(n) / Math.log(2);\r\n\r\n            // if(n != (1 << m))throw new RuntimeException(\"length N must be power of 2\");\r\n\r\n            // lookup tables\r\n            this.cosLookup = new Array<number>(n / 2);\r\n            this.sinLookup = new Array<number>(n / 2);\r\n\r\n            for (let i = 0; i < n / 2; i++) {\r\n                const arc = (-2 * Math.PI * i) / n;\r\n                this.cosLookup[i] = Math.cos(arc);\r\n                this.sinLookup[i] = Math.sin(arc);\r\n            }\r\n        }\r\n\r\n        public processReal(srcBuf: Array<number>): Array<Complex> {\r\n            const x = srcBuf.slice();\r\n            const y = new Array<number>(srcBuf.length);\r\n            for (let yi = 0; yi < y.length; yi++) {\r\n                y[yi] = 0.0;\r\n            }\r\n            this.fftCooleyTukey(x, y);\r\n            const rc = new Array<Complex>(x.length);\r\n            for (let i = 0; i < x.length; i++) {\r\n                rc[i] = new Complex(x[i], y[i]);\r\n            }\r\n            return rc;\r\n        }\r\n\r\n        public fftCooleyTukey(real: Array<number>, img: Array<number>): void {\r\n            let i: number;\r\n            let j = 0;\r\n            let k: number;\r\n            let n1: number;\r\n            let n2: number = this.n / 2;\r\n            let a: number;\r\n            let c: number;\r\n            let s: number;\r\n            let t1: number;\r\n            let t2: number;\r\n\r\n            for (i = 1; i < this.n - 1; i++) {\r\n                n1 = n2;\r\n                while (j >= n1) {\r\n                    j = j - n1;\r\n                    n1 = n1 / 2;\r\n                }\r\n                j = j + n1;\r\n\r\n                if (i < j) {\r\n                    t1 = real[i];\r\n                    real[i] = real[j];\r\n                    real[j] = t1;\r\n                    t1 = img[i];\r\n                    img[i] = img[j];\r\n                    img[j] = t1;\r\n                }\r\n            }\r\n\r\n            n1 = 0;\r\n            n2 = 1;\r\n            for (i = 0; i < this.m; i++) {\r\n                n1 = n2;\r\n                n2 = n2 + n2;\r\n                a = 0;\r\n                for (j = 0; j < n1; j++) {\r\n                    c = this.cosLookup[a];\r\n                    s = this.sinLookup[a];\r\n                    a += 1 << (this.m - i - 1);\r\n\r\n                    for (k = j; k < this.n; k = k + n2) {\r\n                        t1 = c * real[k + n1] - s * img[k + n1];\r\n                        t2 = s * real[k + n1] + c * img[k + n1];\r\n                        real[k + n1] = real[k] - t1;\r\n                        img[k + n1] = img[k] - t2;\r\n                        real[k] = real[k] + t1;\r\n                        img[k] = img[k] + t2;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n\r\n\r\n        public process(t: Array<Complex>): Array<Complex> {\r\n            const reals: Array<number> = new Array<number>(this.n);\r\n            const imgs: Array<number> = new Array<number>(this.n);\r\n            const trans: Array<Complex> = new Array<Complex>(this.n);\r\n            for (let i = 0; i < this.n; i++) {\r\n                reals[i] = t[i].real;\r\n                imgs[i] = t[i].img;\r\n            }\r\n            this.fftCooleyTukey(reals, imgs);\r\n            for (let i = 0; i < this.n; i++) {\r\n                trans[i] = new Complex(reals[i], imgs[i]);\r\n            }\r\n            return trans;\r\n        }\r\n\r\n    }\r\n\r\n"]}