我有一些来自System.Speech.Recognition的简单代码,它们工作得很好:
using (var recognizer = new SpeechRecognitionEngine(new CultureInfo("en-US")))
{
recognizer.LoadGrammar(new DictationGrammar());
recognizer.SpeechRecognized += recognizer_SpeechRecognized;
recognizer.SetInputToDefaultAudioDevice();
recognizer.RecognizeAsync(RecognizeMode.Multiple);
}
private void recognizer_SpeechRecognized(object sender, SpeechRecognizedEventArgs e)
{
textBox1.Text = "Recognized text: " + e.Result.Text;
}当我使用Windows7的时候,我在"Control Panel" -> "Speech Recognition" -> "Train your computer to better understand you"做演讲训练。
我的程序是否自动利用已完成的任何训练?培训的好处是基于用户还是基于机器?这些语音“配置文件”可以(轻松)移动吗?
发布于 2013-04-02 08:33:21
是的,训练(尤其是听写)是有用的。通过训练,准确率可以提高20-50%。(如果用户有口音,这一点尤其正确。)
培训收益是按用户计算的。
微软有一个复制语音配置文件的工具,但它是为较旧版本的SR引擎(XP时代)构建的,据我所知,微软没有人愿意更新它或在较新的SR引擎上保证它。如果你想尝试一下,搜索"Speech Profile Manager",它就会弹出来。
发布于 2013-03-07 06:07:22
是的,看起来虽然可能不需要训练它,但它是可以做到的:this site和this site。
发布于 2013-03-08 02:51:47
我认为当你使用听写语法时,训练会很有帮助。如果你使用的是更有限的应用程序语法,那么训练就不那么有价值了。
请记住,Windows client speech recognition API (System.Speech)和服务器端speech recognition API (Microsoft.speech)之间的主要区别之一是,服务器API是为多用户设计的,并且不能被训练(考虑到语音自动电话系统,您不能训练每个呼叫者)。如果你有好奇心,这个SO问题可能会有帮助- What is the difference between System.Speech.Recognition and Microsoft.Speech.Recognition?
https://stackoverflow.com/questions/15258987
复制相似问题