当我将其设置为转录音频文件时,如何在 Sphinx 4 中获取时间索引(或帧号)?
我正在使用的代码如下所示:
audioURL = ...
AudioFileDataSource dataSource = (AudioFileDataSource) cm.lookup("audioFileDataSource");
dataSource.setAudioFile(audioURL, null);
Result result;
while ((result = Recognizer.recognize()) != null) {
Token token = result.getBestToken();
//DoubleData data = (DoubleData) token.getData();
//long frameNum = data.getFirstSampleNumber(); // data seem always null
String resultText = token.getWordPath(false, false);
...
}
我试图从结果/令牌对象中获取转录时间,例如类似于字幕制作者所做的事情。我找到了 Result.getFrameNumber() 和 Token.getFrameNumber() 但它们似乎返回解码的帧数,而不是在整个音频文件的上下文中找到结果的时间(或帧)。
我查看了 AudioFileDataSource.getDuration()[=private] 和识别器类,但还没有弄清楚如何获得所需的转录时间索引..
想法?:)