Sponsored Links

Jumat, 26 Januari 2018

Sponsored Links

Speech recognition with C# and the Raspberry Pi | Jeremy Lindsay
src: jeremylindsayni.files.wordpress.com

Speech Recognition Grammar Specification (SRGS) is a W3C standard for how speech recognition grammars are specified. A speech recognition grammar is a set of word patterns, and tells a speech recognition system what to expect a human to say. For instance, if you call an auto-attendant application, it will prompt you for the name of a person (with the expectation that your call will be transferred to that person's phone). It will then start up a speech recognizer, giving it a speech recognition grammar. This grammar contains the names of the people in the auto attendant's directory and a collection of sentence patterns that are the typical responses from callers to the prompt.

SRGS specifies two alternate but equivalent syntaxes, one based on XML, and one using augmented BNF format. In practice, the XML syntax is used more frequently.

Both the ABNF and XML form have the expressive power of a context-free grammar. A grammar processor that does not support recursive grammars has the expressive power of a finite state machine or regular expression language.

If the speech recognizer returned just a string containing the actual words spoken by the user, the voice application would have to do the tedious job of extracting the semantic meaning from those words. For this reason, SRGS grammars can be decorated with tag elements, which when executed, build up the semantic result. SRGS does not specify the contents of the tag elements: this is done in a companion W3C standard, Semantic Interpretation for Speech Recognition (SISR). SISR is based on ECMAScript, and ECMAScript statements inside the SRGS tags build up an ECMAScript semantic result object that is easy for the voice application to process.

Both SRGS and SISR are W3C Recommendations, the final stage of the W3C standards track. The W3C VoiceXML standard, which defines how voice dialogs are specified, depends heavily on SRGS and SISR.


Video Speech Recognition Grammar Specification



Examples

Here is an example of the augmented BNF of SRGS, as it could be used in an auto attendant application:

  #ABNF 1.0 ISO-8859-1;    // Default grammar language is US English  language en-US;    // Single language attachment to tokens  // Note that "fr-CA" (Canadian French) is applied to only  //  the word "oui" because of precedence rules  $yes = yes | oui!fr-CA;    // Single language attachment to an expansion  $people1 = (Michel Tremblay | André Roy)!fr-CA;    // Handling language-specific pronunciations of the same word  // A capable speech recognizer will listen for Mexican Spanish and  //   US English pronunciations.  $people2 = Jose!en-US | Jose!es-MX;    /**   * Multi-lingual input possible   * @example may I speak to André Roy   * @example may I speak to Jose   */  public $request = may I speak to ($people1 | $people2);  

Here is the same SRGS example, using the XML form:


Maps Speech Recognition Grammar Specification



See also

  • SISR
  • VoiceXML
  • Pronunciation Lexicon Specification (PLS)
  • Natural Language Semantics Markup Language
  • JSGF

Vega-Lite: A Grammar of Interactive Graphics - YouTube
src: i.ytimg.com


External links

  • SRGS Specification (W3C Recommendation)
  • SISR Specification (W3C Recommendation)
  • VoiceXML Forum

Source of the article : Wikipedia

Comments
0 Comments