Version: January 23, 2007
Copyright ©2007 W3C® (MIT, ERCIM, Keio), All Rights Reserved. W3C liability, trademark and document use rules apply.
The W3C Semantic Interpretation for Speech Recognition (SISR) Version 1.0 Specification
entered the Candidate Recommendation period on 11 January 2006. Based on vendors' implementation feedback, the specification was later modified (the
the starttime / endtime feature was removed) and republished as a Last Call Working Draft.
The planned time period for entering Proposed Recommendation is January 2007.
Preparation of an Implementation Report is a key criteria for moving beyond the Candidate Recommendation. This document describes the requirements for the Implementation Report and the process that the Voice Browser Working Group will follow in preparing the report. This document has been updated since its original publication to include implementation report data collected from vendors.
During the CR period, the Working Group will carry out the following activities:
You are invited to contribute to the assessment of the W3C SISR 1.0 Specification by participating in the Implementation Report process.
starttime/endtime feature (the archive contains a change
 log listing the updates).The VBWG established the following entrance criteria to Proposed Recommendation in the Request for CR:
Loquendo believes speech market can take great benefit from speech standards and is continuously supporting their development and deployment. As an active member of the W3C Voice Browser group, Loquendo welcomes the Semantic Interpretation for Speech Recognition recommendation as the last step toward a standard-only speech grammar definition. Further to the full implementation of the W3C SRGS (voice and DTMF mode, ABNF and XML syntax, signal and text input), Loquendo ASR 7.0 now fully supports SISR specification, enabling the developer to use both "Script" and "String Literal" tag syntaxes, for an easy yet powerful EcmaScript-based Semantic Interpretation. The support of SISR standard is also available in all Loquendo products exploiting ASR, namely Loquendo Speech Suite, the client server solution based on MRCP, as well as VoxNauta, the VoiceXML/CCXML voice platform solution.
Required features:
Optional features:
Nuance is pleased to see the W3C Semantic Interpretation for Speech Recognition (SISR) 1.0 specification moving toward final Recommendation. We have implemented SISR in our high performance network-based speech recognition engine and expect SISR to be widely adopted by telephony platform vendors and by other users of automatic speech recognition. We note from experience with the current Candidate Recommendation and earlier drafts that SISR and the Speech Recognition Grammar Specification can be combined to build powerful speech recognition-based applications. Implementation Details: Nuance has implemented all required and all but two optional features in the SISR standard: limited portions of XML fragment generation and the metadata 'starttime' and 'endtime' variables are not supported.
Voxpilot has found the W3C Semantic Interpretation for Speech Recognition (SISR) Version 1 to be a complete and consistent specification suitable for implementation. Semantic interpretation is a crucial brick within the W3C Speech Interface Framework and provides a powerful mechanism to associate meaning or semantics with raw utterances detected by speech recognisers. Semantic interpretation is a necessity for contemporary speech applications. The XML serialisation of the ECMAScript result mechanism (c.f. Section 7) is valuable for representing semantic results within XML data interchange formats and of particular use within the IETF Media Resource Control Protocol (MRCP) when conveying semantic results from speech servers to clients.
The following table lists the assertions that were derived from the SISR 1.0 Specification. The Assertion ID column uniquely identifies the assertion and links to a corresponding test. The Spec column identifies the section of the specification from which the assertion was derived. The Required column indicates whether or not the spec requires the platform to implement the feature described by the assertion. The Automatable column indicates whether or not the associated test can be automated or requires manual execution. The Assertion column describes the assertion.
Note:
The original version
of this document included tests for the starttime / endtime feature. During the
Call for Implementations, insufficient implementation data was received for this feature and at least one
vendor queried its merit, pointing out that other mechanisms for obtaining such information are possible.
As a result, the working group decided to remove the feature and republish the specification as a
Last Call Working Draft. In this version
of the Implementation Report Plan, those tests related to the starttime / endtime feature
have been removed (namely assertions 139-147, 150-153, and 155).
| ID | Spec | Req | Auto | Assertion | Results | ||
|---|---|---|---|---|---|---|---|
| Pass | Fail | N/I | |||||
| 2 | [4.2] | Yes. | Yes. | The header of an SRGS grammar may contain one or more global SI Tags. In grammars using the Script tag syntax, these tags are executed before any of the SI Tags in the matching grammar rules are evaluated. | 3 | 0 | 0 | 
| 3 | [4.2] | Yes. | Yes. | Global tags are ignored in Grammars using the String Literal tag syntax. | 3 | 0 | 0 | 
| 4 | [4.2] | Yes. | Yes. | The SI Tags are evaluated only once, in a global scope that will be shared by all evaluations. | 3 | 0 | 0 | 
| 5 | [4.2] | Yes. | Yes. | SI Tags in the grammar header have write access to the global scope to inizialize it. | 3 | 0 | 0 | 
| 6 | [5] | Yes. | Yes. | For a given parse, if there is no SI Tag attached to the expansion in the grammar rule and there are no rule references in the parse, the value for the text meta variable is automatically copied into the Rule Variable 'out' (which then becomes of type string). Applied to semantic literals. | 3 | 0 | 0 | 
| 7 | [5] | Yes. | Yes. | For a given parse, if there is no SI Tag attached to the expansion in the grammar rule that is used to match the utterance, then if there is at least one rule reference, the value of the Rule Variable of the last rule reference in the parse is automatically copied into the Rule Variable.Applied to semantic literals. | 3 | 0 | 0 | 
| 8 | [3.3.1] | Yes. | Yes. | Every grammar rule has a single Rule Variable that holds an ECMAScript Compact Profile variable. | 3 | 0 | 0 | 
| 9 | [3.3.1] | Yes. | Yes. | The Rule Variable can be evaluated. | 3 | 0 | 0 | 
| 10 | [3.3.1] | Yes. | Yes. | The Rule Variable can be assigned to. | 3 | 0 | 0 | 
| 11 | [3.3.1] | Yes. | Yes. | The Rule Variable is identified by 'out'. | 3 | 0 | 0 | 
| 13 | [3.3.1] | Yes. | Yes. | Properties of the Rule Variable can be individually accessed by out.Identifier where Identifier is the name of the property. | 3 | 0 | 0 | 
| 15 | [3.3.2] | Yes. | Yes. | SI Scripts can access the Rule Variable associated with grammar rules referenced in SI Tags that appear after (to the right or below) the rule reference in the grammar expansion, and only if the referenced rule was used in the expansion that matched the input utterance. | 3 | 0 | 0 | 
| 16 | [3.3.2] | Yes. | Yes. | Rule Variables associated to a rule reference can be evaluated. | 3 | 0 | 0 | 
| 17 | [3.3.2] | Yes. | Yes. | Rule Variables associated to referenced rules can be assigned to. | 3 | 0 | 0 | 
| 18 | [3.3.2] | Yes. | Yes. | The Rule Variable associated to a rule reference is identified by rules.Rulename, where Rulename is the rulename of the rule, as defined in SRGS Section 3.1 Basic Rule Definition. | 3 | 0 | 0 | 
| 20 | [3.3.2] | Yes. | Yes. | Individual properties of a Rule Variable.Identifier can be identified by rules.Rulename, where Rulename is the name of the rule and Identifier is the name of the property. | 3 | 0 | 0 | 
| 22 | [3.3.2] | Yes. | Yes. | Every SI Script has access to a rules object that has a property holding the Rule Variable value for every visible rule; the property name is the name of the rule to which the Rule Variable is associated. | 3 | 0 | 0 | 
| 23 | [3.3.2] | Yes. | Yes. | The Rule Variable for the latest rule reference that was used in the expansion matching the utterance up to the position of the SI Tag can be referenced through rules.latest(). | 3 | 0 | 0 | 
| 25 | [3.3.2] | Yes. | Yes. | In an expression, the Rule Variable of the current grammar rule can be evaluated. | 3 | 0 | 0 | 
| 26 | [3.3.2] | Yes. | Yes. | In an expression, the Rule Variable of the current grammar rule can be assigned to. | 3 | 0 | 0 | 
| 27 | [3.3.2] | Yes. | Yes. | In an expression, the rule variables of the referenced rules can be evaluated. | 3 | 0 | 0 | 
| 28 | [3.3.2] | Yes. | Yes. | In an expression, the rule variables of the referenced rules can be assigned to. | 3 | 0 | 0 | 
| 29 | [3.3.2] | Yes. | Yes. | Special Rule NULL can not be evaluated. | 3 | 0 | 0 | 
| 30 | [3.3.3] | Yes. | Yes. | A Rule Variable's text variable is identified by meta.rulename.text, where rulename is the name of the Rule Variable. | 3 | 0 | 0 | 
| 32 | [3.3.3] | Yes. | Yes. | The text variable of the Rule Variable referred to by rules.latest() is identified by meta.latest().text. | 3 | 0 | 0 | 
| 36 | [3.3.3] | Yes. | Yes. | The text variable associated to the current grammar rule is identified by meta.current().text. | 3 | 0 | 0 | 
| 38 | [3.3.3] | Yes. | Yes. | The text variable of the current grammar is read only. | 3 | 0 | 0 | 
| 39 | [3.3.3] | No. | Yes. | A Rule Variable's score variable is identified by meta.rulename.score, where rulename is the name of Rule Variable. | 2 | 0 | 1 | 
| 41 | [3.3.3] | No. | Yes. | The score variable of the Rule Variable referred to by rules.latest() is identified by meta.latest().score. | 2 | 0 | 1 | 
| 45 | [3.3.3] | No. | Yes. | The score variable associated to the current grammar rule is identified by meta.current().score. | 2 | 0 | 1 | 
| 47 | [3.3.3] | No. | Yes. | The score variable of the current grammar rule is read-only. | 2 | 0 | 1 | 
| 48 | [6.3] | Yes. | Yes. | Before evaluating any scripts in the flat parse list, a global anonymous ECMAScript scope is created for the grammar. This global scope is initialized by executing the scripts that are in the global tags in the grammar header. | 3 | 0 | 0 | 
| 49 | [6.3] | Yes. | Yes. | During evaluation of a script in the flat parse list, the global scope is accessible for reading only. | 2 | 1 | 0 | 
| 50 | [6.3] | Yes. | Yes. | The tags within a flat parse are executed in the order in which they appear, left to right. | 3 | 0 | 0 | 
| 51 | [6.3] | Yes. | Yes. | The global tags (in the grammar header) are executed in document order. | 3 | 0 | 0 | 
| 52 | [6.3] | Yes. | Yes. | For each flat parse , a new anonymous ECMAScript scope is created that is a direct child of the global scope object for the grammar in which the related rule is defined. | 3 | 0 | 0 | 
| 53 | [6.3] | Yes. | Yes. | The ECMAScript scope chains always have the global scope (the scope of the whole parse) as top-level object, and the scope belonging to the parse list as successor. | 3 | 0 | 0 | 
| 54 | [6.3] | Yes. | Yes. | Access to variables in tag executions are resolved with the scope chain according to the ECMAScript rules. | 3 | 0 | 0 | 
| 55 | [6.3] | Yes. | Yes. | The variables object according to ES-CP is the scope object created for this rule. This means that local variables that are defined in tags belonging to a rule reference are created in the scope object that was created for this rule. | 3 | 0 | 0 | 
| 56 | [6.3] | Yes. | Yes. | When the environment of a new scope is set up, the variable out is initialized as an empty object. | 3 | 0 | 0 | 
| 59 | [6.3] | Yes. | Yes. | When the environment of a new scope is set up, meta.current().text is initialized (read-only) to the text variable of the current grammar rule. | 3 | 0 | 0 | 
| 61 | [6.3] | No. | Yes. | When the environment of a new scope is set up, meta.score is initialized (read-only) to the score value related to the current grammar rule | 2 | 0 | 1 | 
| 62 | [6.3] | Yes. | Yes. | When execution of the flat parse is finished, the scope object of this flat parse is removed from the scope chain . | 3 | 0 | 0 | 
| 64 | [6.3] | Yes. | Yes. | When execution of the flat parse is finished, rules.rulename of the scope of the referencing rule, where rulename is the name of the referenced rule, is set to the value of the variable out of the child scope. | 3 | 0 | 0 | 
| 68 | [6.3] | Yes. | Yes. | When execution of the flat parse is finished, rules.latest() = rules.rulename (both variables are in the scope of the referencing rule) | 3 | 0 | 0 | 
| 70 | [6.3] | Yes. | Yes. | When execution of the flat parse is finished, meta.latest().text = meta.rulename.text (both variables are in the scope of the referencing rule). | 3 | 0 | 0 | 
| 72 | [6.3] | No. | Yes. | When execution of the flat parse is finished, meta.latest().score = meta.rulename.score (both variables are in the scope of the referencing rule) | 3 | 0 | 0 | 
| 73 | [6.3] | Yes. | Yes. | Within a parse list, results of previously executed rule references that are direct child of this list are available by rules.rulename. | 3 | 0 | 0 | 
| 74 | [6.3] | Yes. | Yes. | If a rule was referenced multiple times in the same scope, the result of the last instantiation is visible. | 3 | 0 | 0 | 
| 75 | [6.3] | Yes. | Yes. | rules.latest() always refers to the result of the previous reference in the current scope. | 3 | 0 | 0 | 
| 76 | [6.3] | Yes. | Yes. | meta.latest().text refers to the corresponding text utterance | 3 | 0 | 0 | 
| 77 | [6.3] | No. | Yes. | meta.latest().score refers to the corresponding score value | 3 | 0 | 0 | 
| 78 | [6.3] | Yes. | Yes. | Since the global scope is read only, assignments to global variables are not allowed in SI Tags in rules. They are only possible in the global SI Tags in the grammar header. | 2 | 1 | 0 | 
| 79 | [6.4] | Yes. | Yes. | Within a single SI Tag, the order of evaluation is determined by ES-CP for the evaluation of a valid ES-CP Program. | 3 | 0 | 0 | 
| 80 | [6.4] | Yes. | Yes. | All global SI Tags (in tags in the grammar header) are executed once, before any SI Tags within a grammar rule are executed | 3 | 0 | 0 | 
| 81 | [6.4] | Yes. | Yes. | The order of evaluating multiple SI Tags within a grammar rule is the order in which the SI Tags appear in the flat parse list for that rule application. | 3 | 0 | 0 | 
| 82 | [6.4] | Yes. | Yes. | The flat parse list also determines how many SI elements will be generated from an SI tag that occurs in a grammar rule. | 3 | 0 | 0 | 
| 83 | [6.4] | Yes. | Yes. | Every SI Tag element in a flat parse list is evaluated exactly once. | 3 | 0 | 0 | 
| 84 | [6.4] | Yes. | Yes. | The order of evaluating String Literals is determined by the order in which the equivalent SI Tag appears in the flat parse list. | 3 | 0 | 0 | 
| 85 | [6.4] | Yes. | Yes. | The computation of the semantic value of a rule reference in a flat parse list may occur at any time during the processing of the entire logical parse structure, subject to the following condition: the semantic value of a rule reference must be computed before any SI tag using that reference's value is processed. | 3 | 0 | 0 | 
| 94 | [3.1] | Yes. | Yes. | Every grammar rule has a single Rule Variable that holds a semantic value. | 3 | 0 | 0 | 
| 95 | [3.1] | Yes. | Yes. | SI tags also have access to the Rule Variables of any other rules referenced by the current grammar rule and already processed by that point in the utterance. | 3 | 0 | 0 | 
| 96 | [3.1] | Yes. | Yes. | The Rule Variables of other rules are referenced by the name of their grammar rule. | 3 | 0 | 0 | 
| 97 | [3.1] | Yes. | Yes. | Rule Variables can hold semantic values of any type defined in ES-CP. They are not explicitly typed. | 3 | 0 | 0 | 
| 98 | [3.1] | Yes. | Yes. | Rule Variables that have not been assigned a value are not defined | 3 | 0 | 0 | 
| 99 | [3.1] | Yes. | Yes. | For every Rule Variable there is an associated variable named "text", of type string, which holds the substring (the series of tokens) in the utterance that is governed by the corresponding grammar rule. | 3 | 0 | 0 | 
| 101 | [3.1] | No. | Yes. | There is an associated variable called "score", of type Number, which holds a value that is related to the confidence or probability of the corresponding grammar rule or some similar measure. | 2 | 0 | 1 | 
| 102 | [3.1] | No. | Yes. | Higher score values indicate higher confidence or probability over the corresponding grammar rule. | 2 | 0 | 1 | 
| 104 | [3.1] | No. | Yes. | The semantic result for an utterance is the value of the Rule Variable of the root rule when all semantic interpretation evaluations have been completed. For certain result formats (e.g. EMMA), this value is serialized into an XML document. | 3 | 0 | 0 | 
| 105 | [3.2] | Yes. | Yes. | The two different possible values of the tag-format declaration in the grammar define which of the two syntaxes is being used. The different syntaxes only change the processing of tags during Semantic Interpretation, in all other respects the grammar behaves identically. Script version. | 3 | 0 | 0 | 
| 106 | [3.2] | Yes. | Yes. | The "Script" tag syntax, enabled by setting the tag-format to "semantics/1.0", defines the contents of tags to be ECMAScript. A Semantic Interpretation Script holds a string that is treated as the source text of a valid ES-CP Program. | 3 | 0 | 0 | 
| 107 | [3.2] | Yes. | Yes. | The "String Literal" tag syntax, enabled by setting the tag-format to "semantics/1.0-literals", defines the contents of tags to be strings. | 3 | 0 | 0 | 
| 108 | [3.2] | Yes. | No. | Within one grammar, it is not possible to mix the two tag syntaxes. All tags in one grammar must have the same tag-format. See also assertion 138. | 3 | 0 | 0 | 
| 110 | [3.2] | Yes. | Yes. | It is possible for externally referenced grammars to have a different tag-format to the parent grammar they are referenced from. | 3 | 0 | 0 | 
| 111 | [3.2.2] | Yes. | Yes. | The environment in which SI tags are embedded may introduce escaped characters, character references or other markup that has to be resolved by the environment. The result after resolution is treated as ES-CP. | 3 | 0 | 0 | 
| 112 | [3.2.2] | Yes. | No. | It is illegal to make an assignment to a variable that has not been previously declared (either implicitly as is the case for Rule Variables or explicitly by using a var statement). Attempting to assign to an undeclared variable will result in a runtime error. | 3 | 0 | 0 | 
| 113 | [3.2.3] | Yes. | Yes. | A tag using the String Literal tag syntax has content that is a sequence of zero or more characters. If the character sequence is not empty, it has to follow either the DoubleStringCharacters or the SingleStringCharacters production of ES 7.8.4. | 3 | 0 | 0 | 
| 114 | [3.2.3] | Yes. | Yes. | During processing, a tag with a String Literal has the same effect as a script that assigns the content of the tag, as a string literal, to the Rule Variable of the rule the tag is in. | 3 | 0 | 0 | 
| 115 | [4.2] | Yes. | Yes. | There are no ordering constraints between SI Tags and other valid SRGS grammar header items. | 3 | 0 | 0 | 
| 116 | [6.3] | Yes. | Yes. | If any of the variables in the flat parse already exist, they are overwritten | 3 | 0 | 0 | 
| 117 | [7] | No. | Yes. | Object Type information and "DontEnum" properties are not serialized | 3 | 0 | 0 | 
| 118 | [7.1] | No. | Yes. | Simple ETLRV types generate XML fragment consisting of character data without any mark-up. The character data will be result of calling the ToString() on the ETLRV. | 3 | 0 | 0 | 
| 119 | [7.1] | No. | Yes. | Each property in the ETLRV becomes an XML element of that name. | 3 | 0 | 0 | 
| 120 | [7.1] | No. | Yes. | Simple scalar property values types (String, Number, Boolean, Null or Undefined) will generate XML character data content contained in the XML element as a result of calling ToString() on the property value. | 3 | 0 | 0 | 
| 121 | [7.1] | No. | Yes. | For complex property values (Object) each child property of this object becomes a child element, and the contents of these child elements are in turn processed. | 3 | 0 | 0 | 
| 122 | [7.1] | No. | Yes. | Indexed elements of an Array object (e.g. a[0], a[1]. etc.) become XML child elements with name 'item'. Each <item> element has an attribute named 'index', which is the index of the corresponding element in the array. In addition, the XML element containing the 'item's includes an attribute named 'length', whose value is given by the length property of the ECMAScript Array object. | 3 | 0 | 0 | 
| 123 | [7.1] | No. | No. | It is an error to transform an ECMAScript object into XML, that contains properties with names that are not allowed in XML. | 3 | 0 | 0 | 
| 124 | [7.2] | No. | Yes. | Properties specified in the _attributes object are rendered as XML attributes of the containing object. | 1 | 0 | 2 | 
| 125 | [7.2] | No. | Yes. | The value of _value is treated as character data content of the containing object or the value of an attribute if the containing object is a child of _attributes. | 1 | 0 | 2 | 
| 126 | [7.3] | No. | Yes. | When an object contains the _nsdecl property, the namespace declaration is attached to the resultant XML serialized element for this object. | 1 | 0 | 2 | 
| 127 | [7.3] | No. | Yes. | The _prefix property of _nsdecl indicates the namespace prefix and the _name property of _nsdecl indicates the corresponding namespace name (usually a URI reference). | 1 | 0 | 2 | 
| 128 | [7.3] | No. | Yes. | If the _prefix property is an empty string, the default namespace is declared. | 1 | 0 | 2 | 
| 129 | [7.3] | No. | Yes. | If both _prefix and _name are empty strings, the namespace declaration xmlns="" applies. | 1 | 0 | 2 | 
| 130 | [7.3] | No. | Yes. | When an Array object contains the _nsprefix property, the prefix also applies to the automatically generated <item> elements and length and index attributes. | 1 | 0 | 2 | 
| 131 | [7.1] | No. | Yes. | The values of properties of type String may contain special characters such as < and &, which could be erroneously treated as the start of markup by XML processors. An SI processor can use CDATA sections or character escaping to avoid this problem. | 3 | 0 | 0 | 
| 132 | [7.1] | No. | Yes. | Not indexed elements of an Array object, for instance the keys of an associative array (e.g. a["prop"]), are subject to the same transformation rules as the regular properties of an object. | 3 | 0 | 0 | 
| 133 | [7.1] | No. | Yes. | In a sparse array, only those elements which hold defined values will be serialized. | 3 | 0 | 0 | 
| 134 | [3.3.2] | Yes. | Yes. | Special Rule VOID can not be evaluated. | 3 | 0 | 0 | 
| 135 | [3.3.2] | Yes. | Yes. | Special Rule GARBAGE can not be evaluated. | 3 | 0 | 0 | 
| 136 | [5] | Yes. | Yes. | For a given parse, if there is no SI Tag attached to the expansion in the grammar rule and there are no rule references in the parse, the value for the text meta variable is automatically copied into the Rule Variable 'out' (which then becomes of type string). Applied to semantic scripts. | 3 | 0 | 0 | 
| 137 | [5] | Yes. | Yes. | For a given parse, if there is no SI Tag attached to the expansion in the grammar rule that is used to match the utterance, then if there is at least one rule reference, the value of the Rule Variable of the last rule reference in the parse is automatically copied into the Rule Variable. Applied to semantic scripts. | 3 | 0 | 0 | 
| 138 | [3.2] | Yes. | Yes. | The two different possible values of the tag-format declaration in the grammar define which of the two syntaxes is being used. The different syntaxes only change the processing of tags during Semantic Interpretation, in all other respects the grammar behaves identically. Literals version. See also assertion 108. | 3 | 0 | 0 | 
| 148 | [6.3] | Yes. | Yes. | Before the first tag in a flat parse is executed, the environment of a new scope is set up in the following way: rules.latest() returns undefined. | 3 | 0 | 0 | 
| 149 | [6.3] | Yes. | Yes. | Before the first tag in a flat parse is executed, the environment of a new scope is set up in the following way: meta.latest() returns undefined. | 3 | 0 | 0 | 
| 154 | [3.1] | Yes. | Yes. | Processors that don't compute or don't have access to score values must return undefined as the score value. | 3 | 0 | 0 | 
This appendix describes the framework employed for authoring SISR tests. Tests are written using Speech Recognition Grammar Specification (SRGS) grammars (XML Form) with embedded semantic scripts or semantic literals. The input utterance and the corresponding intended semantic result output are contained in metadata (described below). A fixed number of predefined tokens are used in the SRGS grammar to facilitate automatic translation to a different speech recognition language or to DTMF type grammars.
A child element of <metadata> called <test-data> is employed to hold the prescribed input utterance and the corresponding desired semantic result output.
The <test-data> element has a required attribute called input which contains the input utterance used to match against the grammar. The utterance is constrained to use only the following tokens (in any order and with any multiplicity):
The semantic result obtained from matching the utterance to the grammar and subsequently processing the SISR <tag>s is represented either as an ECMAScript Object Initialiser (see Section 11.1.5 of ECMA-262) contained in the output attribute of <test-data> or as the XML Serialized equivalent (see Section 7.0 of SISR) contained in the child content of <test-data>.
The <metadata> element only contains one <test-data> element (i.e. there is only one input-output pair for each test). The <test-data> and children (if any) employ the namespace http://www.w3.org/2006/01/sisr-conformance. The corresponding XML schema is given below.
| 
<?xml version="1.0" encoding="UTF-8"?>
<xsd:schema targetNamespace="http://www.w3.org/2006/01/sisr-conformance"
            xmlns="http://www.w3.org/2006/01/sisr-conformance"
            xmlns:xsd="http://www.w3.org/2001/XMLSchema"
            elementFormDefault="qualified">
    <xsd:simpleType name="GrammarToken.datatype">
        <xsd:restriction base="xsd:token">
            <xsd:enumeration value="vienna"/>
            <xsd:enumeration value="redmond"/>
            <xsd:enumeration value="boston"/>
            <xsd:enumeration value="budapest"/>
            <xsd:enumeration value="paris"/>
        </xsd:restriction>
    </xsd:simpleType>
    <xsd:simpleType name="GrammarTokens.datatype">
        <xsd:list itemType="GrammarToken.datatype"/>
    </xsd:simpleType>
    <xsd:element name="test-data">
        <xsd:complexType mixed="true">
            <xsd:sequence minOccurs="0" maxOccurs="unbounded">
                <xsd:any processContents="skip"/>
            </xsd:sequence>
            <xsd:attribute name="input" type="GrammarTokens.datatype" use="required"/>
            <xsd:attribute name="output" type="xsd:string"/>
        </xsd:complexType>
    </xsd:element>
