Merge branch 'javascript-buffer-length' (Fixes #2693)

This commit is contained in:
Reuben Morais 2020-01-27 21:22:25 +01:00
commit 1d6a337ab4
2 changed files with 7 additions and 5 deletions

View File

@ -109,12 +109,10 @@ audioStream.on('finish', () => {
console.error('Running inference.'); console.error('Running inference.');
const audioLength = (audioBuffer.length / 2) * (1 / desired_sample_rate); const audioLength = (audioBuffer.length / 2) * (1 / desired_sample_rate);
// We take half of the buffer_size because buffer is a char* while
// LocalDsSTT() expected a short*
if (args['extended']) { if (args['extended']) {
console.log(metadataToString(model.sttWithMetadata(audioBuffer.slice(0, audioBuffer.length / 2)))); console.log(metadataToString(model.sttWithMetadata(audioBuffer)));
} else { } else {
console.log(model.stt(audioBuffer.slice(0, audioBuffer.length / 2))); console.log(model.stt(audioBuffer));
} }
const inference_stop = process.hrtime(inference_start); const inference_stop = process.hrtime(inference_start);
console.error('Inference took %ds for %ds audio file.', totalTime(inference_stop), audioLength.toPrecision(4)); console.error('Inference took %ds for %ds audio file.', totalTime(inference_stop), audioLength.toPrecision(4));

View File

@ -18,8 +18,12 @@ using namespace node;
char* bufferData = Buffer::Data(bufferObj); char* bufferData = Buffer::Data(bufferObj);
size_t bufferLength = Buffer::Length(bufferObj); size_t bufferLength = Buffer::Length(bufferObj);
if (bufferLength % 2 != 0) {
SWIG_exception_fail(SWIG_ERROR, "Buffer length must be even. Make sure your input audio is 16-bits per sample.");
}
$1 = ($1_ltype)bufferData; $1 = ($1_ltype)bufferData;
$2 = ($2_ltype)bufferLength; $2 = ($2_ltype)(bufferLength / 2);
} }
// apply to DS_FeedAudioContent and DS_SpeechToText // apply to DS_FeedAudioContent and DS_SpeechToText