recognize_file(path, dict, jsgf, hmm, add_params="", timeout=60); - распознать звуковой файл как речь, используя Open Source Speech Recognition Toolkit CMU Sphinx
- файл должен быть с разрешением 128 Kb/s (8 kHz) ( Изменить формат файла можно через sound->convert_file )
Функция на вход принимает параметры:
path – путь к звуковому файлу, который нужно распознать (формат wav, дискретизация должна соответствовать дискретизации используемой модели) dict – путь к словарю (путь должен быть относительно папки Audio Tools) jsgf – путь к файлу грамматики (формат JSGF (путь должен быть относительно папки Audio Tools) hmm – путь к каталогу hmm модели (путь должен быть относительно папки Audio Tools) add_params – дополнительные параметры командной строки для запуска pocketsphinx_continuous.exe timeout – максимальное время, которое будет отведено на эту операцию
После отработки функция возвращает результат своей работы в робот :
true – последовательность цифр , продиктованных в звуковом файле (через пробел) false – операция не была успешно завершена
Пример использования recognize_file (Python):
# Additional paths import sys sys.path.insert(0, '../../../Templates PY/') xhe_host = "127.0.0.1:7010" from xweb_human_emulator import * # начало echo("<hr><font color=blue>sound.xxxxxxxxx</font><hr>") # 1 echo("1. Подготовим файл : ") echo(sound.convert_file("test/mp3/4196092774.mp3","test/mp3/4196092774.wav","8000"),"\n") # 2 echo("2. Распознаем файл с английскими цифрами (0-9) используя CMU Sphinx : ") echo(sound.recognize_file("test/mp3/4196092774.wav","digits\\digits.dict","digits\\digits.gram","cmusphinx-en-us-8khz-5.2","-samprate 8000 -remove_dc yes -remove_noise no -vad_threshold 3.4 -vad_prespeech 19 -vad_postspeech 37 -silprob 2.5"),"\n") # конец echo("<hr><br>") # Quit app.quit()
Пример использования recognize_file (JS):
// подключим объект для управления эмулятором, если еще не подключен xhe_host="127.0.0.1:7022"; echo=require("../../../Templates JS/init.js"); // начало echo("<hr><font color=blue>sound.play_sound</font><hr>"); // 1 echo("1. Подготовим файл : "); echo(sound.convert_file("test/mp3/4196092774.mp3","test/mp3/4196092774.wav","8000")+"\n"); // 2 echo("2. Распознаем файл с английскими цифрами (0-9) используя CMU Sphinx : "); echo(sound.recognize_file("test/mp3/4196092774.wav","digits\\digits.dict","digits\\digits.gram","cmusphinx-en-us-8khz-5.2","-samprate 8000 -remove_dc yes -remove_noise no -vad_threshold 3.4 -vad_prespeech 19 -vad_postspeech 37 -silprob 2.5")+"\n"); // конец echo("<hr><br>"); // Quit app.quit();