3
我正在嘗試使用python進行語音識別。除此之外,我需要得到每個單詞的開始和結束時間。Python - 語音識別時間偏移
我寧願使用一個可以處理這個問題的免費庫。我聽說獅身人面像能夠做到這一點,但我找不到任何示例(對於Python來說)。
我將不勝感激任何幫助或建議。
我正在嘗試使用python進行語音識別。除此之外,我需要得到每個單詞的開始和結束時間。Python - 語音識別時間偏移
我寧願使用一個可以處理這個問題的免費庫。我聽說獅身人面像能夠做到這一點,但我找不到任何示例(對於Python來說)。
我將不勝感激任何幫助或建議。
事情是這樣的:
from os import environ, path
from pocketsphinx.pocketsphinx import *
from sphinxbase.sphinxbase import *
MODELDIR = "../../../model"
DATADIR = "../../../test/data"
config = Decoder.default_config()
config.set_string('-hmm', path.join(MODELDIR, 'en-us/en-us'))
config.set_string('-lm', path.join(MODELDIR, 'en-us/en-us.lm.bin'))
config.set_string('-dict', path.join(MODELDIR, 'en-us/cmudict-en-us.dict'))
config.set_string('-logfn', '/dev/null')
decoder = Decoder(config)
stream = open(path.join(DATADIR, 'goforward.raw'), 'rb')
in_speech_bf = False
decoder.start_utt()
while True:
buf = stream.read(1024)
if buf:
decoder.process_raw(buf, False, False)
if decoder.get_in_speech() != in_speech_bf:
in_speech_bf = decoder.get_in_speech()
if not in_speech_bf:
decoder.end_utt()
print ('Result:', decoder.hyp().hypstr)
print ([(seg.word, seg.prob, seg.start_frame, seg.end_frame) for seg in decoder.seg()])
decoder.start_utt()
else:
break
decoder.end_utt()
更多的例子here。