speaker-calibration 2.2.217 → 2.2.218

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 (142) hide show
  1. package/.eslintignore +71 -71
  2. package/.eslintrc.json +40 -40
  3. package/.github/workflows/update-phrases.yml +37 -0
  4. package/.prettierignore +69 -69
  5. package/.prettierrc +14 -14
  6. package/LICENSE +20 -20
  7. package/README.md +133 -133
  8. package/__mocks__/fileMock.js +1 -1
  9. package/__mocks__/styleMock.js +1 -1
  10. package/babel.config.js +3 -3
  11. package/coverage/clover.xml +71 -71
  12. package/coverage/coverage-final.json +224 -224
  13. package/coverage/lcov-report/PythonServerInterface.js.html +265 -265
  14. package/coverage/lcov-report/base.css +354 -354
  15. package/coverage/lcov-report/block-navigation.js +82 -82
  16. package/coverage/lcov-report/favicon.png +0 -0
  17. package/coverage/lcov-report/index.html +123 -123
  18. package/coverage/lcov-report/prettify.css +101 -101
  19. package/coverage/lcov-report/prettify.js +937 -937
  20. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  21. package/coverage/lcov-report/sorter.js +189 -189
  22. package/coverage/lcov-report/src/index.html +121 -121
  23. package/coverage/lcov-report/src/server/PythonServerInterface.js.html +268 -268
  24. package/coverage/lcov-report/src/server/index.html +123 -123
  25. package/coverage/lcov-report/src/tasks/audioCalibrator.js.html +499 -499
  26. package/coverage/lcov-report/src/tasks/audioRecorder.js.html +412 -412
  27. package/coverage/lcov-report/src/tasks/index.html +143 -143
  28. package/coverage/lcov-report/src/tasks/volume/index.html +123 -123
  29. package/coverage/lcov-report/src/tasks/volume/volume.js.html +409 -409
  30. package/coverage/lcov-report/src/utils.js.html +172 -172
  31. package/coverage/lcov.info +91 -91
  32. package/dist/Procfile +0 -0
  33. package/dist/example/NoSleep.min.js +1 -1
  34. package/dist/example/credentials.json.gpg +0 -0
  35. package/dist/example/fetch-languages-sheets.js +77 -77
  36. package/dist/example/i18n.js +28705 -28705
  37. package/dist/example/index.html +47 -47
  38. package/dist/example/listener.html +79 -79
  39. package/dist/example/server.js +51 -51
  40. package/dist/example/speaker.html +145 -145
  41. package/dist/example/speakerUI.js +273 -273
  42. package/dist/example/styles.css +99 -99
  43. package/dist/listener.js +13 -13
  44. package/dist/main.js +12 -12
  45. package/dist/main.js.LICENSE.txt +0 -0
  46. package/dist/mlsGen.js +6814 -6814
  47. package/dist/mlsGen.wasm +0 -0
  48. package/dist/package-lock.json +1018 -1018
  49. package/dist/package.json +18 -18
  50. package/doc/AudioCalibrator.html +417 -417
  51. package/doc/AudioPeer.html +251 -251
  52. package/doc/AudioRecorder.html +195 -195
  53. package/doc/ImpulseResponse.html +215 -215
  54. package/doc/Listener.html +308 -308
  55. package/doc/MlsGenInterface.html +226 -226
  56. package/doc/MyEventEmitter.html +274 -274
  57. package/doc/PythonServerAPI.html +109 -109
  58. package/doc/Speaker-Calibration-UML-Diagram.png +0 -0
  59. package/doc/Speaker.html +276 -276
  60. package/doc/Takes%20a%20target%20element%20where%20html%20elements%20will%20be%20appended..html +128 -128
  61. package/doc/Takes%20the%20url%20of%20the%20current%20site%0Aand%20a%20target%20element%20where%20html%20elements%20will%20be%20appended..html +138 -138
  62. package/doc/Takes%20the%20url%20of%20the%20current%20site%20and%20a%20target%20element%20where%20html%20elements%20will%20be%20appended..html +137 -137
  63. package/doc/Volume.html +88 -88
  64. package/doc/audioCalibrator.js.html +179 -179
  65. package/doc/audioPeer.js.html +175 -175
  66. package/doc/audioRecorder.js.html +163 -163
  67. package/doc/creates%20a%20new%20AudioRecorder%20instance.%20%0ASets%20up%20the%20audio%20context%20and%20file%20reader..html +114 -114
  68. package/doc/fonts/OpenSans-Bold-webfont.eot +0 -0
  69. package/doc/fonts/OpenSans-Bold-webfont.svg +1829 -1829
  70. package/doc/fonts/OpenSans-Bold-webfont.woff +0 -0
  71. package/doc/fonts/OpenSans-BoldItalic-webfont.eot +0 -0
  72. package/doc/fonts/OpenSans-BoldItalic-webfont.svg +1829 -1829
  73. package/doc/fonts/OpenSans-BoldItalic-webfont.woff +0 -0
  74. package/doc/fonts/OpenSans-Italic-webfont.eot +0 -0
  75. package/doc/fonts/OpenSans-Italic-webfont.svg +1829 -1829
  76. package/doc/fonts/OpenSans-Italic-webfont.woff +0 -0
  77. package/doc/fonts/OpenSans-Light-webfont.eot +0 -0
  78. package/doc/fonts/OpenSans-Light-webfont.svg +1830 -1830
  79. package/doc/fonts/OpenSans-Light-webfont.woff +0 -0
  80. package/doc/fonts/OpenSans-LightItalic-webfont.eot +0 -0
  81. package/doc/fonts/OpenSans-LightItalic-webfont.svg +1834 -1834
  82. package/doc/fonts/OpenSans-LightItalic-webfont.woff +0 -0
  83. package/doc/fonts/OpenSans-Regular-webfont.eot +0 -0
  84. package/doc/fonts/OpenSans-Regular-webfont.svg +1830 -1830
  85. package/doc/fonts/OpenSans-Regular-webfont.woff +0 -0
  86. package/doc/global.html +308 -308
  87. package/doc/index.html +58 -58
  88. package/doc/listener.js.html +170 -170
  89. package/doc/mlsGen_mlsGenInterface.js.html +117 -117
  90. package/doc/myEventEmitter.js.html +124 -124
  91. package/doc/peer-connection_audioPeer.js.html +188 -188
  92. package/doc/peer-connection_listener.js.html +311 -311
  93. package/doc/peer-connection_speaker.js.html +381 -381
  94. package/doc/sc-activity-diagram.png +0 -0
  95. package/doc/scripts/linenumber.js +25 -25
  96. package/doc/scripts/prettify/Apache-License-2.0.txt +202 -202
  97. package/doc/scripts/prettify/lang-css.js +24 -24
  98. package/doc/scripts/prettify/prettify.js +640 -640
  99. package/doc/server_PythonServerAPI.js.html +160 -160
  100. package/doc/speaker.js.html +248 -248
  101. package/doc/styles/jsdoc-default.css +371 -371
  102. package/doc/styles/prettify-jsdoc.css +111 -111
  103. package/doc/styles/prettify-tomorrow.css +163 -163
  104. package/doc/tasks_audioCalibrator.js.html +207 -207
  105. package/doc/tasks_audioRecorder.js.html +190 -190
  106. package/doc/tasks_impulse-response_impulseResponse.js.html +442 -442
  107. package/doc/tasks_impulse-response_mlsGen_mlsGenInterface.js.html +175 -175
  108. package/doc/tasks_volume_volume.js.html +185 -185
  109. package/doc/utils.js.html +105 -105
  110. package/jest.config.js +173 -173
  111. package/makefile +74 -0
  112. package/netlify.toml +26 -26
  113. package/package.json +78 -78
  114. package/src/config/firebase.js +26 -26
  115. package/src/index.html +21 -21
  116. package/src/listener-app/listener.js +153 -153
  117. package/src/main.js +23 -23
  118. package/src/myEventEmitter.js +83 -83
  119. package/src/peer-connection/audioPeer.js +183 -183
  120. package/src/peer-connection/listener.js +369 -369
  121. package/src/peer-connection/peerErrors.js +25 -25
  122. package/src/peer-connection/speaker.js +767 -765
  123. package/src/powerCheck.js +98 -98
  124. package/src/server/PythonServerAPI.js +869 -869
  125. package/src/tasks/audioCalibrator.js +360 -360
  126. package/src/tasks/audioRecorder.js +315 -315
  127. package/src/tasks/combination/combination.js +3160 -3160
  128. package/src/tasks/combination/mlsGen/mlsGen.cpp +98 -98
  129. package/src/tasks/combination/mlsGen/mlsGen.hpp +303 -303
  130. package/src/tasks/combination/mlsGen/mlsGenInterface.js +131 -131
  131. package/src/tasks/combination/mlsGen/mlsGenTest.cpp +180 -180
  132. package/src/tasks/impulse-response/impulseResponse.js +610 -610
  133. package/src/tasks/impulse-response/mlsGen/mlsGen.cpp +98 -98
  134. package/src/tasks/impulse-response/mlsGen/mlsGen.hpp +303 -303
  135. package/src/tasks/impulse-response/mlsGen/mlsGenInterface.js +131 -131
  136. package/src/tasks/impulse-response/mlsGen/mlsGenTest.cpp +180 -180
  137. package/src/tasks/volume/volume.cpp +2 -2
  138. package/src/tasks/volume/volume.hpp +22 -22
  139. package/src/tasks/volume/volume.js +279 -279
  140. package/src/utils.js +205 -205
  141. package/webpack.config.js +64 -64
  142. package/.gitignore +0 -81
