-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathbenchmark.js
37 lines (33 loc) · 951 Bytes
/
benchmark.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
import Pianolizer from './pianolizer.js'
const print = globalThis.process?.release?.name
? console.log // Browser
: postMessage // NodeJS
const pianolizer = new Pianolizer(44100)
const bufferSize = 128
const input = new Float32Array(bufferSize)
let output
const start = performance.now()
let i
for (i = 0; i < bufferSize * 10000; i++) {
const j = i % bufferSize
input[j] = ((i % 100) / 50.0) - 1.0 // sawtooth, 441Hz
if (j === bufferSize - 1) {
output = pianolizer.process(input, 0.05)
}
}
const end = performance.now()
const elapsed = (end - start) / 1000
const message = '# benchmark: ' + Math.round(i / elapsed) + ' samples per second'
print(message)
const test = {
21: 0.0000176868034031,
33: 0.6048160195350647,
45: 0.1517304629087448,
52: 0.0671678557991981,
57: 0.0384459346532821
}
for (const key in test) {
if (Math.abs(output[key] - test[key]) > 1e-7) {
throw new Error('BAD OUTPUT FOR KEY ' + key)
}
}