File size: 2,451 Bytes
ba88daa
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
abfa0a3
ba88daa
abfa0a3
ba88daa
 
 
 
abfa0a3
 
ba88daa
 
 
 
 
abfa0a3
ba88daa
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
// return an object
// {
//   samples: a float32 array
//   sampleRate: an integer
// }
function readWave(filename, Module) {
  const filenameLen = Module.lengthBytesUTF8(filename) + 1;
  const pFilename = Module._malloc(filenameLen);
  Module.stringToUTF8(filename, pFilename, filenameLen);

  const w = Module._SherpaOnnxReadWave(pFilename);
  Module._free(pFilename);


  const samplesPtr = Module.HEAP32[w / 4] / 4;
  const sampleRate = Module.HEAP32[w / 4 + 1];
  const numSamples = Module.HEAP32[w / 4 + 2];

  const samples = new Float32Array(numSamples);
  for (let i = 0; i < numSamples; i++) {
    samples[i] = Module.HEAPF32[samplesPtr + i];
  }

  Module._SherpaOnnxFreeWave(w);

  return {samples: samples, sampleRate: sampleRate};
}

function readWaveFromBinaryData(uint8Array, Module) {
  const numBytes = uint8Array.length * uint8Array.BYTES_PER_ELEMENT;
  const pointer = Module._malloc(numBytes);

  const dataOnHeap = new Uint8Array(Module.HEAPU8.buffer, pointer, numBytes);
  dataOnHeap.set(uint8Array);

  const w =
      Module._SherpaOnnxReadWaveFromBinaryData(dataOnHeap.byteOffset, numBytes);
  if (w == 0) {
    console.log('Failed to read wave from binary data');
    return null;
  }

  Module._free(pointer);

  const samplesPtr = Module.HEAP32[w / 4] / 4;
  const sampleRate = Module.HEAP32[w / 4 + 1];
  const numSamples = Module.HEAP32[w / 4 + 2];

  const samples = new Float32Array(numSamples);
  for (let i = 0; i < numSamples; i++) {
    samples[i] = Module.HEAPF32[samplesPtr + i];
  }

  Module._SherpaOnnxFreeWave(w);


  return {samples: samples, sampleRate: sampleRate};
}

// data is an object
// {
//   samples: a float32 array
//   sampleRate: an integer
// }
function writeWave(filename, data, Module) {
  const pSamples =
      Module._malloc(data.samples.length * data.samples.BYTES_PER_ELEMENT);
  Module.HEAPF32.set(data.samples, pSamples / data.samples.BYTES_PER_ELEMENT);

  const filenameLen = Module.lengthBytesUTF8(filename) + 1;
  const pFilename = Module._malloc(filenameLen);
  Module.stringToUTF8(filename, pFilename, filenameLen);

  Module._SherpaOnnxWriteWave(
      pSamples, data.samples.length, data.sampleRate, pFilename);

  Module._free(pFilename);
  Module._free(pSamples);
}

if (typeof process == 'object' && typeof process.versions == 'object' &&
    typeof process.versions.node == 'string') {
  module.exports = {
    readWave,
    writeWave,
    readWaveFromBinaryData,
  };
}