如下面的代码所示,当使用ssml语句请求azure TTS时,响应被延迟了大约2秒。
public static async Task SynthesizeAudioAsync()
{
var config = SpeechConfig.FromSubscription("xxxxxxxxxKey", "xxxxxxxRegion");
using var synthesizer = new SpeechSynthesizer(config, null);
var ssml = File.ReadAllText("C:/ssml.xml");
var result = await synthesizer.SpeakSsmlAsync(ssml); <=== The delay is right here
using var stream = AudioDataStream.FromResult(result);
await stream.SaveToWaveFileAsync("C:/file.wav");
}
有什么问题吗?还是响应速度延迟2秒是正常现象?
发布于 2021-01-19 13:08:47
var result = await synthesizer.SpeakSsmlAsync(ssml);
据我所知,转换语音所需的时间与ssml中的数据成正比。
在后端发生的事情是: ssml数据被中继到Azure Speech Services,azure speech service处理文本,使用ML Model构建所需的音频字节,并返回给请求客户端。
我假设您所说的延迟就是执行上述过程的延迟。如果要识别的数据/文本很大,则需要相当长的时间来构建所需的音频字节。
由于您使用的是await
,代码将一直等待,直到它完成。
https://stackoverflow.com/questions/65775889
复制相似问题