package/src/powerCheck.js CHANGED
@@ -1,99 +1,99 @@
1
- export const volumePowerCheck = (rec, fs, preSec, Sec, _calibrateSoundPowerBinDesiredSec) => {
2
- const coarseHz = 1 / _calibrateSoundPowerBinDesiredSec;
3
- const power = rec.map(x => Math.pow(x, 2)); // Squared values of the signal
4
-
5
- // Adjust coarseHz so that fs is an integer multiple of coarseHz.
6
- let n = Math.round(fs / coarseHz);
7
-
8
- // Sampling times for plotting
9
- const t = Array.from({ length: power.length }, (_, i) => i / fs);
10
-
11
- const coarseSamples = Math.ceil(power.length / n);
12
- const coarsePowerDb = new Array(coarseSamples).fill(0);
13
- const coarseT = new Array(coarseSamples).fill(0);
14
-
15
- for (let i = 0; i < coarseSamples; i++) {
16
- const indices = Array.from({ length: Math.min(n, power.length - i * n) }, (_, idx) => i * n + idx);
17
- const extremeIndices = [indices[0], indices[indices.length - 1]];
18
-
19
- const avgPower = indices.reduce((sum, idx) => sum + power[idx], 0) / indices.length;
20
- coarsePowerDb[i] = 10 * Math.log10(avgPower);
21
-
22
- const avgTime = (t[extremeIndices[0]] + t[extremeIndices[1]]) / 2;
23
- coarseT[i] = avgTime;
24
- }
25
-
26
- const prepSamples = Math.round(coarseHz * preSec);
27
- const postSamples = Math.round(coarseHz * (preSec + Sec));
28
- const sd = Math.round(standardDeviation(coarsePowerDb.slice(prepSamples)) * 10) / 10;
29
-
30
- const coarseTRounded = coarseT.map(t => Math.round(t * 1000) / 1000); // Round to 3 decimal places
31
- const coarsePowerDbRounded = coarsePowerDb.map(db => Math.round(db * 1000) / 1000); // Round to 3 decimal places
32
-
33
- const start = interpolate(coarseT, coarsePowerDb, preSec);
34
- const end = interpolate(coarseT, coarsePowerDb, preSec + Sec);
35
-
36
- let preT = coarseTRounded.slice(0, prepSamples);
37
- let preDb = coarsePowerDbRounded.slice(0, prepSamples);
38
-
39
- // Adjust starting point of preT and preDb
40
- if (preT[preT.length - 1] < preSec) {
41
- preT.push(preSec);
42
- preDb.push(start);
43
- }
44
-
45
- let recT = coarseTRounded.slice(prepSamples, postSamples);
46
- let recDb = coarsePowerDbRounded.slice(prepSamples, postSamples);
47
-
48
- if (recT[0] > preSec) {
49
- recT.unshift(preSec);
50
- recDb.unshift(start);
51
- }
52
-
53
- if (recT[recT.length - 1] < preSec + Sec) {
54
- recT.push(preSec + Sec);
55
- recDb.push(end);
56
- }
57
-
58
- let postT = coarseTRounded.slice(postSamples);
59
- let postDb = coarsePowerDbRounded.slice(postSamples);
60
-
61
- if (postT[0] > preSec + Sec) {
62
- postT.unshift(preSec + Sec);
63
- postDb.unshift(end);
64
- }
65
-
66
- return { preT, preDb, recT, recDb, postT, postDb, sd };
67
- }
68
-
69
- // Helper function for interpolation
70
- export const interpolate = (x, y, target) => {
71
- let lowIdx = 0;
72
- while (lowIdx < x.length - 1 && x[lowIdx] < target) {
73
- lowIdx++;
74
- }
75
-
76
- const x0 = x[lowIdx - 1];
77
- const y0 = y[lowIdx - 1];
78
- const x1 = x[lowIdx];
79
- const y1 = y[lowIdx];
80
-
81
- // Linear interpolation
82
- return y0 + ((target - x0) * (y1 - y0)) / (x1 - x0);
83
- }
84
-
85
- // Helper function to calculate standard deviation
86
- export const standardDeviation = (arr) => {
87
- const mean = arr.reduce((sum, val) => sum + val, 0) / arr.length;
88
- const variance = arr.reduce((sum, val) => sum + Math.pow(val - mean, 2), 0) / arr.length;
89
- return Math.sqrt(variance);
90
- }
91
-
92
- export const getPower = (dataArray) => {
93
- const squaredValues = dataArray.map(value => value * value);
94
- const sum_of_squares = squaredValues.reduce((total, value) => total + value, 0);
95
- const squared_mean = sum_of_squares / dataArray.length;
96
- const dbLevel = 20 * Math.log10(Math.sqrt(squared_mean));
97
- const roundedDbLevel = Math.round(dbLevel * 10) / 10;
98
- return roundedDbLevel;
1
+ export const volumePowerCheck = (rec, fs, preSec, Sec, _calibrateSoundPowerBinDesiredSec) => {
2
+ const coarseHz = 1 / _calibrateSoundPowerBinDesiredSec;
3
+ const power = rec.map(x => Math.pow(x, 2)); // Squared values of the signal
4
+
5
+ // Adjust coarseHz so that fs is an integer multiple of coarseHz.
6
+ let n = Math.round(fs / coarseHz);
7
+
8
+ // Sampling times for plotting
9
+ const t = Array.from({ length: power.length }, (_, i) => i / fs);
10
+
11
+ const coarseSamples = Math.ceil(power.length / n);
12
+ const coarsePowerDb = new Array(coarseSamples).fill(0);
13
+ const coarseT = new Array(coarseSamples).fill(0);
14
+
15
+ for (let i = 0; i < coarseSamples; i++) {
16
+ const indices = Array.from({ length: Math.min(n, power.length - i * n) }, (_, idx) => i * n + idx);
17
+ const extremeIndices = [indices[0], indices[indices.length - 1]];
18
+
19
+ const avgPower = indices.reduce((sum, idx) => sum + power[idx], 0) / indices.length;
20
+ coarsePowerDb[i] = 10 * Math.log10(avgPower);
21
+
22
+ const avgTime = (t[extremeIndices[0]] + t[extremeIndices[1]]) / 2;
23
+ coarseT[i] = avgTime;
24
+ }
25
+
26
+ const prepSamples = Math.round(coarseHz * preSec);
27
+ const postSamples = Math.round(coarseHz * (preSec + Sec));
28
+ const sd = Math.round(standardDeviation(coarsePowerDb.slice(prepSamples)) * 10) / 10;
29
+
30
+ const coarseTRounded = coarseT.map(t => Math.round(t * 1000) / 1000); // Round to 3 decimal places
31
+ const coarsePowerDbRounded = coarsePowerDb.map(db => Math.round(db * 1000) / 1000); // Round to 3 decimal places
32
+
33
+ const start = interpolate(coarseT, coarsePowerDb, preSec);
34
+ const end = interpolate(coarseT, coarsePowerDb, preSec + Sec);
35
+
36
+ let preT = coarseTRounded.slice(0, prepSamples);
37
+ let preDb = coarsePowerDbRounded.slice(0, prepSamples);
38
+
39
+ // Adjust starting point of preT and preDb
40
+ if (preT[preT.length - 1] < preSec) {
41
+ preT.push(preSec);
42
+ preDb.push(start);
43
+ }
44
+
45
+ let recT = coarseTRounded.slice(prepSamples, postSamples);
46
+ let recDb = coarsePowerDbRounded.slice(prepSamples, postSamples);
47
+
48
+ if (recT[0] > preSec) {
49
+ recT.unshift(preSec);
50
+ recDb.unshift(start);
51
+ }
52
+
53
+ if (recT[recT.length - 1] < preSec + Sec) {
54
+ recT.push(preSec + Sec);
55
+ recDb.push(end);
56
+ }
57
+
58
+ let postT = coarseTRounded.slice(postSamples);
59
+ let postDb = coarsePowerDbRounded.slice(postSamples);
60
+
61
+ if (postT[0] > preSec + Sec) {
62
+ postT.unshift(preSec + Sec);
63
+ postDb.unshift(end);
64
+ }
65
+
66
+ return { preT, preDb, recT, recDb, postT, postDb, sd };
67
+ }
68
+
69
+ // Helper function for interpolation
70
+ export const interpolate = (x, y, target) => {
71
+ let lowIdx = 0;
72
+ while (lowIdx < x.length - 1 && x[lowIdx] < target) {
73
+ lowIdx++;
74
+ }
75
+
76
+ const x0 = x[lowIdx - 1];
77
+ const y0 = y[lowIdx - 1];
78
+ const x1 = x[lowIdx];
79
+ const y1 = y[lowIdx];
80
+
81
+ // Linear interpolation
82
+ return y0 + ((target - x0) * (y1 - y0)) / (x1 - x0);
83
+ }
84
+
85
+ // Helper function to calculate standard deviation
86
+ export const standardDeviation = (arr) => {
87
+ const mean = arr.reduce((sum, val) => sum + val, 0) / arr.length;
88
+ const variance = arr.reduce((sum, val) => sum + Math.pow(val - mean, 2), 0) / arr.length;
89
+ return Math.sqrt(variance);
90
+ }
91
+
92
+ export const getPower = (dataArray) => {
93
+ const squaredValues = dataArray.map(value => value * value);
94
+ const sum_of_squares = squaredValues.reduce((total, value) => total + value, 0);
95
+ const squared_mean = sum_of_squares / dataArray.length;
96
+ const dbLevel = 20 * Math.log10(Math.sqrt(squared_mean));
97
+ const roundedDbLevel = Math.round(dbLevel * 10) / 10;
98
+ return roundedDbLevel;
99
99
  }