Speech in the Input Barcode Control
Control Purpose
The main use for an Input Barcode control is to allow the operator to capture/read barcode data with the device's barcode reader.
Depending on what your MCL-Designer V4 subscription includes, this control can have another feature - speech.
This means that the operator can read a barcode (with the use of the device's barcode reader) or say the characters that form the barcode. It also enables the use of output information (instructions to be heard by the operator) and the use of spoken words to establish data input order, meaning, using a specific word (= focus word) to set the focus on a specific control within a screen.
This topic only describes the speech related options included in an Input Barcode control. For more information on this control, see Adding an Input Barcode Control to a Screen.
Step-by-step
1. Add the Input Barcode control to the screen by dragging it from the top section of the "Control" tab OR the Style Preview section onto the screen.
2. In the control's properties window, fill in the "General", "Advanced", "Layout" and "Routing" tabs as required. See Adding an Input Barcode Control to a Screen.
Remember that all speech input data (stored in a variable that is defined in the "General" tab) must be managed with the use of processes in the "Actions" tab.
3. Open the "Speech" tab. By default, all the tab's options are inactive.
This tab is used to activate the control's speech attribute and to define its use (control focus through speech, prompts, accepted word sequence, etc.).
4. Check the "Speech Input" box to enable the control's speech feature.
5. Fill in the available options:
When entering data in the "Speech Grammar" table, you can use the editing bar to the right to add (), delete () and/or move () table rows.
Focus Word |
Enter a focus word OR click to select a variable with the intended value. See Variable Usage.
The focus word is used by the operator to set the focus on the current control before input. Ex: The operator uses the focus word to turn the corresponding control into the active element (ready to receive input) in the screen without having to touch the control or use the direction keys of a keyboard. |
Focus Prompt |
If required, enter the focus prompt OR click to access the Speech Prompt Builder assistant to create it. See The Speech Prompt Builder. The focus prompt's purpose is to provide information or instructions to the operator so that he can use speech input. The focus prompt can be a word, a sound, etc. |
Key Words |
This option is only applicable for App Word List that associate spoken words to specific keys/key combinations. If required, select an App Word List from the drop-down OR click to open the "Word List" window and select one from the table.
Remember, this option only works with App Word List that associate spoken words to specific keys/key combinations. The drop-down only displays compatible App Word List but, if you use the "Word List" table, it will show all the App Word Lists in your project and it will be up to you to select a compatible one.
This type of App Word List implies the use of "Hotkey" actions in the current control's "Actions" tab (spoken word associated to a key>> key associated to an action). See Example I (Escape Sequence).
|
Speech Grammar (Word Sequence for Data Input) table |
|
Word List column |
It is possible to combine two or more word lists to create a word list sequence but this only works for App Word Lists that associate spoken words to numeric/alphanumeric values. App Word Lists that include key codes do NOT apply. Construct a word sequence with one or more word lists. Select the App Word List from the drop-down OR click and select it from the "Word List" table (the "Word List" table allows you to view the existing App Word Lists (see To View the App Word Lists), to edit them (see To Edit an App Word List) or to add new ones (see To Add an App Word List). As an alternative, you can also enter a variable that contains the name of the intended App Word List.
Remember, this option only works with app word lists that associate spoken words to values. The drop-down and the "Word List" table display all the App Word Lists in your project and it will be up to you to select the compatible App Word List(s).
If you use more than one word list, remember that this is a word sequence, meaning, you have to order your word list selection according to the intended speech input sequence. Ex: For a word sequence such as "Code 5 2 Read", you have to do the following selection: 1st - the word list that includes the word "Code".(List A) 2nd - the word list that includes the numeric units "5" and "2" (List B) 3rd - the word list that includes the word "Read". (List C) If you were to select List B first, then, List C and, then, List A, you would be creating the following speech input sequence - "5 2 Read Code".
|
Min column |
Specify the minimum number of units from the selected word list to be used in the word sequence. |
Max column |
Specify the maximum number of units from the selected word list to be used in the word sequence. |
End of Input |
Select the end of input mode from the drop-down OR click and select it from the "Word List" table: Auto - use of automatic system criteria to determine the end of speech input. Global Validation Word - requires a specific word to be spoken by the operator to mark the end of speech input. This word is defined in the Global Words List.
When selecting this option, make sure that the Global Words List contains a spoken word with <ENTER> as the return key and that the list is enabled. See Global Words.
None - speech input ends when the operator uses the maximum length of the input word sequence. Validation Word List - This option is only available in the drop-down if you have already created an App Word List with a specific characteristic - this App Word List must include spoken words associated to the key code "<Enter>" or "<Enter1>" or <Enter2>", etc. (up to "<Enter9>").
Example of an App Word List that can be used as a validation list:
In this case, the operator will be able to say "Ended"; "Completed", "Done" or "Concluded" to indicate the end of his speech input.
See Example II (Speech Input Validation and Routing).
|
Hint Value(s) |
If required, define "Hint Value(s)" for the current control. Enter the value(s) OR click to select a variable with the intended value. See Variable Usage.
Hint values refer to the expected speech input value(s) for this context (the expected words spoken by the operator when the focus is on the current Input Barcode). These hint values are only used in a post-speech processing phase. After the speech input has been recognized, in case there is more than one possible match with a similar confidence level, the acceptance criteria will force the selection of the hint value even, if its score is slightly lower than the other recognized set of words. Ex: If you set the hint values for this control at 1 9 and the operator says "1 9" and "2 6" and both inputs have a high confidence level (leading to two speech recognition results), the hint values are taken into consideration and the "2 6" input/result is discarded. |
Sync Mode |
The sync mode determines when the operator can start his speech input taking into account the current speech output. Select the most appropriate sync mode from the corresponding drop-down: Sequential (End of last Prompt) - The operator has to listen to the complete speech output before he can start his speech input (recommended sync mode). Anticipated (start of last Prompt) - The operator can start speaking as soon as the speech output (what the operator hears) is initiated. Continuous (End of last Input) - The operator can speak inputs continuously, one after the other. This sync mode implies the creation/use of specific grammar constructions to allow the application to recognize/validate each speech input. See Speech Dialog/Sync Mode. |
You MUST either select a word list in the "Key Words" option or create a speech grammar sequence in the "Speech Grammar" table (with one or more word lists) to ensure that this control has speech commands associated to it.
In terms of speech grammar sequence, each numeric and/or alphabetic word counts as 1 unit. Although words are composed of many letters, each word is considered 1 unit.
6. Continue to the "Actions" tab and add the necessary processes to handle the speech input received via the current Input Barcode control. See Adding an Input Barcode Control to a Screen - Actions tab (step 29).
Any future editing in the "Speech" tab, requires clicking in the properties window to apply the changes.
Remember that the variable that receives the speech input is defined in the control's "General" tab.
App Word Lists with Keys/Key Combinations/Key Codes
App Word Lists that associate spoken words to keys/key combinations/key codes can have two main uses:
I. To use a specific spoken word and/or a specific key/key combination to trigger an action.
To do this, you must associate a specific spoken word to a specific key/key combination (in an App Word List) and a specific action to that key/key combination (through a "Hotkey" action).
See Example I (Escape Sequence) below.
II. To use one or more spoken words to indicate the end of an operator's speech input (initial purpose) and trigger a specific action for each word (additional purpose or redirection).
This implies the creation of a specific App Word List that associates spoken words to the following key codes - "<ENTER>", "<ENTER1>"," <ENTER2>", etc., up to "<ENTER9>".
The corresponding default values for these key codes ("EN" for "<ENTER>", "E1" for "<ENTER1>", "E2" for "<ENTER2>" and so on) are stored in the default Local variable "L_Keycode". This variable is associated to another default Local variable - "L_Entry_Type" - which stores the type of input ("VO" for speech input, "KB" for keyboard input and the symbology of a barcode input). The "L_Keycode" variable will only receive data if the entry type is speech input (meaning, with a "VO" value in the "L_Entry_Type" variable).
See Example II (Speech Input Validation and Routing).
This is an example of how to use an App Word List that includes keys to navigate/exit the application (in other words, to create an "escape sequence").
1. Create an App Word List ("Exit_Words") with the following content:
2. In the Input Barcode's "Speech" tab ("Key Words" option), select "<Exit_Words>".
3. In the "Actions" tab of the Input Barcode, add 2 "Hotkey" actions (one per spoken word/key) to the control's execution flow.
Expected Behavior When the operator reaches this control within the application, he will be able to: •Say the word "Repeat" to stay in the current screen; •Say the word "Exit" to close the application; •Press the <F1> key, in the device, to stay in the current screen. •Press the <CLEAR> key, in the device, to exit the application.
|
This example describes the use of two spoken words to stipulate the end of the speech input and to redirect the application flow according to the used spoken word.
1. Create an App Word List ("Validation_Words") with the following content:
2. In the "Speech" tab of the Input Barcode (in the "End of Input" option), select the "<Validation_Words>" App Word List.
3. In the Input Barcode's "Actions" tab, add the following processes:
Expected Behavior If the operator ends his speech input with the word "Short", the application will consider the input as complete and redirect him to "R:Routine_SHORT". If the operator ends his speech input with the word "Ready", the application will, also, consider the input as complete but will redirect him to "R:Routine_READY".
|
Consider a word sequence with 1 word list - a numeric type list ("Numeric1").
The "Numeric1" word list includes digits from "0" to "9".
The total of minimum units to use per word sequence is 3. The total of maximum units to use per word sequence is 3. This means that the word sequence consists of 3 digits (three units).
The "End of Input" is set to "None", meaning, the operator does NOT have to say a validation word at the end of his speech input (NOT needed because of the fixed digit input).
Remember that each numeric and/or alphabetic word counts as 1 unit.
Possible Speech Inputs
"5" "1" "0" (1 + 1 + 1 = 3 units) "5" "7" "2" (1 + 1 + 1 = 3 units) "8" "3" "9" (1 + 1 + 1 = 3 units)
It is possible to merge sequential word lists. This means that the operator can speak the words included in those 2 merged lists in any position in the word sequence. This is done in the "Min" and "Max" columns of the "Speech Grammar" table, which is where you determine the minimum and maximum length of a word list: a. Select the in the "Max" column of the first word list to be merged. b. Select the in the "Min" column of the word list that follows.
Example of Merged Word Lists
There are two sequential word lists:
The "Numeric1" word list includes digits from "0" to "9". The "NATO_Alphabet" word list contains the NATO designations and corresponding alphabet letters (from "A" to "Z").
Selecting the arrow symbols as displayed in the image above ensures the merging of the 2 word lists. The "End of Input" is set to "None", meaning, the operator does NOT have to say a validation word at the end of speech input (NOT needed because of the fixed digit input). This means that the operator must say 3 units, EITHER numbers or letters or both.
Remember that each numeric and/or alphabetic word counts as 1 unit.
Possible Speech Inputs (word sequences)
"foxtrot" "1" "0" (1 + 1 + 1 = 3 units) "5" "golf" "2" (1 + 1 + 1 = 3 units) "8" "charlie" "delta" (1 + 1 + 1 = 3 units) "alpha" "bravo" "echo" (1 + 1 + 1 = 3 units) "6" "4" "9" (1 + 1 + 1 = 3 units)
|