Не удается заставить Google STT API работать на встроенном компьютере (AArch64) - PullRequest
0 голосов
/ 30 апреля 2019

Мне нужно установить GoogleSTT на компьютере, но код не работает, он работает, когда я нахожусь на моем компьютере, но не на моей системе Buildroot.

Я получил эту ошибку во время выполнения:

    /root/node_modules/grpc/src/grpc_extension.js:57
        throw e;
        ^

    Error: File not found
        at Object.Module._extensions..node (module.js:681:18)
        at Module.load (module.js:565:32)
        at tryModuleLoad (module.js:505:12)
        at Function.Module._load (module.js:497:3)
        at Module.require (module.js:596:17)
        at require (internal/module.js:11:18)
        at Object.<anonymous>                                                                         
    (/root/node_modules/grpc/src/grpc_extension.js:32:13)
        at Module._compile (module.js:652:30)
        at Object.Module._extensions..js (module.js:663:10)
        at Module.load (module.js:565:32)

Возможно, мне не хватает пакета, но все упомянутое выше установлено правильно, код был проверен на моем компьютере без ошибок,

Я попытался очистить кеш, восстановить модулис -f

const io = require("socket.io-client");
const record = require('node-record-lpcm16');
const speech = require('@google-cloud/speech');


const client = new speech.SpeechClient();
var socket = io.connect("http://90.87.53.32:7700/");

const encoding = 'LINEAR16';
const sampleRateHertz = 16000;
const languageCode = 'fr-FR';

const request = {
    config: {
        encoding: encoding,
        sampleRateHertz: sampleRateHertz,
        languageCode: languageCode,
        enableAutomaticPunctuation: true,
    },
    interimResults: true, // If you want interim results, set this to true
};


/*class Socket {
    constructor() {
        process.on('message', (msg) => {
            this.set(msg);
        });
        process.send('loaded');
    }
}*/

const recognizeStream = client
    .streamingRecognize(request)
    .on('error', console.error)
    .on('data', data =>
        socket.emit("lol", (
            data.results[0] && data.results[0].alternatives[0]
                ? `Transcription: ${data.results[0].alternatives[0].transcript}\n`
                : `\n\nReached transcription time limit, press Ctrl+C\n`))
    );

socket.on('connect', function () {
    record
        .start({
            sampleRateHertz: sampleRateHertz,
            threshold: 0,
            verbose: false,
            recordProgram: 'arecord', // Try also "arecord" or "sox"
            silence: '10.0',
        })
        .on('error', console.error)
        .pipe(recognizeStream);

    console.log('Listening, press Ctrl+C to stop.');
    socket.emit('lol', "Message");
});

возникает та же ошибка с или без socket.io-client.

, поскольку мой BIOS не имеет RTC, у меня есть какой-то жестко запрограммированный метод обновления временитак что Google может не иметь возможности установить правильную дату и время на моем компьютере, но я думаю, что он дает сбой даже перед выполнением чего-либо

Здесь больше информации:

npm

process.versions

{ http_parser: '2.8.1',
  node: '8.11.4',
  v8: '6.2.414.54',
  uv: '1.20.2',
  zlib: '1.2.11',
  ares: '1.14.0',
  modules: '57',
  nghttp2: '1.32.0',
  napi: '3',
  openssl: '1.0.2p' }

os.platform ()

'linux'

os.arch ()

'arm64'

_

Сист

uname -a

Linux buildroot 4.14.29-v8 #1 SMP PREEMPT Mon Apr 29 13:48:27 UTC 2019 aarch64 GNU/Linux дата здесь нарушена из-за отсутствия rtc, как я уже говорил, для связи с серверами узлов мне нужно вручную установить правильную дату и время

npmls grpc

/root -- @google-cloud/speech@2.3.1 -- google-gax@0.25.6 +-- grpc@1.20.2 -- grpc-gcp@0.1.1 -- grpc@1.20.2 deduped

ls -lR node_modules / grpc / src / node

node_modules/grpc/src/node:
    total 1
    drwxr-xr-x    3 root     root          1024 Apr 30  2019 extension_binary

 node_modules/grpc/src/node/extension_binary:
    total 1
    drwxr-xr-x    2 root     root          1024 Apr 30  2019 node-v57-linux-                    
    arm64-glibc

 node_modules/grpc/src/node/extension_binary/node-v57-linux-arm64-glibc:
    total 13983
    -rwxr-xr-x    1 root     root      14318016 Apr 26  2019 grpc_node.node

плюс: как обновить часы машины

date -s "$(wget -qSO- google.com 2>&1 | grep Date: | cut -d' ' -f5-8 | awk -v FS=' ' -v OFS=- '{print $3,$2,$1,$4}' | sed -r 's/\bJan\b/01/g; s/\bFeb\b/02/g; s/\bMar\b/03/g; s/\bApr\b/04/g; s/\bMay\b/05/g; s/\bJun\b/06/g; s/\bJul\b/07/g; s/\bAug\b/08/g; s/\bSep\b/09/g; s/\bOct\b/10/g; s/\bNov\b/11/g; s/\bDec\b/12/g' | sed 's/./ /11')"

Идет исправление

Выполненные действия:

Изменение l: 32 из /root/node_modules/grpc/src/grpc_extension.js

binary.find(path.resolve(path.join(__dirname, '../package.json')));

Соответствующий путь - /root/node_modules/grpc/src/node/extension_binary/node-v57-linux-arm64-glibc/grpc_node.node, который является правильным двоичным путем

, пытаясьигнорировать это приведет меня к отсутствию функций из gRPC и разрешить использовать его:

/root/node_modules/grpc/src/client_interceptors.js:664
  [grpc.opType.SEND_MESSAGE]: [grpc.opType.SEND_INITIAL_METADATA],
               ^
 TypeError: Cannot read property 'SEND_MESSAGE' of undefined
    at Object.<anonymous> 
    (/root/node_modules/grpc/src/client_interceptors.js:664:16)
    at Module._compile (module.js:652:30)
    at Object.Module._extensions..js (module.js:663:10)
    at Module.load (module.js:565:32)
    at tryModuleLoad (module.js:505:12)
    at Function.Module._load (module.js:497:3)
    at Module.require (module.js:596:17)
    at require (internal/module.js:11:18)
    at Object.<anonymous> (/root/node_modules/grpc/src/client.js:35:27)
    at Module._compile (module.js:652:30)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...