</xsd:schema>
 | 
This section illustrates example tests. For clarity, the schema locations have been omitted
The following example demonstrates the usual case of the output given as an ECMAScript Object Initialiser.
| 
<?xml version="1.0" encoding="UTF-8"?>
<grammar version="1.0"
         xml:lang="en-IE"
         root="top"
         tag-format="semantics/1.0"
         xmlns="http://www.w3.org/2001/06/grammar">
    <metadata>
        <test-data input="boston"
                   output="{ answer: 7 }"
                   xmlns="http://www.w3.org/2006/01/sisr-conformance"/>
    </metadata>
    <rule id="top" scope="public">
        boston <tag>out.answer=1+2*3</tag>
    </rule>
</grammar>
 | 
The following example demonstrates the output given in the XML Serialization representation.
| 
<?xml version="1.0" encoding="UTF-8"?>
<grammar version="1.0"
         xml:lang="en-IE"
         root="top"
         tag-format="semantics/1.0"
         xmlns="http://www.w3.org/2001/06/grammar">
    <metadata>
        <test-data input="boston"
                   xmlns="http://www.w3.org/2006/01/sisr-conformance">
            <answer>7</answer>
        </test-data>
    </metadata>
    <rule id="top" scope="public">
        boston <tag>out.answer=1+2*3</tag>
    </rule>
</grammar>
 | 
The SISR 1.0 Implementation Report includes 105 assertions and corresponding tests. The Voice Browser Working Group would like to further acknowledge the contributions of several individuals: