IBM语音技术API说明,比较锻炼英文能力

 

 

 

 

 

IBM语音技术API说明,比较锻炼英文能力_第1张图片SMAPI (Speech Manager Application
Programming Interface) Reference
IBM ViaVoice. SDK for Windowsa


Printed in the USA

Note

Before using this information and the product it supports, be sure to read the general information under Appendix
D "Notices".

First Edition (August 1998)

The following paragraph does not apply to the United Kingdom or any country where such provisions are
inconsistent with local law: INTERNATIONAL BUSINESS MACHINES CORPORATION PROVIDES THIS
PUBLICATION "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED,
INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY OR
FITNESS FOR A PARTICULAR PURPOSE. Some states do not allow disclaimer of express or implied
warranties in certain transactions, therefore, this statement may not apply to you.

This publication could include technical inaccuracies or typographical errors. Changes are periodically made to
the information herein; these changes will be incorporated in new editions of the publication. IBM may make
improvements and/or changes in the product(s) and/or the program(s) described in this publication at any time.

It is possible that this publication may contain reference to, or information about, IBM products (machines and
programs), programming, or services that are not announced in your country. Such references or information
must not be construed to mean that IBM intends to announce such IBM products, programming, or services in
your country.

Requests for technical information about IBM products should be made to your IBM reseller or IBM marketing
representative.


Contents


About this Book 19
Who Should Read This Book ..... . . . . ..... . . . ..... . . . . .... 19
RelatedPublications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19

Part 1: IBM Speech API (SMAPI)

Chapter 1 SMAPI Overview 21

Formatof theFunctionCallDescriptions . . . . . . . . . . . . . . . . . . . . . 21

NamingConventions. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23

SMAPI Function Calls by Group ... . . . . ..... . . . ..... . . . . .... 24
Attribute HandlingFunctions.... . . . . ..... . . . ..... . . . . .... 24
Callback and Dispatching Functions . . ..... . . . ..... . . . . .... 24
Data Access Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
ConnectionFunctions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
SessionFunctions. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
Database Functions.. . . . . ..... . . . . ..... . . . ..... . . . . .... 28
Speech Recognition Engine State Functions . . . . . . . . . . . . . . . . 29
Vocabulary Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
Audio Functions. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30

Parallel SessionAPI Calls . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31

Chapter 2 Starter Set APIs 33

StarterSet SMAPIs for Command and Control . . . ..... . . . . .... 33
Establishing a Recognition Session. . . ..... . . . ..... . . . . .... 34
Setting Up and Enabling Vocabularies ..... . . . ..... . . . . .... 34
Directing the Engine toProcess Speech. . . ..... . . . ...... . . . 35

IBM SMAPI Reference


Contents

ProcessingRecognized Commands. . . . . ..... . . . ..... . . . . . 35
Disconnecting fromthe Engine ..... . . . . ..... . . . ..... . . . . . 36

Starter Set SMAPIs for Dictation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
Establishing a Recognition Session.. . . . . ..... . . . ..... . . . . . 37
Setting Up and Enabling Vocabularies. . . . ..... . . . ..... . . . . . 37
Directing the Engine to ProcessSpeech . . ..... . . . ..... . . . . . 38
ProcessingRecognized Text . . ..... . . . . ..... . . . ..... . . . . . 38
Correcting Errors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
Disconnecting fromthe Engine ..... . . . . ..... . . . ..... . . . . . 40

Chapter 3 Function Calls to the Speech Recognition Engine 41

SmAddCallback . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
SmAddPronunciation . ..... . . . . ..... . . . . ..... . . . ..... . . . . . 42
SmAddToVocab. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
SmApiVersionCheck. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
SmAutoComplete. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
SmCancelPlayback . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
SmClose. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
SmConnect. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
SmCorrectText. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
SmDefineGrammar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
SmDefineVocab. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
SmDefineVocabEx . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
SmDetachSessions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
SmDisableVocab . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70
SmDiscardData . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
SmDiscardSpeechData .... . . . . ..... . . . . ..... . . . ..... . . . . . 74
SmDisconnect .. . . . . ..... . . . . ..... . . . . ..... . . . ..... . . . . . 76
SmDispatch . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
SmEnableVocab. . . . . ..... . . . . ..... . . . . ..... . . . ..... . . . . . 79
SmEventNotify. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
SmHaltRecognizer . . . ..... . . . . ..... . . . . ..... . . . ..... . . . . . 83
SmMicOff . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
SmMicOn . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87

IBM ViaVoice SDK for Windows


Contents

SmNewContext . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89
SmOpen. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91
SmPlayMessage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93
SmPlayUtterance. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
SmPlayWords . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
SmQuery. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 103
SmQueryAddedWords. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 109
SmQueryAddedWordsEx. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
SmQueryAlternates. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114
SmQueryBinary. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 116
SmQueryDefault . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117
SmQueryEnabledVocabs. . . . ..... . . . . ..... . . . ..... . . . . ... 119
SmQueryEnrollIds . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121
SmQueryLanguages... . . . . ..... . . . . ..... . . . ..... . . . . ... 123
SmQueryPhraseAlternatives. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125
SmQueryPronunciation. . . . . ..... . . . . ..... . . . ..... . . . . ... 127
SmQueryPronunciations . . . . ..... . . . . ..... . . . ..... . . . . ... 129
SmQueryPronunciationsEx . . ..... . . . . ..... . . . ..... . . . . ... 131
SmQueryScripts. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 133
SmQuerySessions. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 135
SmQuerySpeechData. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 136
SmQueryTasks. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137
SmQueryTopics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 139
SmQueryUserDefault. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141
SmQueryUserInfo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 143
SmQueryUsers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 145
SmQueryVocabs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 147
SmQueryWord. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 149
SmReceiveMsg . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 151
SmRecognizeNextWord. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 152
SmReleaseFocus. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 154
SmRemoveCallback.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 155
SmRemoveFromVocab . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156

IBM SMAPI Reference


Contents

SmRemovePronunciation... . . . . ..... . . . . ..... . . . ..... . . . . 159
SmRequestFocus. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161
SmRequestMicOff . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .163
SmRequestMicOn . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .164
SmRestoreSpeechData.... . . . . ..... . . . . ..... . . . ..... . . . . 165
SmSaveSpeechData . ..... . . . . ..... . . . . ..... . . . ..... . . . .167
SmSet. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 169
SmSetArg. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 178
SmSetBinary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .179
SmSetDefault.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 181
SmSetDirectory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .183
SmSetUserDefault . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 184
SmSetUserInfo.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 186
SmUndefineVocab . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 188
SmWordCorrection. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 190

Chapter 4 Data Access Functions 195

SmGetAlphabets . . . . ..... . . . . ..... . . . . ..... . . . ..... . . . .195
SmGetAlternates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 197
SmGetAnnotations. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 198
SmGetApplication. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 200
SmGetApplications. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 201
SmGetAudioLevel. . . . ..... . . . . ..... . . . . ..... . . . ..... . . . . 202
SmGetBinaryItemValue . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 203
SmGetCodePage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 204
SmGetDescriptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .205
SmGetEngineState. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 207
SmGetEnrollId . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 209
SmGetEnrollIds . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .210
SmGetEventId . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .212
SmGetEventOptions. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 213
SmGetFirmWords. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 214
SmGetFlags. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 215

IBM ViaVoice SDK for Windows


Contents

SmGetFocusChangeReason. ..... . . . . ..... . . . ..... . . . . ... 217
SmGetFocusState . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 218
SmGetGrammarPath.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 219
SmGetIncrements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 220
SmGetItemValue . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 221
SmGetLanguages ..... . . . . ..... . . . . ..... . . . ..... . . . . ... 222
SmGetMicState . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 223
SmGetMsgName. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 224
SmGetMsgType. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 225
SmGetNameValue. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 226
SmGetNumberWordMsgs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 227
SmGetOptions. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 228
SmGetPercentages.... . . . . ..... . . . . ..... . . . ..... . . . . ... 229
SmGetPhraseScore. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 230
SmGetPhraseState. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 231
SmGetPreferred. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 233
SmGetPronunciations.. . . . . ..... . . . . ..... . . . ..... . . . . ... 234
SmGetRc.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235
SmGetRcDescription. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 236
SmGetRcName . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 237
SmGetSampleRates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 238
SmGetScriptFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 239
SmGetScripts. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 240
SmGetService . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 241
SmGetSessionId . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 242
SmGetSeverity. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 243
SmGetSizes. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 244
SmGetSpeechDataArchive . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 245
SmGetSpeechDataOptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 246
SmGetSpeechDataSize. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 247
SmGetSpeechDataVersion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 248
SmGetSpelling. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 249
SmGetSpellings. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 251

IBM SMAPI Reference


Contents

SmGetStates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 253
SmGetStatus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 254
SmGetTags.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 256
SmGetTask.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257
SmGetTaskFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .258
SmGetTasks. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 259
SmGetTimes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .260
SmGetTopics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .262
SmGetTrained. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 263
SmGetUserId. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 264
SmGetUserIds . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 266
SmGetUsers. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 268
SmGetUtteranceNumber . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 269
SmGetVocabList. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 270
SmGetVocabName. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 271
SmGetVocabPath. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 273
SmGetVocWords . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .274
SmGetWords . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 276
SmGetWordTimes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .277
SmReturnRc. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 279
SmReturnRcDescription. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 280
SmReturnRCName . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .281

Chapter 5 Reply Message Structures and Callbacks 283

Reply Message Structures Received from the Speech Engine . . . . 283
Callbacks . ..... . . . . ..... . . . . ..... . . . . ..... . . . ..... . . . . 294
Reply Structure Functions for Unsolicited Callbacks . . . . . . . . . . . . 297

Chapter 6 Data Types 301

caddr_t . . ..... . . . . ..... . . . . ..... . . . . ..... . . . ..... . . . . 301
SmArg . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 301
SmArgVal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 302

IBM ViaVoice SDK for Windows


Contents

SmHandler . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 302
SM_ANNOTATION.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 303
Sm_Msg. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 304
SM_VOCWORD . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 304
SM_WORD . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 305

Chapter 7 SMAPI Attributes 307

System Dependent Definition for Argument Lists . . . . . . . . . . . . . . 307
Argument Attribute List . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 307
ApplicationInformation Attributes . . . . . . . . . . . . . . . . . . . . . . . . 307
SmNapplicationName. . . ..... . . . . ..... . . . ..... . . . . ... 307
Requested Services . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 308
SmNresetServices. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 308
SmNdatabase.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 308
SmNrecognize. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 308
OptionsFlags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 308
SmNdiscardSessionData.. . . . . . . . . . . . . . . . . . . . . . . . . . . . 308
SmNdiscardSessionAdaptation . . . . ..... . . . ..... . . . . ... 308
SmNSaveSessionData. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 308
SmNSaveSessionAdaptation.. . . . . ..... . . . ..... . . . . ... 308
WindowHandle ..... . . . . ..... . . . . ..... . . . ..... . . . . ... 309
SmNwindowHandle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 309
User DefinitionArguments. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 309
SmNaudioHost.... . . . . ..... . . . . ..... . . . ..... . . . . ... 309
SmNconnectID.... . . . . ..... . . . . ..... . . . ..... . . . . ... 309
SmNenrollID. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 309
SmNnavigator. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 309
SmNtask. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 309
SmNuserID. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 310

Part 2: IBM Dictation Macro API (DMAPI)

Chapter 8 DMAPI Overview

311

Formatof theFunctionCallDescriptions . . . . . . . . . . . . . . . . . . . . 311

IBM SMAPI Reference


Contents

DMAPI Function Calls . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .312

Chapter 9 DMAPI Function Calls

315

DmClose . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .315
DmFlushEx.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 316
DmFreeMacro. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 317
DmFreeMacroEx . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .318
DmFreeNames. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 319
DmGetGroupsOnPage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 320
DmGetKey . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .321
DmGetKeyGroup . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .322
DmGetKeyGroupOption.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 323
DmGetKeyGroupOptionSelection. . . . . . . . . . . . . . . . . . . . . . . . . . . 324
DmGetLastError. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 325
DmGetMacro . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .327
DmGetMacroEx . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 329
DmGetNumberOfGroups. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 331
DmGetNumberOfOptions. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 332
DmGetNumberOfSelections. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 333
DmGetTemplate. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 334
DmIsNumberFlagged. ..... . . . . ..... . . . . ..... . . . ..... . . . . 336
DmKeywordFromType . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .337
DmOpen. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 339
DmQueryDelimiters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 341
DmQueryMacroNames.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 342
DmQueryTemplateNames . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 343
DmQuerySetAndStoreKey. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 344
DmSetKey . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .345
DmStartMacroEditor. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 346
DmStoreKey. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 347
DmTypeFromKeyword . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .348
DmUpdate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .350

IBM ViaVoice SDK for Windows


Contents

Chapter 10 Data Types

351

DMERROR . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 351
DM_MACRO_STRUCT. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 352
DM_TEMPLATE_FIELD. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 354

Part 3: IBM SMAPI Grammar Compiler API

Chapter 11 SMAPI Grammar Compiler API Overview 355

Formatof theFunctionCallDescriptions . . . . . . . . . . . . . . . . . . . . 355
Grammar Compiler API Function Calls . . . . . . . . . . . . . . . . . . . . . . 356

Chapter 12 SMAPI Grammar Compiler API Function Calls 357

VtAddArg . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 357
VtCompileGrammar. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 358
VtGetMessage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 359
VtGetTranslation. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 360
VtLoadFSG . . . . . ..... . . . . ..... . . . . ..... . . . ..... . . . . ... 362
VtSethArg.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 363
VtUnloadFSG. . . . ..... . . . . ..... . . . . ..... . . . ..... . . . . ... 364

Chapter 13 Data Types 365

VtArg. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 365

Part 4: Other ViaVoice APIs

Chapter 14 VtGeneratePronunciations

369

VtGeneratePronunciations . . ..... . . . . ..... . . . ..... . . . . ... 369

IBM SMAPI Reference


Part 5: Appendixes


Appendix A

Contents

SMAPI Return Codes, Messages, Message Types 371

SMAPI Return Codes and Messages .. . . . . ..... . . . ..... . . . . 371
Engine Return Codes and Messages... . . . . ..... . . . ..... . . . . 375
Status Codesand Messages. . . . ..... . . . . ..... . . . ..... . . . . 376
SMAPI MessageTypes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .377
SMAPI MessageExplanations. . . ..... . . . . ..... . . . ..... . . . . 381
SM_RC_ACOUSTICS_TOO_LONG. . . . . ..... . . . ..... . . . . 381
SM_RC_ADDED . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .381
SM_RC_ADDWORD_LIMIT_EXCEEDED. . . . . . . . . . . . . . . . . . 382
SM_RC_ALREADY_CONNECTED . . . . . . . . . . . . . . . . . . . . . . . 382
SM_RC_ALREADY_OPENED. . . . . . . . . . . . . . . . . . . . . . . . . . . 382
SM_RC_ASSOC_EVENT_SEM_FAILED . . . . . . . . . . . . . . . . . .383
SM_RC_AUDIO_FORCED_MIC_OFF . . . . . . . . . . . . . . . . . . . .383
SM_RC_AUDIO_IN_USE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .383
SM_RC_AUDIO_OVERRUN . . . . . . . . . . . . . . . . . . . . . . . . . . . . 384
SM_RC_BAD_ACOUSTICS . . . . . . . . . . . . . . . . . . . . . . . . . . . .384
SM_RC_BAD_ADDWORD . . . . . . . . . . . . . . . . . . . . . . . . . . . . .384
SM_RC_BAD_AP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .385
SM_RC_BAD_AUDIO . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 385
SM_RC_BAD_DECO. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 385
SM_RC_BAD_DESCRIPTION. . . . . . . . . . . . . . . . . . . . . . . . . . . 386
SM_RC_BAD_ENROLLID. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 386
SM_RC_BAD_ITEM. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 386
SM_RC_BAD_LANGUAGE. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 387
SM_RC_BAD_MESSAGE. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 387
SM_RC_BAD_MODE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .387
SM_RC_BAD_NAME. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 388
SM_RC_BAD_SCRIPT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 388
SM_RC_BAD_TAG . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .388
SM_RC_BAD_TASKID. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 389
SM_RC_BAD_USERID. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 389
SM_RC_BAD_UTTNO.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 389
SM_RC_BAD_VALUE. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 390
SM_RC_BAD_VOCAB.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 390

IBM ViaVoice SDK for Windows


Contents

SM_RC_BUSY_LAST_UTTERANCE. . . . . . . . . . . . . . . . . . . . . 390
SM_RC_BUSY_WORD_CORRECTION. . . . . . . . . . . . . . . . . . . 391
SM_RC_CALLBACK_LIST_CHANGED. . . . . . . . . . . . . . . . . . . 391
SM_RC_CONNECTION_CHANGED . . . . . . . . . . . . . . . . . . . . . 391
SM_RC_CREATE_EVENT_SEM_FAILED . . . . . . . . . . . . . . . . . 392
SM_RC_CREATE_MBOX_FAILED. . . . . . . . . . . . . . . . . . . . . . . 392
SM_RC_DEEALLOCATING_SH_MEM.. . . . . . . . . . . . . . . . . . . 392
SM_RC_EALLBUSY. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 393
SM_RC_EALLOC. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 393
SM_RC_EAPIVERSION . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 393
SM_RC_EBADAPPNAME. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 394
SM_RC_EBADHANDLE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 394
SM_RC_EINVAL. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 394
SM_RC_ENOCONN . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 395
SM_RC_ENOHANDLES. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 395
SM_RC_ENOMEM. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 395
SM_RC_ENOMSG . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 396
SM_RC_ENOSERVER . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 396
SM_RC_ENROLLID_BUSY . . . . . . . . . . . . . . . . . . . . . . . . . . . . 396
SM_RC_ENROLLID_EXISTS. . . . . . . . . . . . . . . . . . . . . . . . . . . 397
SM_RC_ENROLLID_RUNNING. . . . . . . . . . . . . . . . . . . . . . . . . 397
SM_RC_ENROLLMENT_NOT_COMPLETE . . . . . . . . . . . . . . . 397
SM_RC_FREE_MEM_ERROR.. . . . . . . . . . . . . . . . . . . . . . . . . 398
SM_RC_EXISTS_IN_NOTIFY. . . . . . . . . . . . . . . . . . . . . . . . . . . 398
SM_RC_FOCUS_DENIED . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 398
SM_RC_FOCUS_GRANTED. . . . . . . . . . . . . . . . . . . . . . . . . . . 399
SM_RC_INCOMPATIBLE_ENROLLMENT . . . . . . . . . . . . . . . . . 399
SM_RC_ILLEGAL_SPOKENLIKE. . . . . . . . . . . . . . . . . . . . . . . . 399
SM_RC_ILLEGAL_SPELLING. . . . . . . . . . . . . . . . . . . . . . . . . . 400
SM_RC_INVALID_PARM_MAX_LEN . . . . . . . . . . . . . . . . . . . . . 400
SM_RC_INVOCAB. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 400
SM_RC_MIC_ALREADY_OFF. . . . . . . . . . . . . . . . . . . . . . . . . . 401
SM_RC_MIC_ALREADY_ON . . . . . . . . . . . . . . . . . . . . . . . . . . . 401
SM_RC_MIC_OFF_PENDING. . . . . . . . . . . . . . . . . . . . . . . . . . 401
SM_RC_MIC_ON_PENDING. . . . . . . . . . . . . . . . . . . . . . . . . . . 402
SM_RC_MISMATCHED_ACOUSTICS. . . . . . . . . . . . . . . . . . . . 402
SM_RC_MISMATCHED_ALPHABET . . . . . . . . . . . . . . . . . . . . . 402
SM_RC_MISMATCHED_LANGUAGE. . . . . . . . . . . . . . . . . . . . . 403

IBM SMAPI Reference


Contents

SM_RC_MISMATCHED_SCRIPT. . . . . . . . . . . . . . . . . . . . . . . . 403
SM_RC_MISSING_EXTERN. . . . . . . . . . . . . . . . . . . . . . . . . . . . 403
SM_RC_MULTIPLE_SPELLINGS.. . . . . . . . . . . . . . . . . . . . . . . 404
SM_RC_NAV_ALREADY_DEFINED. . . . . . . . . . . . . . . . . . . . . . 404
SM_RC_NO_FOCUS_APP. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 404
SM_RC_NO_MORE_CONNECTIONS . . . . . . . . . . . . . . . . . . . . 405
SM_RC_NO_SPACE. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 405
SM_RC_NO_SPACE_INIT_ENROLL . . . . . . . . . . . . . . . . . . . . .405
SM_RC_NO_SPACE_INIT_RECO . . . . . . . . . . . . . . . . . . . . . . .406
SM_RC_NO_SPACE_MIC_ON . . . . . . . . . . . . . . . . . . . . . . . . . . 406
SM_RC_NO_SPACE_TERM_ENROLL. . . . . . . . . . . . . . . . . . . . 406
SM_RC_NOT_ADDED . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .407
SM_RC_NOT_DELETED . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .407
SM_RC_NOT_IN_NOTIFY . . . . . . . . . . . . . . . . . . . . . . . . . . . . .407
SM_RC_NOT_INVOCAB. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 408
SM_RC_NOT_VALID_REQUEST. . . . . . . . . . . . . . . . . . . . . . . . 408
SM_RC_NOT_WHILE_MIC_ON. . . . . . . . . . . . . . . . . . . . . . . . . 408
SM_RC_NOT_WHILE_PLAYING. . . . . . . . . . . . . . . . . . . . . . . . . 409
SM_RC_NOT_YET . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .409
SM_RC_OK . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 409
SM_RC_OPEN_SYNCH_QUEUE_FAILED. . . . . . . . . . . . . . . . . 410
SM_RC_PLAY_OPEN_ERROR. . . . . . . . . . . . . . . . . . . . . . . . . . 410
SM_RC_QUEUE_CLOSE_ERROR. . . . . . . . . . . . . . . . . . . . . . . 410
SM_RC_RECORD_OPEN_ERROR. . . . . . . . . . . . . . . . . . . . . . 411
SM_RC_REPLY_NULL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .411
SM_RC_SERVER_ERROR. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 411
SM_RC_SERVER_FILE_CLOSE_ERROR . . . . . . . . . . . . . . . . . 412
SM_RC_SERVER_FILE_OPEN_ERROR. . . . . . . . . . . . . . . . . . 412
SM_RC_SERVER_FILE_READ_ERROR. . . . . . . . . . . . . . . . . . 413
SM_RC_SERVER_FILE_WRITE_ERROR . . . . . . . . . . . . . . . . . 413
SM_RC_SERVER_MALLOC_ERROR . . . . . . . . . . . . . . . . . . . .414
SM_RC_SERVER_PROCESS_ERROR . . . . . . . . . . . . . . . . . . . 414
SM_RC_SERVER_TERMINATED.. . . . . . . . . . . . . . . . . . . . . . . 415
SM_RC_SM_EINVAL_MSG_TYPE. . . . . . . . . . . . . . . . . . . . . . . 415
SM_RC_SM_NOT_ACTIVE_CLIENT . . . . . . . . .. . . . . . . .. . . . 415
SM_RC_SM_NOT_OPEN. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 416
SM_RC_SUB_UNSET_ERROR . . . . . . . . . . . . . . . . . . . . . . . . .416
SM_RC_SPELLING_TOO_LONG. . . . . . . . . . . . . . . . . . . . . . . . 416

IBM ViaVoice SDK for Windows


Contents

SM_RC_USERID_BUSY. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 417
SM_RC_USERID_EXISTS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 417
SM_RC_WRONG_SM_VERSION . . . . . . . . . . . . . . . . . . . . . . . 417
SM_STAT_BAD_AUDIO . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 418
SM_STAT_BAD_MESSAGE . . . ...... . . . ..... . . . ...... . . 418
SM_STAT_BAD_TAG. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 418
SM_STAT_BAD_UTTERANCE. . . . . . . . . . . . . . . . . . . . . . . . . . 419
SM_STAT_ENROLLMENT_BUSY. . . . . . . . . . . . . . . . . . . . . . . . 419
SM_STAT_ENROLLMENT_COMPLETE. . . . . . . . . . . . . . . . . . . 419
SM_STAT_ENROLLMENT_FAILED . . . . . . . . . . . . . . . . . . . . . . 420
SM_STAT_ENROLLMENT_RECORDING. . . . . . . . . . . . . . . . . . 420
SM_STAT_ENROLLMENT_RUNNING . . . . . . . . . . . . . . . . . . . . 420
SM_STAT_PLAY_START. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 421
SM_STAT_PLAY_STOP. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 421
ROUTER.MSGLog. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 422
SM_INIT_DATABASE_REPLY.. . . . . . . . . . . . . . . . . . . . . . . . . . 423
SM_INIT_RECOGNIZER_REPLY. . . . . . . . . . . . . . . . . . . . . . . . 423
SM_TERMINATE_DATABASE_REPLY . . . . . . . . . . . . . . . . . . . . 423
SM_TERMINATE_RECOGNIZER_REPLY . . . . . . . . . . . . . . . . . 423

Appendix B DMAPI Return Codes and Messages 425

DMAPI Return Codesand Messages. . . ..... . . . ..... . . . . ... 425
DMAPIMessage Explanations . . . ...... . . . ..... . . . ...... . . 427
DM_ERR_ACT_FILE_PARSE.. . . . . . . . . . . . . . . . . . . . . . . . . . 427
DM_ERR_BAD_EXE_FORMAT . . . . . . . . . . . . . . . . . . . . . . . . . 427
DM_ERR_DUPLICATE_MACRO. . . . . . . . . . . . . . . . . . . . . . . . . 427
DM_ERR_EACCESS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 428
DM_ERR_EBADF.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 428
DM_ERR_EMFILE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 428
DM_ERR_ENOENT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 429
DM_ERR_ENOSPC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 429
DM_ERR_EXPDLL_ERR . ..... . . . . ..... . . . ..... . . . . ... 429
DM_ERR_EXPDLL_LOAD_FAILED . . ..... . . . ..... . . . . ... 430
DM_ERR_EXPDLL_QUERYFUN_FAILED . . . . . . . . . . . . . . . . . 430
DM_ERR_EXPDLL_TIMEOUT.. . . . . ..... . . . ..... . . . . ... 430
DM_ERR_FILE_READ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 431
DM_ERR_INI_FILE_PARSE. . . . . . . . . . . . . . . . . . . . . . . . . . . . 431

IBM SMAPI Reference


Appendix C
Appendix D


Index

Contents

DM_ERR_INVALID_DOMAIN . . . . . . . . . . . . . . . . . . . . . . . . . . .431
DM_ERR_INVALID_HANDLE . . . . . . . . . . . . . . . . . . . . . . . . . . .432
DM_ERR_INVALID_KEYTYPE . . . . . . . . . . . . . . . . . . . . . . . . . .432
DM_ERR_INVALID_KEYWORD. . . . . . . . . . . . . . . . . . . . . . . . . 432
DM_ERR_INVALID_LANGUAGE. . . . . . . . . . . . . . . . . . . . . . . . . 433
DM_ERR_INVALID_MACRO. . . . . . . . . . . . . . . . . . . . . . . . . . . . 433
DM_ERR_INVALID_MACROFILE. . . . . . . . . . . . . . . . . . . . . . . . 433
DM_ERR_INVALID_MACRORELEASE . . . . . . . . . . . . . . . . . . .434
DM_ERR_INVALID_MACROVERSION. . . . . . . . . . . . . . . . . . . . 434
DM_ERR_INVALID_TEMPLATE. . . . . . . . . . . . . . . . . . . . . . . . . 434
DM_ERR_INVALID_USERID. . . . . . . . . . . . . . . . . . . . . . . . . . . . 435
DM_ERR_LOAD_RESOURCE_DLL. . . . . . . . . . . . . . . . . . . . . . 435
DM_ERR_MACRO_NESTING. . . . . . . . . . . . . . . . . . . . . . . . . . . 435
DM_ERR_MACRO_NOT_FOUND. . . . . . . . . . . . . . . . . . . . . . . . 436
DM_ERR_MALLOC.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 436
DM_ERR_MISSING_CLIPBRD_FORMAT . . . . . . . . . . . . . . . . . 436
DM_ERR_NOT_ENOUGH_SHARED_MEMORY . . . . . . . . . . . . 437
DM_ERR_NOTIFY_EXCEEDED.. . . . . . . . . . . . . . . . . . . . . . . . 437
DM_ERR_NOUPDATE.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 437
DM_ERR_OK. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 438
DM_ERR_OPEN_CLIPBOARD_FAILED. . . . . . . . . . . . . . . . . . . 438
DM_ERR_OUT_OF_SYSTEM_RES. . . . . . . . . . . . . . . . . . . . . . 438
DM_ERR_FILE_SET_AFFECT_FLAG . . . . . . . . . . . . . . . . . . . .439
DM_ERR_SHARED_MEM_UNDEFINED . . . . . . . . . . . . . . . . . . 439
DM_ERR_SYSTEM_PARM_LONG. . . . . . . . . . . . . . . . . . . . . . . 439
DM_ERR_TEMPLATE_NOT_FOUND. . . . . . . . . . . . . . . . . . . . . 440
DM_ERR_TRANSFER_TO_CLIPBRD . . . . . . . . . . . . . . . . . . . .440
DM_ERR_UNDEFINED. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 440
DM_ERR_UNEXPECTED_EOF . . . . . . . . . . . . . . . . . . . . . . . . . 441

Speech Recognition Engine Error Messages 443

Notices 445

Trademarks .. . . . . ..... . . . . ..... . . . . ..... . . . ..... . . . .446

447

IBM ViaVoice SDK for Windows


About This Book

This book provides detailed information on developing Windowsa 95/98 or Windows NT. speech-
aware applications using IBM ViaVoice. Speech Solutions Developer’s Kit (SDK) for Windows and
Speech Manager Application Programming Interfaces (SMAPI) from IBM. The ViaVoice SDK
provides three sets of APIs: Speech Manager APIs (SMAPI), Dictation Macro APIs (DMAPI), and
Grammar Compiler APIs. This document is a PDF format viewable with the Adobe Acrobat Reader
and we recommend that you print it out.

Who Should Read This Book

Read this book if you are a software developer interested in writing Windows 95/98 or Windows NT

4.0 applications using the ViaVoice SDK APIs.
Related Publications

Refer to the following publications included with this version for additional programming, reference,
and design information:

. SMAPI Developer’s Guide
. SAPI Reference
. ActiveX Developer’s Guide
. ActiveX Developer’s Guide Help File
Refer to the following sources for additional programming, reference, and design information:

. ViaVoice Developer’s Corner website at:
http://www.ibm.com/viavoice/dev_home.html

. IBM ViaVoice SDK Web Channel at:
http://www.software.ibm.com/viavoice/subscribe.html

. OLE Automation Reference from Microsoft
IBM SMAPI Reference


IBM ViaVoice SDK for Windows


Chapter 1 SMAPI Overview

This chapter describes the format of the function calls that are presented in Chapter 3 “Function Calls
to the Speech Recognition Engine” and Chapter 4 “Data Access Functions”. Chapter 3 contains the
function calls that go directly to the speech recognition engine. Chapter 4 contains the function calls
that do not interact with the engine; they provide local access to the logical contents of a message that
has already been received.

This chapter also lists the calls by functional group.

Format of the Function Call Descriptions

The description of each function call contains the following information:

Function Name

The name of the function call.

Purpose

The purpose and description of the function call.

Syntax

The syntax of the function as declared in SMAPI.H.

Parameters

Definitions of the parameters.

IBM SMAPI Reference


SMAPI Overview

Return Values

Return values are listed in two groups:

.
Return values that are set by the SMAPI or as a result of an unsuccessful connection to the
speech recognition engine. These values are always returned by the called function whether it
was called synchronously or asynchronously.
.
Return values that are set from within the speech recognition engine. These values are returned
by the called function only if it was called synchronously. If it was called asynchronously, the
speech-aware application must retrieve this type of return value from within the appropriate
callback by using the SmGetRc function.
For detailed descriptions of SMAPI errors, reference “SMAPI Return Codes and Messages” on
page 369.

Reply Structure Functions by Message Type

A list of all reply message structures that can be received from the speech recognition engine; and
for each listed reply message structure, the SmGet functions that can extract data from it.

Task Related Functions and Callbacks

A list of functions and callbacks broadly related by task to this function. This is applicable to
functions that do not return a reply structure. For example, task related groups include:

.
Vocabulary Processing
.
User Processing
.
Application Initiation
.
Speech Processing
.
Application Termination
IBM ViaVoice SDK for Windows


This section also lists related unsolicited callbacks.

Reply Structure-Related Functions and Callbacks

Clarifies when the SmGet functions can be called. If the function prototype SmXxx is listed as
related for any SmGet function, then that function can be called as follows:

.
Immediately after a synchronous SmXxx call
.
From SmNXxxCallback after an asynchronous SmXxx call
.
From the message reply structure after an asynchronous SmXxx call.
Naming Conventions

Use the following conventions when creating various IDs and names passed to the speech recognition
engine:

.
User IDs can consist of only lowercase alphanumeric characters plus the underscore and
hyphen characters.
.
Descriptions cannot contain a new line character.
.
An ID must contain at least one character.
The following values, found in the file SMLIMITS.H, shows the maximum lengths of key variables:
#define SM_MAX_USERID_LEN 8
#define SM_MAX_ENROLLID_LEN 8
#define SM_MAX_TASKNAME_LEN 8
#define SM_MAX_SCRIPTNAME_LEN 8

IBM SMAPI Reference


SMAPI Overview

SMAPI Function Calls by Group

The following information lists the SMAPI calls by functional group.

Attribute Handling Functions

These functions are implemented locally within the application's address space by the SMAPI layer
and do not require any interaction with the speech recognition engine. Consequently, they can be made
at any time, independent of the speech focus.

. SmSetArg
Callback and Dispatching Functions

These functions are also implemented locally in the application's address space by the SMAPI layer.

. SmAddCallback
. SmDispatch
. SmReceiveMsg
. SmRemoveCallback
Data Access Functions

The data access functions manipulate data received by the application. They are independent of the
speech focus.

. SmGetAlphabets
. SmGetAlternates
. SmGetAnnotations
. SmGetApplication
. SmGetApplications
. SmGetAudioLevel
IBM ViaVoice SDK for Windows


. SmGetBinaryItemValue
. SmGetCodepage
. SmGetDefaultTopics
. SmGetDescriptions
. SmGetEngineState
. SmGetEnrollId
. SmGetEnrollIds
. SmGetEventId
. SmGetEventOptions
. SmGetFirmWords
. SmGetFlags
. SmGetFocusState
. SmGetInfirmWords
. SmGetItemValue
. SmGetLanguages
. SmGetMicState
. SmGetMsgName
. SmGetMsgType
. SmGetNameValue
. SmGetNumberWordMsgs
. SmGetOptions
. SmGetPercentages
. SmGetPhraseScore
. SmGetPreferred
. SmGetPronunciations
. SmGetRc
IBM SMAPI Reference


SMAPI Overview

. SmGetRcDescription
. SmGetRcName
. SmGetSampleRates
. SmGetScriptFlags
. SmGetScripts
. SmGetService
. SmGetSessionId
. SmGetSeverity
. SmGetSizes
. SmGetSpeechDataArchive
. SmGetSpeechDataOptions
. SmGetSpeechDataSize
. SmGetSpeechDataVersion
. SmGetSpelling
. SmGetSpellings
. SmGetStates
. SmGetStatus
. SmGetTags
. SmGetTask
. SmGetTaskFlags
. SmGetTasks
. SmGetTimes
. SmGetTopics
. SmGetTrained
. SmGetUserId
. SmGetUserIds
IBM ViaVoice SDK for Windows


. SmGetUsers
. SmGetUtteranceNumber
. SmGetVocabList
. SmGetVocabName
. SmGetVocabPath
. SmGetVocWords
. SmGetWords
. SmGetWordTimes
. SmReturnRc
. SmReturnRcDescription
. SmReturnRcName
Connection Functions

These functions enable an application to connect to, or disconnect from, the speech recognition engine.

. SmApiVersionCheck
. SmOpen
. SmConnect
. SmDisconnect
. SmClose
IBM SMAPI Reference


SMAPI Overview

Session Functions

The session-sharing related calls are appropriate when an application is in a particular state.

. SmDetachSessions
. SmReleaseFocus
. SmRequestFocus
. SmRequestMicOff
. SmRequestMicOn
Database Functions

These functions access database information. Although they do divert some engine resources, they do
not interfere with the application's use of the speech recognition engine. Consequently, they are
permitted at any time after calling SmConnect. Some returned information pertains to a specific
session; some pertains to the speech recognition engine as a whole.

. SmQueryAddedWords
. SmQueryAddedWordsEx
. SmQueryAlternates
. SmQueryDefaults
. SmQueryEnabledVocabs
. SmQueryEnrollIds
. SmQueryLanguages
. SmQueryPronunciation
. SmQueryPronunciations
. SmQueryPronunciationsEx
. SmQuerySessions
. SmQueryTasks
. SmQueryTopics
IBM ViaVoice SDK for Windows


. SmQueryUserDefault
. SmQueryUserInfo
. SmQueryUsers
. SmQueryVocabs
. SmQueryWord
The following functions are administrative. They do not change the state of the engine for the
application with focus:

. SmSetDefault
. SmSetUserDefault
. SmSetUserInfo
Speech Recognition Engine State Functions

These functions set and query the state of the speech recognition engine.

. SmSet
. SmQuery
Vocabulary Functions

These functions change the state of the active, dynamically specified vocabularies, and they are
handled independently for each session. They are transparent to the application.

. SmAddPronunciation
. SmAddToVocab
. SmCorrectText
. SmDefineVocab
. SmDefineVocabEx
. SmDisableVocab
IBM SMAPI Reference


SMAPI Overview

. SmDiscardData
. SmEnableVocab
. SmEventNotify
. SmHaltRecognizer
. SmNewContext
. SmRecognizeNextWord
. SmRemoveFromVocab
. SmRemovePronunciation
. SmUndefineVocab
. SmWordCorrection
Audio Functions

These functions change the state of the audio system. Given a single audio source, this changes the
engine state for the application with focus. Therefore, these functions can only be called by the
application with focus.

. SmCancelPlayback
. SmMicOn
. SmMicOff
. SmPlayMessage
. SmPlayUtterance
. SmPlayWords
IBM ViaVoice SDK for Windows


Parallel Session API Calls

Parallel Session API Calls

The feature of having multiple engine connections from a single application is known as parallel
sessions. If you want more than one connection from your application, you must use the parallel
session calls. The name of a parallel session call is the same as the regular function call except for two
things: the name of the call has the characters Ses inserted after the Sm, for example the parallel
session disconnect call is SmSesDisconnect. Secondly, each parallel session call takes one additional
parameter, which is the session ID. This is always the first parameter. So for the disconnect example,
the call is SmSesDisconnect(hSession), where hSession is the session ID. The session ID is returned
in the first parameter of the SmSesOpen call.

IBM SMAPI Reference


SMAPI Overview

IBM ViaVoice SDK for Windows


Chapter 2 Starter Set APIs

To develop a full-function speech application, you do not need to use all of the functions provided in
the SMAPI. You can use a subset of calls, known as the Starter Set SMAPIs. These calls do not use
separate header or library files.

Note:

The ViaVoice Run Time Kit contains several user interface applications that you must include with
your speech-aware application. Inclusion of these applications ensures optimal recognition performance
for your users. They also serve as reusable applications, so that you don't have to develop
these same functions yourself (setting up the microphone, changing ViaVoice system parameters,
enrollment, and managing the user's personal vocabulary).

Starter Set SMAPIs for Command and Control

When writing your command and control application, you must first establish a connection with the
speech recognition engine. Next, you direct the engine to start processing speech. Your application
interacts with the engine to set up and activate vocabularies and grammars. Most of your work is
involved in processing the recognized speech. When you are done, you disconnect from the engine.

Here are the Starter Set SMAPIs for command and control applications:

. SmOpen
. SmConnect
. SmDefineGrammar
. SmDefineVocab
. SmDefineVocabEx
. SmEnableVocab
. SmDisableVocab
. SmRequestFocus
. SmReleaseFocus
IBM SMAPI Reference


Starter Set APIs

. SmMicOn
. SmMicOff
. SmRecognizeNextWord
. SmReceiveMsg
. SmGetFirmWords
. SmGetAnnotations
. SmDisconnect
. SmClose
Establishing a Recognition Session

To establish a recognition session with the engine, use SmOpen to set up local parameters for starting
the engine and SmConnect, which actually establishes the link between your application and the
engine. You can use SmSetArg to set the input parameters to SmOpen and SmConnect (such as
language, user ID, and enroll ID), but you'll probably want to take the defaults using
SM_DEFAULT_* parameters.

Setting Up and Enabling Vocabularies

A vocabulary is a list of words and/or phrases that the engine uses to match speech input and translate
it into text. Your command and control application specifies the set of active words by defining and
enabling one or more vocabularies. A vocabulary can be predefined in a grammar file, or it can be
created at runtime as a dynamic command vocabulary.

By passing the name of your compiled grammar file to SmDefineGrammar, the words and phrases of
your grammar are defined to the engine. SmDefineVocab allows you to build command vocabularies
dynamically by passing a list of words and phrases that make up that vocabulary. You would also use
this call to define the names for any external references in your grammar file. SmEnableVocab
enables a vocabulary. When decoding speech, the engine searches all of the enabled vocabularies to
translate speech to text. You can have more than one vocabulary active in your application at a time.

IBM ViaVoice SDK for Windows


To improve performance (both recognition speed and accuracy), your application should narrow the
possibilities by enabling and disabling vocabularies as they are needed. You disable a vocabulary by
using the SmDisableVocab call.

Directing the Engine to Process Speech

The speech recognition engine supports both shared and parallel sessions, which means that there can
be several applications connected to the speech recognition engine at the same time, and that a single
application can have more than one connection to the speech recognition engine at the same time, too.
You should design your application so that it cooperates with other speech-aware applications for
control of the microphone. This is known as "having speech focus." An application must have speech
focus to receive recognized text; this may or may not equate to input focus. You need to ensure that
your application has speech focus when it needs it. This is done by using SmRequestFocus to request
speech focus and SmReleaseFocus to release speech focus when you're done.

Once you have speech focus, your application must tell the engine to start processing audio data.
SmMicOn engages the engine to start processing audio data, and SmMicOff tells the engine to stop
processing audio data.

Processing Recognized Commands

The bulk of the work in your application involves getting the recognized commands from the engine
and determining what to do with it. For a command and control application, the engine waits for your
application to direct it to start recognizing words. Use SmRecognizeNextWord to start the engine
looking for words to decode. When the engine recognizes a word from a dynamic command
vocabulary, it returns the word with alternates in the SM_RECOGNIZED_WORD message. When a
phrase is recognized from a grammar, the engine returns the set of words and annotations in the
SM_RECOGNIZED_PHRASE message. Use SmReceiveMsg to accept and process these messages.
In either case, the engine stops decoding until your application makes another
SmRecognizeNextWord call. This gives you a chance to change active vocabularies for recognizing
the next command. While halted, however, the engine continues to capture and process audio, so no
words are lost.

IBM SMAPI Reference


Starter Set APIs

Disconnecting from the Engine

When your application is closing down, you must disconnect and close the session with the speech
recognition engine. To do this, use SmDisconnect and SmClose.

Starter Set SMAPIs for Dictation

The Dictation Starter Set SMAPIs will enable you to develop a dictation application that supports
commands, dictation, word-error playback and correction, and language model cache updates.

. SmOpen
. SmConnect
. SmDefineGrammar
. SmDefineVocab
. SmEnableVocab
. SmDisableVocab
. SmUndefineVocab
. SmMicOn
. SmMicOff
. SmRequestFocus
. SmReleaseFocus
. SmNewContext
. SmRecognizeNextWord
. SmGetFirmWords
. SmGetInfirmWords
. SmHaltRecognizer
. SmEventNotify
IBM ViaVoice SDK for Windows


. SmReceiveMsg
. SmQueryAlternates
. SmPlayWords
. SmWordCorrection
. SmDiscardData
. SmDisconnect
. SmClose
Establishing a Recognition Session

To establish a recognition session with the engine, use SmOpen to set up local parameters for starting
the engine and SmConnect, which actually establishes the link between your application and the
engine. You can use SmSetArg to set the input parameters to SmOpen and SmConnect (such as
language, user ID, and enroll ID), but you'll probably want to take the defaults using
SM_DEFAULT_* parameters.

Setting Up and Enabling Vocabularies

A vocabulary is a list of words and/or phrases that the engine uses to match speech input and translate
it into text. Your application specifies the set of active words by defining and enabling one or more
vocabularies.

A dictation application must first enable a predefined domain (such as the general office vocabulary)
before the engine can use it to decode text. It does so by using the SmEnableVocab function. To have
command words recognized during dictation (such as "stop dictation"), the application must enable the
dictation vocabulary first, and then define the command vocabulary. Grammar vocabularies cannot be
active at the same time as dictation vocabularies, although you can support both dictation and
command and control within the same application. SmDefineGrammar defines a grammar
vocabulary to the engine, and SmDefineVocab defines a dynamic command vocabulary.
SmEnableVocab enables all types of vocabularies (dictation, grammar, and dynamic command).

IBM SMAPI Reference


Starter Set APIs

To improve performance (both recognition speech and accuracy), your application should narrow the
possibilities by enabling and disabling vocabularies as they are needed. You disable a vocabulary by
using the SmDisableVocab call. You can also use SmUndefineVocab to delete a dynamic command
vocabulary, but it must have been disabled first.

Directing the Engine to Process Speech

The speech recognition engine supports both shared and parallel sessions, which means that there can
be several applications connected to the speech recognition engine at the same time, and that a single
application can have more than one connection to the speech recognition engine at the same time, too.
You should design your application so that it cooperates with other speech-aware applications for
control of the microphone. This is known as "having speech focus." An application must have speech
focus to receive recognized text; this may or may not equate to input focus. You need to ensure that
your application has speech focus when it needs it. This is done by using SmRequestFocus to request
speech focus and SmReleaseFocus to release speech focus when you're done.

Once you have speech focus, your application must tell the engine to start processing audio data.
SmMicOn engages the engine to start processing audio data, and SmMicOff tells the engine to stop
processing audio data.

Processing Recognized Text

The bulk of the work in your application involves getting the recognized text from the engine and
determining what to do with it. For a dictation application, the engine waits for your application to
direct it to start recognizing words. Use SmRecognizeNextWord to start the engine looking for words
to decode. If the engine recognizes a word from a dictation vocabulary, the available decoded words
are sent to the application in an SM_RECOGNIZED_TEXT reply message. The
SM_RECOGNIZED_TEXT reply message provides a list of firm and infirm words. Use
SmReceiveMsg to receive messages from the engine. The engine continues decoding words as they
are spoken. SmEventNotify requests that your application be notified when the engine completes
decoding all of the audio up to the point of the call.

Commands are handled as described in the preceding section, "Processing Recognized Commands".

IBM ViaVoice SDK for Windows


When a word is recognized, there is a reply structure generated which you can access via function
calls. This allows you to access both firm and infirm words. When your application is notified that a
word is recognized, use SmGetFirmWords and SmGetInfirmWords to retrieve the list of words from
the reply message.

The engine continues decoding speech after a word is recognized during dictation. There are times
your application may need to halt the engine during dictation recognition; for example, while setting
new context or adding pronunciations. To do this, use SmHaltRecognizer, which will temporarily halt
recognition. A subsequent SmRecognizeNextWord call restarts the recognition process.

SmNewContext is called when dictation begins at a new location in the document. Context refers to
the previous and following words, which are used to decode the current word.

If the engine recognizes a word from a command vocabulary, the word is sent to the application in an
SM_RECOGNIZED_WORD reply message. The engine halts and waits for further instruction from
the application. Use SmGetFirmWords on SM_RECOGNIZED_WORD to get the recognized text
from the engine.

Correcting Errors

Correcting misrecognized words and improving recognition by updating personal data files are key
functions of dictation applications. Use SmPlayWords to play back previously spoken words or
phrases to the user. This can be of great help to the user in the correction process. Use
SmQueryAlternates to provide alternative choices when incorrectly recognized words have been
detected by the user. SmWordCorrection corrects a misrecognized word. It notifies the engine that a
word or sequence of words was corrected by the user. It can be used to update the user's text
vocabulary, word-usage model, and pronunciation pool.

Since the data that the engine stores can be resource intensive, use SmDiscardData to discard audio
and error correction data for recognized words that are not referenced again. This can conserve speech
recognition engine disk space requirements.

IBM SMAPI Reference


Starter Set APIs

Disconnecting from the Engine

When your application is closing down, you must disconnect and close the session with the speech
recognition engine. To do this, use SmDisconnect and SmClose.

IBM ViaVoice SDK for Windows


Chapter 3 Function Calls to the Speech
Recognition Engine

This chapter lists and describes the function calls that go directly to the speech recognition engine.

SmAddCallback

Purpose
SmAddCallback adds a single callback routine for the specified message.

Syntax

int SmAddCallback (char *reply_name, SmHandler *handler,
caddr_t client_data);


Parameters

reply_name


input - The name of the type of message.

handler


input -The function name of the routine that handles the message.

client_data


input - Data passed back to the handler when it is called.

Return Values

Sm_RC_EALLOC
SM_RC_ENOMEM
SM_RC_NOT_VALID_REQUEST
SM_RC_OK
SM_RC_SM_NOT_OPEN


Task Related Functions and Callbacks

SmDispatch
SmRemoveCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmAddPronunciation

Purpose
SmAddPronunciation adds a new pronunciation.
This function provides the method for associating a pronunciation with a spelling.
The following restrictions apply when calling SmAddPronunciation:

.
The engine must be halted.
.
The utterance used to build the pronunciation must be complete.
.
If an SmAddPronunciation call fails and the call is immediately repeated with exactly the
same parameters, the engine will automatically apply more lenient threshold parameters the
second time. Reference “SmSet” on page 167 for a detailed description of the
SM_REJECTION_THRESHOLD parameter.
Note:

For this call to be valid, the application must first enable audio saving through
SmSet(SM_SAVE_AUDIO, TRUE).

Syntax

int SmAddPronunciation (char *spelling, char *pronunciation, long uttno,
short repetitions, long options, SM_MSG *reply);


Parameters

spelling


input -A null-terminated character string containing the spelling for the added pronunciation.

pronunciation


input - A null-terminated character string containing the pronunciation added and associated with
the given spelling. This parameter holds the phonetic spelling for the word, which indicates how
the word is pronounced.

uttno


input - Utterance number.

repetitions


input - Number of repetitions must be set to 1.

IBM ViaVoice SDK for Windows


SmAddPronunciation

options


input -The options are:

.
SM_ADD_PRONUNCIATION_ADD -Add a pronunciation.
.
SM_ADD_PRONUNCIATION_REPLACE - Delete existing pronunciations and replace
them with this new one.
reply


input/output - A pointer to a reply structure or to SmAsynchronous, indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_ADDWORD_LIMIT_EXCEEDED
SM_RC_BAD_ACOUSTICS
SM_RC_BAD_ADDWORD
SM_RC_ILLEGAL_SOUNDSLIKE
SM_RC_ILLEGAL_SPELLING
SM_RC_MISMATCHED_ACOUSTICS
SM_RC_NOT_ADDED
SM_RC_NOT_VALID_REQUEST
SM_RC_NOT_YET
SM_RC_SERVER_ERROR
SM_RC_SERVER_FILE_OPEN_ERROR
SM_RC_SERVER_FILE_READ_ERROR


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SM_RC_SERVER_FILE_WRITE_ERROR
SM_RC_SERVER_MALLOC_ERROR


Reply Structure Functions by Message Type

SM_ADD_PRONUNCIATION_REPLY


SmGetRc


SmGetSpelling


SmGetSpellings


Task Related Functions and Callbacks

SmQueryPronunciation
SmQueryPronunciations
SmRemovePronunciation
SmNaddPronunciationCallback
SmNqueryPronunciationCallback
SmNqueryPronunciationsCallback
SmNremovePronunciationCallback


IBM ViaVoice SDK for Windows


SmAddToVocab

SmAddToVocab

Purpose

SmAddToVocab adds words to a vocabulary.

This function adds words to predefined vocabularies or to a vocabulary previously created by
SmDefineVocab. SmAddToVocab can be used to dynamically change command vocabularies
within an application. If any of the specified words do not have an existing pronunciation, the call
returns the list of words without pronunciations. Missing pronunciations must be added by using the
SmAddPronunciation function. Pronunciations exist for all words in the predefined vocabularies
and for words added by the user. For a predefined vocabulary the words are added in the user's
personal pronunciation area of the vocabulary.

This call is valid only when the speech recognition engine is not decoding speech to text.

If a specified word does not exist in the current pool, the backup dictionary will be searched. If the
word is found in the backup dictionary, it will be added to the temporary pool, except that when
SmAddToVocab specifies a dictation vocabulary such as “text,” the word will be added to the
personal pool.

Syntax

int SmAddToVocab (char *vocab, short nvocwords, SM_VOCWORD *vocwords[],
SM_MSG *reply);


Parameters

vocab


input - The name of the vocabulary to which words are added.

nvocwords


input - The number of words added to the vocabulary, up to the limit defined by

SM_MAX_WORDS.

vocwords


input -The spellings of the words added to the vocabulary.

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is

made asynchronously.

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_BAD_VOCAB
SM_RC_NOT_VALID_REQUEST
SM_RC_SERVER_FILE_OPEN_ERROR
SM_RC_SERVER_FILE_WRITE_ERROR


Reply Structure Functions by Message Type

SM_ADD_TO_VOCAB_REPLY


SmGetRc


SmGetVocabName


SmGetVocWords


Task Related Functions and Callbacks

SmDefineVocab
SmDisableVocab
SmEnableVocab
SmQueryAddedWords
SmQueryEnabledVocabs
SmQueryVocabs
SmQueryWord
SmRemoveFromVocab
SmUndefineVocab


IBM ViaVoice SDK for Windows


SmAddToVocab

SmNaddToVocabCallback
SmNdefineVocabCallback
SmNdisableVocabCallback
SmNenableVocabCallback
SmNqueryAddedWordsCallback
SmNqueryEnabledVocabsCallback
SmNqueryVocabsCallback
SmNqueryWordsCallback
SmNremoveFromVocabCallback
SmNundefineVocabCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmApiVersionCheck

Purpose

SmApiVersionCheck verifies the current version of the SMAPI.

This function checks whether the version of the SMAPI used to compile the speech-aware
application is compatible with the API currently installed on the system. The reply message
contains the return code indicating the current status.

Syntax

int SmApiVersionCheck (char *caller_version, char **sm_version);


Parameters

caller_version


input - Indicates the version used to compile the application. The constant

SM_API_VERSION_STRING is used for the comparison check.

sm_version


output - The version of the SMAPI currently installed on the system.

Return Values

SM_RC_OK
SM_RC_WRONG_SM_VERSION


IBM ViaVoice SDK for Windows


SmAutoComplete

SmAutoComplete

Purpose
SmAutoComplete is called by a client application to request completions of a specified string.

Syntax

int SmAutoComplete (unsigned long flags, int max_depth, char *spelling,
SM_MSG *reply);


Parameters

flags


input - reserved

max_depth


input - maximum number of completions to return. Limited to SM_MAX_VOCWORDS.

spelling


input - string for which completions are requested

reply


input - The pointer to a reply structure or to SmAsynchronous indicating that the call is made

asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST
SM_RC_SERVER_FILE_OPEN_ERROR
SM_RC_SERVER_FILE_READ_ERROR
SM_RC_SERVER_MALLOC_ERROR


Reply Structure Functions by Message Type

SM_AUTO_COMPLETE_REPLY
SmGetSpelling
SmGetSpellings


Task Related Functions and Callbacks

SmNautoCompleteCallback


Access Functions

SmGetSpelling (returns spelling)
SmGetSpellings (returns spellings array)


Remarks

SmAutoComplete will search active vocabularies, including topics, for completions of the given
string. If the number requested cannot be satisfied from the active vocabularies, the backup
dictionary will be searched.

IBM ViaVoice SDK for Windows


SmCancelPlayback

SmCancelPlayback

Purpose

SmCancelPlayback cancels the request to play back a message, utterance, or words.

This function cancels a play request from the SmPlayMessage, SmPlayUtterance, and

SmPlayWords functions.

Syntax

int SmCancelPlayback (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_CANCEL_PLAYBACK_REPLY
SmGetRc


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Task Related Functions and Callbacks

SmPlayMessage
SmPlayUtterance
SmPlayWords
SmNcancelPlaybackCallback
SmNplayMessageCallback
SmNplayMessageStatusCallback
SmNplayUtteranceCallback
SmNplayUtteranceStatusCallback
SmNplayWordsCallback
SmNplayWordsStatusCallback


IBM ViaVoice SDK for Windows


SmClose

SmClose

Purpose

SmClose closes the SMAPI connection.

If the speech-aware application has not already called the SmDisconnect function to terminate the

connection with the speech recognition engine, the speech API does so before executing SmClose.

Syntax

int SmClose ();


Parameters

None.

Return Values

SM_RC_OK
SM_RC_SM_NOT_OPEN


Task Related Functions and Callbacks

SmDisconnect
SmNdisconnectCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmConnect

Purpose

SmConnect connects to the speech recognition engine.

This function establishes a session with the speech recognition engine. The desired type of session
and other necessary information are provided by setting SMAPI attributes. Once a session is
established the session type cannot be changed. To change the session type, call SmDisconnect
then call SmConnect again.

Syntax

int SmConnect (int nargs, SmArg *Args, SM_MSG *reply);


Parameters

nargs


input - The number of arguments in the accompanying argument list.

Args


input - A set of arguments that indicate the parameters used to connect to the speech recognition
engine. Speech API arguments can also be set prior to an SmConnect call by using the SmSetArg
function, which specifies the parameter or attribute name and its value. The attributes passed to
this function determine the session type.

For details on establishing a speech session, see the SMAPI Developer's Guide. For details on the
attributes, see “SMAPI Attributes” on page 305.

reply


input - The pointer to a reply structure or to SmAsynchronous, indicating that the call is made
asynchronously.

IBM ViaVoice SDK for Windows


SmConnect

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_EUNEXP
SM_RC_INCOMPATIBLE_ENROLLMENT
SM_RC_NAVIGATOR_ALREADY_DEFINED
SM_RC_SM_NOT_OPEN
SM_RC_ALREADY_CONNECTED
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_BAD_ADDWORD
SM_RC_BAD_AP
SM_RC_BAD_AUDIO
SM_RC_BAD_DECO
SM_RC_BAD_DESCRIPTION
SM_RC_BAD_ENROLLID
SM_RC_BAD_PASSWORD
SM_RC_BAD_SCRIPT
SM_RC_BAD_TASKID
SM_RC_BAD_USERID
SM_RC_ENROLLID_EXISTS
SM_RC_ENROLLID_RUNNING
SM_RC_ENROLLMENT_NOT_COMPLETE
SM_RC_MISMATCHED_ALPHABET
SM_RC_MISMATCHED_LANGUAGE
SM_RC_MISMATCHED_SCRIPT
SM_RC_NOT_VALID_REQUEST
SM_RC_SERVER_ERROR
SM_RC_SEVER_FILE_OPEN_ERROR


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_CONNECT_REPLY
SmGetMsgType
SmGetRc
SmGetService
SmGetSessionId
SmGetTask
SmGetTasks
SmGetUserId


Only recognition sessions:

SmGetCodepage
SmGetEnrollId
SmGetEnrollIds
SmGetLanguages
SmGetSessionId
SmGetUserId
SmGetUserIds


Task Related Functions and Callbacks

SmOpen
SmSetArg
SmNconnectCallback


IBM ViaVoice SDK for Windows


SmCorrectText

SmCorrectText

Purpose

SmCorrectText updates the user's voice model with a sequence of text the user considers correct.

This function provides the speech recognition engine with a sequence of correctly recognized text.
This text can be used to adapt the user's voice model, thereby improving future recognition of
dictated text.

Syntax

int SmCorrectText (short nwords, SM_WORD *words[], SM_MSG *reply);


Parameters

nwords


input - The number of words in the text sequence.

words


input - An array of pointers to the words of the text.

reply


input/output - The pointer to a reply structure indicating that the call is made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST
SM_RC_SERVER_FILE_OPEN_ERROR
SM_RC_SERVER_FILE_WRITE_ERROR


Reply Structure Functions by Message Type

SM_CORRECT_TEXT_REPLY
SmGetRc


Task Related Functions and Callbacks

SmNewContext
SmRemovePronunciation
SmWordCorrection
SmNcorrectTextCallback
SmNnewContextCallback
SmNremovePronunciationCallback
SmNwordCorrectionCallback


IBM ViaVoice SDK for Windows


SmDefineGrammar

SmDefineGrammar

Purpose

SmDefineGrammar defines a grammar-based vocabulary.

This function dynamically defines a new vocabulary that can be enabled through the
SmEnableVocab function, along with dynamic command vocabularies defined through
SmDefineVocab. The vocabulary content is specified by a precompiled FSG file, produced by the
grammar compiler.

Like SmDefineVocab, SmDefineGrammar returns a list of grammar words that don't have
pronunciations. Unlike SmDefineVocab, if any pronunciation is missing, SmDefineGrammar
fails with a return code of SM_RC_NOT_INVOCAB, since recognition of a grammar network
with missing pronunciations is not well defined. Use SmGetVocWords to retrieve the list of
missing words.

If external lists are missing (for example, there was no SmDefineVocab before the
SmDefineGrammar), SmDefineGrammar will also fail. This time, the return code is
SM_RC_MISSING_EXTERN. The names of the external lists are returned as if they were words
without pronunciations, and can also be obtained with SmGetVocWords.

Since missing externs is really a program logic error, these are checked and returned before
determining if any words are missing pronunciations. So, if both externs and words are missing,
you first get SM_RC_MISSING_EXTERN. When that is fixed, you get
SM_RC_NOT_INVOCAB.

Note that pronunciations can be found in the user's personal pool, application-specific pools
(created by Dictionary Builder) or the base domain pool. If a specified word does not exist in the
current pool, the backup dictionary will be searched. If the word is found in the backup dictionary,
it will be added to the temporary pool, except that when SmAddToVocab specifies a dictation
vocabulary such as “text,” the word will be added to the personal pool.

Syntax

int SmDefineGrammar (char *vocab, char *grammar, long options,
SM_MSG *reply);


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Parameters

vocab


input -The name of the new grammar.

grammar


input - The fully qualified path name of the FSG file containing the compiled grammar.

options


flags include:

.
SM_PHRASE_ALLOW_SILENCES - allow inter-word silences within phrase.
.
SM_PHRASE_SHOW_SILENCES -silence indicated in returned phrase. Silences are
returned via the word spelling "" in the recognized phrase message.
.
SM_PHRASE_NO_SILENCES - don't allow inter-word silences
.
SM_PHRASE_ALLOW_INSERTIONS - allow insertions within phrase
.
SM_PHRASE_SHOW_INSERTIONS - insertions indicated in returned phrase. Insertions
are returned via an empty word spelling "" in the recognized phrase message.
.
SM_PHRASE_NO_INSERTIONS -don't allow insertions
Note:

These run-time flags override settings compiled in the FSG file.

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is
made asynchronously.

Return Values

SM_RC_OK
SM_RC_MISSING_EXTERN
SM_RC_NOT_VALID_REQUEST
SM_RC_NOT_INVOCAB
SM_RC_BAD_VOCAB
SM_RC_SERVER_FILE_MALLOC_ERROR
SM_RC_SERVER_FILE_OPEN_ERROR
SM_RC_SERVER_FILE_READ_ERROR


IBM ViaVoice SDK for Windows


SmDefineGrammar

Reply Structure Functions by Message Type

SM_DEFINE_GRAMMAR_REPLY
SmNdefineGrammarCallback
SmGetVocabName
SmGetGrammarPath
SmGetVocWords


Task Related Functions and Callbacks

SmEnableVocab
SmUndefineGrammar
SmDisableVocab
SmNdisableVocabCallback
SmNdenableVocabCallback
SmNundefineVocabCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmDefineVocab

Purpose

SmDefineVocab defines a new vocabulary.

This function dynamically creates a new vocabulary that can later be used by calling the
SmEnableVocab function. The vocabulary created by SmDefineVocab consists only of the words
specified in the call with all words receiving an equal voice model weighting. This function can be
used to dynamically create command vocabularies in an application. If any of the specified words
do not have an existing pronunciation, the call returns a list of words without pronunciations.
Pronunciations can be found in the predefined vocabulary and in the user's personal vocabulary.
Predefined vocabularies are not dynamic. Dynamic vocabularies are intended for command
vocabulary recognition.

SmDefineVocab takes more time to execute than SmEnableVocab and SmDisableVocab;
therefore, it is more efficient to define a vocabulary once and enable/disable frequently rather than
to define multiple times.

This call is valid only when the speech recognition engine is not decoding speech to text. For
examples of conditions when the engine is not decoding speech to text, see "Setting Up
Vocabularies" in the SMAPI Developer's Guide.

If a specified word does not exist in the current pool, the backup dictionary will be searched. If the
word is found in the backup dictionary, it will be added to the temporary pool, except that when
SmAddToVocab specifies a dictation vocabulary such as “text,” the word will be added to the
personal pool.

Syntax

int SmDefineVocab (char *vocab, short nvocwords, SM_VOCWORD *vocwords[],
SM_MSG *reply);


Parameters

vocab


input -The name of the new vocabulary.

nvocwords


input -The number of words in the new vocabulary. Limited to SM_MAX_VOCWORDS.

IBM ViaVoice SDK for Windows


SmDefineVocab

vocwords


input -The spellings of the words in the new vocabulary.

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_BAD_VOCAB
SM_RC_NOT_VALID_REQUEST
SM_RC_SERVER_FILE_OPEN_ERROR
SM_RC_SERVER_FILE_WRITE_ERROR


Reply Structure Functions by Message Type

SM_DEFINE_VOCAB_REPLY
SmGetRc
SmGetVocabName
SmGetVocWords


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Task Related Functions and Callbacks

SmAddToVocab
SmDisableVocab
SmEnableVocab
SmQueryAddedWords
SmQueryEnabledVocabs
SmQueryVocabs
SmQueryWord
SmRemoveFromVocab
SmUndefineVocab
SmNaddToVocabCallback
SmNdefineVocabCallback
SmNdisableVocabCallback
SmNenableVocabCallback
SmNqueryAddedWordsCallback
SmNqueryEnabledVocabsCallback
SmNqueryVocabsCallback
SmNqueryWordsCallback
SmNremoveFromVocabCallback
SmNundefineVocabCallback


IBM ViaVoice SDK for Windows


SmDefineVocabEx

SmDefineVocabEx

Purpose

A new supported function, SmDefineVocabEx is an extension of the SMAPI function
SmDefineVocab. This function is called by a client application to define a vocabulary.


If a specified word does not exist in the current pool, the backup dictionary will be searched. If the
word is found in the backup dictionary, it will be added to the temporary pool, except that when
SmAddToVocab specifies a dictation vocabulary such as “text,” the word will be added to the
personal pool.

Syntax

int SmDefineVocabEx (char *vocab, void *data, int length, long options,
char *acoustic_id, char *poolname, SM_MSG *reply);


Parameters

vocab


input - The name of the vocabulary being defined.

data


Data used to define the new vocabulary. The form of the data depends on the value of the options
argument.

length


Length of data in bytes or number of elements

options


Options which specify how vocabulary is defined. These options are valid for almost all
vocabularies:


SM_VOCAB_REPLACE
Replace any currently defined vocabulary with the same name. This eliminates the need to
undefine the current vocabulary before defining the new one.

SM_VOCAB_GLOBAL
Active even if the client does not have focus.


SM_VOCAB_NOHALT
Engine does not halt after returning a command.


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

These options specify the format of the data:

SM_VOCAB_BINARY
The data is a buffer in binary format.
SM_VOCAB_FILE


The data is the name of a file.

SM_VOCAB_WORDS
The data is a list of words in ASCII format.
SM_VOCAB_VOCWORDS


The data is an array of pointers to SM_VOCWORD structures and the length field specifies
the number of elements in the array.

These options specify the type of vocabulary:
SM_VOCAB_COMMAND
Regular command vocabulary.

SM_VOCAB_TEXT

Acts like the “text” vocabulary but with no LM.
SM_VOCAB_FSG
Regular compiled grammar.


SM_VOCAB_PHRASE

Single-phrase grammar (for example, for Enrollment).
SM_VOCAB_SELECT
Select-phrase grammar (verb + any phrase)


SM_VOCAB_VERBFINAL
Verb follows selected phrase
In addition, the existing SM_PHRASE_ options may be set for grammars:

acoustic_id


Reserved: must be set to NULL

poolname


Reserved: must be set to NULL

reply


SmAsynchronous or pointer to reply structure.

IBM ViaVoice SDK for Windows


SmDefineVocabEx

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_BAD_VOCAB
SM_RC_MISSING_EXTERN
SM_RC_NOT_INVOCAB
SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_DEFINE_VOCABULARY_REPLY


SmGetVocabName


SmGetVocabPath


SmGetVocWords


SmGetEventOptions


Task Related Functions and Callbacks

SmAddToVocab
SmDefineVocab
SmDefineGrammar
SmDisableVocab
SmEnableVocab
SmQueryAddedWords
SmQueryEnabledVocabs
SmQueryVocabs


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmQueryWord
SmRemoveFromVocab
SmUndefineVocab
SmNaddToVocabCallback
SmNdefineVocabCallback
SmNdisableVocabCallback
SmNenableVocabCallback
SmNqueryAddedWordsCallback
SmNqueryEnabledVocabsCallback
SmNqueryVocabsCallback
SmNqueryWordsCallback
SmNremoveFromVocabCallback
SmNundefineVocabCallback
SmNdefineVocabExCallback


Access Functions:

SmGetVocabName (Returns the name of the defined vocabulary.)
SmGetVocWords (Returns array of SPCH_VOCWORDs not successfully defined.)
SmGetVocabPath (Returns the name of file from input data argument.)
SmGetOptions (Returns options specified in input argument.)


Remarks:

Calling SmDefineVocabEx with options SM_VOCAB_VOCWORDS and
SM_VOCAB_COMMAND set is equivalent to calling SmDefineVocab. Calling
SmDefineVocabEx with options SM_VOCAB_FILE and SM_VOCAB_FSG set is equivalent to
calling SmDefineGrammar. Calling SmDefineVocabEx with options SM_VOCAB_WORDS and
SM_VOCAB_PHRASE set is equivalent to calling SmDefineGrammar with
SM_PHRASE_LITERAL set.

Only a few combinations of format and type option flags are currently supported:

SM_VOCAB_VOCWORDS + SM_VOCAB_COMMAND
SM_VOCAB_VOCWORDS + SM_VOCAB_TEXT
SM_VOCAB_FILE + SM_VOCAB_FSB
SM_VOCAB_WORDS + SM_VOCAB_PHRASE


The following options have not yet been implemented:

SM_VOCAB_REPLACE, SM_VOCAB_SELECT, SM_VOCAB_VERBFINAL


IBM ViaVoice SDK for Windows


SmDetachSessions

SmDetachSessions

Purpose

SmDetachSessions requests that one or more sessions detach.

This function requests all applications connected to the speech recognition engine to disconnect
from it. SmQuerySessions can be used to monitor the number of attached applications. The
disconnect request is in the form of the SM_REQUEST_DETACH reply message structure. The
engine does not force a session to disconnect and does not wait for a reply to the disconnect
request. This function can be used for switching users (or user ID, enroll ID, task).

Syntax

int SmDetachSessions (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is
made asynchronously.

Return Values

SM_RC_OK


Reply Structure Functions by Message Type

SM_DETACH_SESSIONS_REPLY
SmGetRc


Task Related Functions and Callbacks

SmQuerySessions
SmNdetachRequestedCallback
SmNdetachSessionsCallback
SmNquerySessionsCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmDisableVocab

Purpose

SmDisableVocab disables a defined vocabulary.

This function disables a vocabulary so it is no longer used by the speech recognition engine to
decode speech to text during a recognition session. Only the specified vocabulary is disabled. Any
other enabled vocabularies remain active.

This function is valid only when the speech recognition engine is not decoding speech to text. For
examples of conditions when the engine is not decoding speech to text, see "Setting Up
Vocabularies" in the SMAPI Developer's Guide.

Syntax

int SmDisableVocab (char *vocab, SM_MSG *reply);


Parameters

vocab


input - The name of the vocabulary to be disabled.

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


IBM ViaVoice SDK for Windows


SmDisableVocab

For synchronous call and callbacks:

SM_RC_BAD_VOCAB
SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_DISABLE_VOCAB_REPLY


SmGetRc


SmGetVocabName


Task Related Functions and Callbacks

SmAddToVocab
SmDefineVocab
SmEnableVocab
SmQueryAddedWords
SmQueryEnabledVocabs
SmQueryVocabs
SmQueryWord
SmRemoveFromVocab
SmUndefineVocab
SmNaddToVocabCallback
SmNdefineVocabCallback
SmNdisableVocabCallback
SmNenableVocabCallback
SmNqueryAddedWordsCallback
SmNqueryEnabledVocabsCallback
SmNqueryVocabsCallback
SmNqueryWordsCallback
SmNremoveFromVocabCallback
SmNundefineVocabCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmDiscardData

Purpose

SmDiscardData discards audio and error-correction data.

This function discards audio data and error-correction information for recognized words that are
not referenced again, thus conserving speech recognition engine disk space (reference
“SmDisconnect” on page 74 for the SmNdiscardSessionData speech attribute used).

SmDiscardData works on the granularity of utterances (between SmMicOn and SmMicOff) and
discards utterance files owned by the application. Ownership is established by the application that
turned the microphone on to create the utterance. An application can guarantee ownership of its
data by toggling the microphone Off and On when it receives focus.

Syntax

int SmDiscardData (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


IBM ViaVoice SDK for Windows


SmDiscardData

Reply Structure Functions by Message Type

SM_DISCARD_DATA_REPLY
SmGetRc


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmDiscardSpeechData

Purpose

SmDiscardSpeechData will be called by a client application to specify audio data that can be
deleted.

Syntax

int SmDiscardSpeechData (unsigned long flags, short ntags, long stags[],
long etags[], SM_MSG *reply);


Parameters

flags


Reserved.

ntags


Specifies number of tags in tag arrays

stags


Array of starting tags

etags


Array of ending tags

reply


SmAsynchronous or pointer to reply structure.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK


IBM ViaVoice SDK for Windows


SmDiscardSpeechData

SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_DISCARD_SPEECH_DATA_REPLY
SmGetStatus


Task Related Functions and Callbacks

SmQuerySpeechData
SmRestoreSpeechData
SmSaveSpeechData
SmNdiscardSpeechDataCallback
SmNquerySpeechDataCallback
SmNrestoreSpeechDataCallback
SmNsaveSpeechDataCallback


Access Functions:

SmGetFlags (Returns flags)
SmGetStatus (Returns status)


Remarks:

When this function is called, the engine will mark off sections .tag files associated with start/end tag
pairs. If an entire utterance is marked, the files associated with that utterance will be deleted. When
the speech data is saved (SmSaveSpeechData) those sections of remaining .wav files associated
with the tags marked as discarded will not be saved. Any tags marked as discarded will no longer be
usable.

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmDisconnect

Purpose

SmDisconnect disconnects from the speech recognition engine. This function closes the
communication connection with the speech recognition engine.


Any asynchronous engine messages left in the application message queue after the
SmDisconnect() call returns are no longer valid and should not be used in any further SMAPI calls.

If the application needs to reconnect to the engine after a call to SmDisconnect(), then any engine
messages remaining in the application message queue for the previously connected session must
be removed before calling SmConnect().

Syntax

int SmDisconnect (int nargs, SmArg *Args, SM_MSG *reply);


Parameters

nargs


input - The number of arguments in the accompanying argument list.

Args


input - A set of arguments that indicate default parameters for disconnecting from the speech
recognition engine. Different attributes can be specified depending on the type of session and the
disposition of current data. Arguments include:

In recognition sessions:

SmNdiscardSessionAdaptation


Reset the user's voice model to the state it was in before the decoding session.

SmNdiscardSessionData


Delete any data for this session.

SmNsaveSessionData


Keep the session data until the user re-initializes. (Default)

SmNsaveSessionAdaptation


Keep words added to the word-usage model during this session. (Default)

IBM ViaVoice SDK for Windows


SmDisconnect

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK


For synchronous call and callbacks:

SM_RC_BAD_ENROLLID
SM_BAD_SCRIPT
SM_RC_BAD_VALUE
SM_RC_ENROLLID_EXISTS
SM_RC_ENROLLID_RUNNING
SM_RC_NO_SPACE_TERM_ENROLL
SM_RC_NOT_VALID_REQUEST
SM_RC_SERVER_ERROR


Reply Structure Functions by Message Type

SM_DISCONNECT_REPLY


SmGetMsgType


SmGetRc


SmGetService


Task Related Functions and Callbacks

SmClose
SmNdisconnectCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmDispatch

Purpose

SmDispatch receives one message and dispatches the callbacks.

This function provides the method through which callback functions are executed by Windows
applications. More specifically, this function receives one message from the speech recognition
engine and dispatches the appropriate callback routines, which were previously registered using
SmAddCallback, for the default connection.

Syntax

int SmDispatch (unsigned long ap_val);


Parameters

ap_val


input - Windows applications need to specify lParam here for ap_val.

Return Values

SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_EINVAL
SM_RC_EMSGSIZE
SM_RC_ENOCONN
SM_RC_ENOHANDLES
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_ETIMEOUT
SM_RC_EUNEXP
SM_RC_EUNKMSG
SM_RC_NOT_OPEN
SM_RC_OK


Task Related Functions and Callbacks

SmAddCallback
SmRemoveCallback


IBM ViaVoice SDK for Windows


SmEnableVocab

SmEnableVocab

Purpose

SmEnableVocab enables a defined vocabulary.

This function enables a vocabulary to be used by the speech recognition engine to decode speech
to text during a recognition session. Currently enabled vocabularies are not disabled by this
function but remain enabled along with the newly enabled vocabulary. If currently enabled
vocabularies are to be disabled first, then an SmDisableVocab call must be made beforehand for
each vocabulary to be disabled.

This call is valid only when the speech recognition engine is not decoding speech to text.

Syntax

int SmEnableVocab (char *vocab, SM_MSG *reply);


Parameters

vocab


input - The name of the vocabulary to be enabled.

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

For synchronous call and callbacks:

SM_RC_BAD_VOCAB
SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_ENABLE_VOCAB_REPLY


SmGetRc


SmGetVocabName


Task Related Functions and Callbacks

SmAddToVocab
SmDefineVocab
SmDisableVocab
SmQueryAddedWords
SmQueryEnabledVocabs
SmQueryVocabs
SmQueryWord
SmRemoveFromVocab
SmUndefineVocab
SmNaddToVocabCallback
SmNdefineVocabCallback
SmNdisableVocabCallback
SmNenableVocabCallback
SmNqueryAddedWordsCallback
SmNqueryEnabledVocabsCallback
SmNqueryVocabsCallback
SmNqueryWordsCallback
SmNremoveFromVocabCallback
SmNundefineVocabCallback


IBM ViaVoice SDK for Windows


SmEventNotify

SmEventNotify

Purpose

SmEventNotify requests notification when the speech recognition engine completes decoding all
the audio dictated up to the time SmEventNotify was called.

This function causes the callback associated with the SmNeventSynchCallback to be called as
soon as decoding is completed for all the words dictated up to the time SmEventNotify was called.

If a callback is not used, the application is notified with the reply message structure
SM_EVENT_SYNCH sent by the speech recognition engine.


Syntax

int SmEventNotify (long event_id, long options, SM_MSG *reply);


Parameters

event_id


input - The event ID.

options


input - The options for the event, which can be logically OR'ed:

.
SM_EVENT_HALT_RECOGNITION - halt and switch to command recognition when event
is encountered (Default)
.
SM_EVENT_CONTINUE_RECOGNITION - notify application that event was encountered
and continue with recognition
.
SM_EVENT_FIRM_UP - process audio following event
.
SM_EVENT_DISCARD - discard audio following event (Default)
Notes:

SM_EVENT_HALT_RECOGNITION and SM_EVENT_CONTINUE_RECOGNITION cannot
be specified together.

SM_EVENT_FIRM_UP and SM_EVENT_DISCARD cannot be specified together.

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is
made asynchronously.

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_EVENT_NOTIFY_REPLY
SmGetEventId
SmGetRc


SM_EVENT_SYNCH
SmGetEventId
SmGetEventOptions
SmGetRc


Task Related Functions and Callbacks

SmNeventNotifyCallback
SmNeventSynchCallback


IBM ViaVoice SDK for Windows


SmHaltRecognizer

SmHaltRecognizer

Purpose

SmHaltRecognizer temporarily halts recognition.

This function can be called when the speech recognition engine is decoding speech to text. Halting
recognition may be necessary, for example, to define and/or enable vocabularies to be used by the
engine during recognition. Recognition can be restarted with SmRecognizeNextWord.

Syntax

int SmHaltRecognizer (SM_MSG *reply);


Parameters

reply


input/output -The pointer to the reply structure or to the SmAsynchronous value.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST
SM_RC_SERVER_ERROR


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_HALT_RECOGNIZER_REPLY
SmGetNumberWordMsgs
SmGetRc


Task Related Functions and Callbacks

SmMicOff
SmMicOn
SmQuery
SmRecognizeNextWord
SmSet
SmNhaltRecognizerCallback
SmNmicOffCallback
SmNmicOnCallback
SmNqueryCallback
SmNrecognizeNextWordCallback
SmNrecognizedTextCallback
SmNrecognizedWordCallback
SmNsetCallback
SmNutteranceCompletedCallback


IBM ViaVoice SDK for Windows


SmMicOff

SmMicOff

Purpose

SmMicOff turns off the microphone.

This function turns off the microphone; however, in a recognition session, after the microphone is
turned off, the speech recognition engine continues speech to text decoding of words already
spoken. Depending on the speed and what is said before the microphone is turned off, this process
can take several seconds to complete.

Syntax

int SmMicOff (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK


For synchronous call and callbacks:

SM_RC_MIC_ALREADY_OFF
SM_RC_MIC_OFF_PENDING
SM_RC_NOT_VALID_REQUEST


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_MIC_OFF_REPLY
SmGetRc


Task Related Functions and Callbacks

SmHaltRecognizer
SmMicOn
SmQuery
SmRecognizeNextWord
SmSet
SmNhaltRecognizerCallback
SmNmicOffCallback
SmNmicOnCallback
SmNqueryCallback
SmNrecognizeNextWordCallback
SmNrecognizedTextCallback
SmNrecognizedWordCallback
SmNsetCallback
SmNutteranceCompletedCallback


IBM ViaVoice SDK for Windows


SmMicOn

SmMicOn

Purpose

SmMicOn turns on the microphone.

In a recognition session, this function turns on the microphone and starts the audio stream. The

application must issue an SmRecognizedNextWord to start the engine decoding.

Syntax

int SmMicOn (SM_MSG *reply);


Parameters

reply


input/output -The pointer to the reply structure or to the SmAsynchronous value.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_BAD_AP
SM_RC_BAD_DECO
SM_RC_BUSY_LAST_UTTERANCE
SM_RC_BUSY_WORD_CORRECTION
SM_RC_ENROLLMENT_NOT_COMPLETE
SM_RC_MIC_ALREADY_ON


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SM_RC_MIC_OFF_PENDING
SM_RC_MIC_ON_PENDING
SM_RC_NO_SPACE_MIC_ON
SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_MIC_ON_REPLY
SmGetRc
SmGetUtteranceNumber


During a recognition session:

SM_RECOGNIZED_TEXT
SmGetFirmWords
SmGetInfirmWords
SmGetRc
SmGetTimes


Task Related Functions and Callbacks

SmHaltRecognizer
SmMicOff
SmQuery
SmRecognizeNextWord
SmSet
SmNhaltRecognizerCallback
SmNmicOffCallback
SmNmicOnCallback
SmNqueryCallback
SmNrecognizeNextWordCallback
SmNrecognizedTextCallback
SmNrecognizedWordCallback
SmNsetCallback
SmNutteranceCompletedCallback


IBM ViaVoice SDK for Windows


SmNewContext

SmNewContext

Purpose

SmNewContext sends a new text context.

This function allows a change in text context sent to the speech recognition engine. This function
is usually called when text dictation begins at a new location in a document and can only be called
when the speech recognition engine is halted. Context refers to previous and following words,
which are used to decode the current word in a recognition session.

Syntax

int SmNewContext (short nwords, SM_WORD *words[], SM_MSG *reply);


Parameters

nwords


input - The number of words of context sent. Zero means no left context.

words


input - An array of pointers to the context words, ordered from left to right in the text.

reply


input/output -The pointer to the reply structure or to the SmAsynchronous value indicating that
the call is made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_NEW_CONTEXT_REPLY
SmGetRc


Task Related Functions and Callbacks

SmCorrectText
SmCorrectTextCancel
SmRemovePronunciation
SmWordCorrection
SmNcorrectTextCallback
SmNcorrectTextCancelCallback
SmNnewContextCallback
SmNremovePronunciationCallback
SmNwordCorrectionCallback


IBM ViaVoice SDK for Windows


SmOpen

SmOpen

Purpose
SmOpen opens the SMAPI.
This function establishes a SMAPI connection and initializes values in a connection structure.

Syntax

int SmOpen (int nargs, SmArg *Args);


Parameters

nargs


input - The number of arguments in the accompanying argument list.

Args


input - A set of arguments that indicate default parameters for the SMAPI connection. They are
stored in a connection structure for the speech-aware application. The values in the structure are
used to set up the session with the speech recognition engine. SMAPI attributes can also be set by
using the SmSetArg function, which specifies the attribute name and its value.

For details on establishing a speech session, see the SMAPI Developer's Guide. For details on the
attributes, reference “SMAPI Attributes” on page 305.

Return Values

SM_RC_EALLOC
SM_RC_ENOMEM
SM_RC_NAVIGATOR_ALREADY_DEFINED
SM_RC_OK
SM_RC_ALREADY_CONNECTED
SM_RC_ALREADY_OPENED


For synchronous call and callbacks:

SM_RC_OPEN_SYNCH_QUEUE_FAILED
SM_RC_NOT_VALID_REQUEST


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Task Related Functions and Callbacks

SmConnect
SmSetArg
SmNconnectCallback


IBM ViaVoice SDK for Windows


SmPlayMessage

SmPlayMessage

Purpose

SmPlayMessage plays back a prerecorded audio file.

This function allows the user to play a prerecorded audio file. After the speech-aware application
requests a playback, it can call SmGetStatus to retrieve the last playback status, which can be one
of the following:

SM_STAT_BAD_AUDIO


The connection to the audio source was lost during playback.

SM_STAT_PLAY_START


The message has started playing.

SM_STAT_PLAY_STOP


The message has stopped playing.
Possible return values passed to the SmNplayMessageStatusCallback are:


.
SM_RC_OK
.
SM_RC_BAD_AUDIO
.
SM_RC_PLAY_OPEN_ERROR
The following restrictions apply when calling SmPlayMessage:

.
Microphone must be off.
.
Speech recognition engine must not be decoding speech to text. In other words, the application
must have received SM_UTTERANCE_COMPLETED from the engine.
Syntax

int SmPlayMessage (char *message_name, char *language, SM_MSG *reply);


Parameters

message_name


input - The fully qualified name of an audio file in IBM ViaVoice format, which is 8-bit (mono) u-
Law PCM at 11.025kHz, 8.0kHz or 22.05kHz. These audio files can be created by dictating the
message and saving to a file in the IBM ViaVoice user path.

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

language


input -The name of the language played.

reply


input/output -The pointer to the reply structure or to the SmAsynchronous value indicating that
the call is made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_BAD_LANGUAGE
SM_RC_BAD_MESSAGE
SM_RC_NOT_VALID_REQUEST
SM_RC_NOT_WHILE_MIC_ON


Reply Structure Functions by Message Type

SM_PLAY_MESSAGE_REPLY


SmGetRc
SM_PLAY_MESSAGE_STATUS


SmGetMsgName


SmGetRc


SmGetStatus


IBM ViaVoice SDK for Windows


SmPlayMessage

Task Related Functions and Callbacks

SmCancelPlayback
SmPlayUtterance
SmPlayWords
SmNcancelPlaybackCallback
SmNplayMessageCallback
SmNplayMessageStatusCallback
SmNplayUtteranceCallback
SmNplayUtteranceStatusCallback
SmNplayWordsCallback
SmNplayWordsStatusCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmPlayUtterance

Purpose

SmPlayUtterance plays back a spoken utterance.

This function allows an utterance or a portion of an utterance previously spoken during dictation or
enrollment to be played back to the user as an error-correction aid. For a monitored enrollment
session, an utterance corresponds to a sentence of an enrollment script and, for a recognition
session, it corresponds to any word spoken between SmMicOn and subsequent SmMicOff.

After the speech-aware application requests a playback it can call SmGetStatus to retrieve the last
playback status, which can be one of the following:

SM_STAT_BAD_AUDIO


The connection to the audio source was lost during playback.

SM_STAT_PLAY_START


The utterance has started playing.

SM_STAT_PLAY_STOP


The utterance has stopped playing.
Possible return values passed to the SmNplayUtteranceStatusCallback are:


.
SM_RC_OK
.
SM_RC_BAD_AUDIO
.
SM_RC_PLAY_OPEN_ERROR
The following restrictions apply when calling SmPlayUtterance:

.
Microphone must be off.
.
Speech recognition engine must not be decoding speech to text. In other words, the application
must have received SM_UTTERANCE_COMPLETED from the engine.
Note:

For this call to be valid, the application must first enable audio saving through

SmSet(SM_SAVE_AUDIO, TRUE).

IBM ViaVoice SDK for Windows


SmPlayUtterance

Syntax

int SmPlayUtterance(long uttno, long begtime, long endtime, SM_MSG *reply);


Parameters

uttno


input -The utterance number to play back. The current utterance number can be extracted from

SM_MIC_ON_REPLY with SmGetUtteranceNumber.

begtime


input - Reserved. Must be set to 0.

endtime


input - Reserved. Must be set to 0.

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is

made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST
SM_RC_NOT_WHILE_MIC_ON


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_PLAY_UTTERANCE_REPLY
SmGetRc


SM_PLAY_UTTERANCE_STATUS

SmGetRc


SmGetStatus


SmGetUtteranceNumber


Task Related Functions and Callbacks

SmCancelPlayback
SmPlayMessage
SmPlayWords
SmNcancelPlaybackCallback
SmNplayMessageCallback
SmNplayMessageStatusCallback
SmNplayUtteranceCallback
SmNplayUtteranceStatusCallback
SmNplayWordsCallback
SmNplayWordsStatusCallback


IBM ViaVoice SDK for Windows


SmPlayWords

SmPlayWords

Purpose

SmPlayWords plays back spoken words.

This function allows a previously spoken word or collection of words to be played back to the user
as an error correction aid.

The SmPlayWords call generates one or more SM_PLAY_WORDS_STATUS messages. When
this message is received, the application can call SmGetStatus to retrieve the status of the last
playback, which can be one of the following:

SM_STAT_BAD_AUDIO


The connection to the audio source was lost during playback.

SM_STAT_BAD_TAG


An invalid word (tag) was specified for the played word.

SM_STAT_PLAY_START


The word has started playing.

SM_STAT_PLAY_STOP


The word has stopped playing.
Possible return values passed to the SmNplayWordsStatusCallback are:


.
SM_RC_OK
.
SM_RC_BAD_TAG
.
SM_RC_PLAY_OPEN_ERROR
The following restrictions apply when calling SmPlayWords:

.
Microphone must be off.
.
Speech recognition engine must not be decoding speech to text. In other words, the application
must have received SM_UTTERANCE_COMPLETED from the engine.
Note:

For this call to be valid, the application must first enable audio saving through

SmSet(SM_SAVE_AUDIO, TRUE).

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Syntax

int SmPlayWords (short ntags, long tags[], long options, SM_MSG *reply);


Parameters

ntags


input - The number of words (tags) to play back.

tags


input - The array of word tags.

options


input - One of the following:

SM_PLAY_WORDS_CONTIGUOUS


When playing multiple words, return a single SM_PLAY_WORDS_STATUS message at the
beginning (SM_STAT_PLAY_START) of each word played, and return a single message
(SM_STAT_PLAY_STOP) after all words have been played. This is the default.

SM_PLAY_WORDS_SAVE_WAVEFILE


Instead of sending audio to the output device, this flag saves the audio data as a wave(WAV)
file. The name of the wave file must be set via an SmSetDirectory call prior to calling the
SmPlayWords function. If the SM_PLAY_WORDS_WITH _SILENCE flag is also set, then
the entire utterance(s) corresponding to the input tag array will be written to the wave file.

SM_PLAY_WORDS_SEPARATE


When playing multiple words, return separate SM_PLAY_WORDS_STATUS messages at the
beginning (SM_STAT_PLAY_START) of each word played and a single message
(SM_STAT_PLAY_STOP) when the entire list of tags has been played. If playback is
canceled, the SM_STAT_PLAY_STOP is also sent to indicate completion of the interrupted
playback request.

SM_PLAY_WORDS_WITH_SILENCE


When playing multiple words, playback the silence between words. The default is to play only
the non-silence portion of recognized words.

reply


input/output -The pointer to a reply structure or to SmAsynchronous, indicating that the call is
made asynchronously.

IBM ViaVoice SDK for Windows


SmPlayWords

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_BAD_TAG
SM_RC_NOT_VALID_REQUEST
SM_RC_NOT_WHILE_MIC_ON


Reply Structure Functions by Message Type

SM_PLAY_WORDS_REPLY

SmGetRc


SM_PLAY_WORDS_STATUS


SmGetRc


SmGetStatus


SmGetTags


Task Related Functions and Callbacks

SmCancelPlayback
SmPlayMessage
SmPlayUtterance
SmQueryWord
SmWordCorrection
SmNcancelPlaybackCallback
SmNplayMessageCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmNplayMessageStatusCallback
SmNplayUtteranceCallback
SmNplayUtteranceStatusCallback
SmNplayWordsCallback
SmNplayWordsStatusCallback
SmNqueryAddedWordsCallback


IBM ViaVoice SDK for Windows


SmQuery

SmQuery

Purpose
SmQuery queries a speech recognition engine parameter.
This function queries the value of the specified speech recognition engine parameter. Call the

SmGetItemValue function to extract the queried value.

Syntax

int SmQuery (short item, SM_MSG *reply);


Parameters

item


input - The parameter queried, which can be one of the following:

SM_API_DEBUG


Values include the following: 0 is debugging off, 1 to 5 provide progressively more debug
information. A value of 1 or 2 provides flow of control information.

SM_API_DISPLAY


Reserved

SM_API_LOG


Reserved

SM_API_TIMING


Reserved

SM_AUDIO_CONFIGURATION


(Not applicable to Windows. Instead use Audio Setup program.)
Query the input source of the audio hardware where audio data is collected. The returned value
is bit mapped and can be any combination of the following values:


. SM_AUDIO_INPUT_MIC_HI_GAIN
. SM_AUDIO_INPUT_MIC_LO_GAIN
. SM_AUDIO_INPUT_LINE_LEFT
. SM_AUDIO_INPUT_LINE_RIGHT
. SM_AUDIO_INPUT_VARIABLE_GAIN
IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

. SM_AUDIO_OUTPUT_LINE_LEFT
. SM_AUDIO_OUTPUT_LINE_RIGHT
. SM_AUDIO_OUTPUT_INTERNAL_SPEAKER
. SM_AUDIO_OUTPUT_VARIABLE_GAIN
Refer to the SMLIMITS.H file for bounds on input and output values.

SM_AUDIO_DEVICE


Query the type of audio hardware. Return values include the following:

. SM_ACPA_AUDIO - Reserved
. SM_PERSONAL_DICTATION_AUDIO
. SM_SYSTEM_AUDIO -native audio system for hardware/operating systems.
SM_AUDIO_INPUT_MODE


(Not applicable to Windows. Instead use Audio Setup program.)
Query the input source of the audio hardware where audio data is collected. We suggest you
use the supplied AUDIO.DLL instead. The returned value is bit mapped and can be any one of
the following values:


. SM_AUDIO_INPUT_LINE_LEFT
. SM_AUDIO_INPUT_LINE_RIGHT
. SM_AUDIO_INPUT_MIC_HI_GAIN
. SM_AUDIO_INPUT_MIC_LO_GAIN
SM_AUDIO_INPUT_GAIN


(Not applicable to Windows. Instead use Audio Setup program.)
If supported by underlying audio, this parameter allows you to query current gain setting.


SM_AUDIO_OUTPUT_GAIN


(Not applicable to Windows. Instead use Audio Setup program.)
If supported by underlying audio, this parameter allows you to query current gain setting.


IBM ViaVoice SDK for Windows


SmQuery

SM_AUDIO_OUTPUT_MODE


(Not applicable to Windows. Instead use Audio Setup program.)
If supported by underlying audio, this bit value indicates the current output destination. We
suggest you use the supplied audio.dll instead. The returned value can be any one of the
following values:


. SM_AUDIO_OUTPUT_LINE_LEFT
. SM_AUDIO_OUTPUT_LINE_RIGHT
. SM_AUDIO_OUTPUT_LINE_INTERNAL_SPEAKER
SM_COMPLETE_COMMAND_TIMEOUT


These timeout parameters are used to control the behavior of finite state grammars. In
particular, they specify how much silence is needed at the end of commands before the engine
will make a recognition decision to accept or reject the command. The amount of silence
required to accept or reject a phrase that is unambiguously complete. Default value is 25
(csecs). Can be overridden by task dependent .par values.

SM_ENABLE_EXCLUSIVE_VOCABS


Query the calling application's vocabularies. The value is either TRUE (1) for enabled, or
FALSE (0) for disabled.

SM_ENGINE_DEBUG


Reserved.

SM_ENGINE_DISPLAY


Reserved.

SM_REJECTION_THRESHOLD


Returns value from SM_MIN_REJECTION_THRESHOLD to
SM_MAX_REJECTION_THRESHOLD (reference “SmSet” on page 167 for a detailed
description of the SM_REJECTION_THRESHOLD parameter).

SM_ENGINE_LOG


Reserved.

SM_NOTIFY_AUDIO_LEVEL


Query the returning of audio-level data during recognition or enrollment. The value is either
TRUE (1) or FALSE (0).

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SM_NOTIFY_COMMAND_WORD


Query whether the application is notified when a command word is recognized by having the
engine send a SM_COMMAND_WORD reply message. The value is either TRUE (1) or
FALSE (0).

SM_NOTIFY_ENGINE_STATE


Query whether the application is notified of a speech recognition engine state change. The
value is either TRUE (1) or FALSE (0).

SM_NOTIFY_FOCUS_STATE


Query whether the application is notified of a speech focus state change. The value is either
TRUE (1) or FALSE (0).

SM_NOTIFY_MIC_STATE


Query whether the application is notified of a microphone state change. The value is either
TRUE (1) or FALSE (0).

SM_PARTIAL_COMMAND_TIMEOUT


These timeout parameters are used to control the behavior of finite state grammars. In
particular, they specify how much silence is needed at the end of commands before the engine
will make a recognition decision to accept or reject the command. The amount of silence
required to accept or reject a phrase that is both partially complete and complete. Default value
is 250 (csecs). It can be overridden by task dependent .par value.

For example, consider the grammar:
command = move up 3 move up five


 Now consider the following acoustic scenarios:
1.MOVE


2.MOVE UP

3.MOVE UP FIVE

1.The engine will accept silences up to 0.5 seconds, waiting for the UP, before rejecting

the phrase as incomplete.

2.The engine will accept silences up to 0.5 seconds, waiting for the optional FIVE, before
accepting the phrase MOVE UP.

3.Then engine will wait only 0.1 seconds after the FIVE to accept the phrase.

For the example given, it seems that you would like to increase the
SM_PARTIAL_COMMAND_TIMEOUT in order to allow longer pauses within phrases.

IBM ViaVoice SDK for Windows


SmQuery

Note that increasing this parameter will also increase the decision time for "ambiguously
complete" phrases.

SM_REDUCED_CPU_MODE


Query the CPU mode of the speech recognition engine. The value is either TRUE (1) for
reduced CPU mode, or FALSE (0) for normal CPU mode. See “SmGetEngineState” on
page 205.

SM_SAVE_AUDIO


Query whether recorded audio is being saved during recognition. The value is either TRUE (1)
or FALSE (0).

SM_ENGINE_TIMING


Reserved.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_BAD_MODE
SM_RC_NOT_YET
SM_RC_EXISTS_IN_NOTIFY
SM_RC_NOT_IN_NOTIFY


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_QUERY_REPLY
SmGetItemValue
SmGetRc


Task Related Functions and Callbacks

SmHaltRecognizer
SmMicOff
SmMicOn
SmRecognizeNextWord
SmSet
SmNhaltRecognizerCallback
SmNmicOffCallback
SmNmicOnCallback
SmNqueryCallback
SmNrecognizeNextWordCallback
SmNrecognizedTextCallback
SmNrecognizedWordCallback
SmNsetCallback
SmNutteranceCompletedCallback


IBM ViaVoice SDK for Windows


SmQueryAddedWords

SmQueryAddedWords

Purpose

SmQueryAddedWords queries added words.

This function requests a list of all words that have been added to vocabularies of the currently

active session.

Syntax

int SmQueryAddedWords (char *vocab, SM_MSG *reply);


Parameters

vocab


input - The name of the vocabulary to query.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_BAD_VOCAB
SM_RC_NOT_VALID_REQUEST


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_QUERY_ADDED_WORDS_REPLY


SmGetRc


SmGetWords


Task Related Functions and Callbacks

SmAddToVocab
SmDefineVocab
SmDisableVocab
SmEnableVocab
SmNaddToVocabCallback
SmNdefineVocabCallback
SmNdisableVocabCallback
SmNenableVocabCallback
SmNplayWordsCallback
SmNplayWordsStatusCallback
SmNqueryAddedWordsCallback
SmNqueryEnabledVocabsCallback
SmNqueryVocabsCallback
SmNqueryWordsCallback
SmNremoveFromVocabCallback
SmNundefineVocabCallback
SmNwordCorrectionCallback
SmPlayWords
SmQueryAddedWords
SmQueryEnabledVocabs
SmQueryVocabs
SmQueryWord
SmRemoveFromVocab
SmUndefineVocab
SmWordCorrection


IBM ViaVoice SDK for Windows


SmQueryAddedWordsEx

SmQueryAddedWordsEx

Purpose

SmQueryAddedWordsEx extends SmQueryAddedWords. This new function accepts an
argument which specifies a starting point. It will return words beginning from this starting point up
to the limit SM_MAX_WORDS (500). If the specified starting point is greater than the number of
added words, no words will be returned.

Syntax

int SmQueryAddedWordsEx (unsigned long flags, unsigned long start,
char *vocab, SM_MSG *reply);


Parameters

flags


Reserved.

start


Specifies O-origin starting place.

vocab


Specifies the name of the vocabulary to query.

reply


SmAsynchronous or the pointer to a reply structure.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST
SM_RC_BAD_VOCAB


Reply Structure Functions by Message Type

SM_QUERY_ADDED_WORDS_REPLY
SmGetWords


Task Related Functions and Callbacks

SmAddToVocab
SmDefineVocab
SmDisableVocab
SmEnableVocab
SmNaddToVocabCallback
SmNdefineVocabCallback
SmNdisableVocabCallback
SmNenableVocabCallback
SmNplayWordsCallback
SmNplayWordsStatusCallback
SmNqueryAddedWordsCallback
SmNqueryAddedWordsExCallback
SmNqueryEnabledVocabsCallback
SmNqueryVocabsCallback
SmNqueryWordsCallback
SmNremoveFromVocabCallback
SmNundefineVocabCallback
SmNwordCorrectionCallback
SmPlayWords
SmQueryAddedWords
SmQueryEnabledVocabs
SmQueryVocabs
SmQueryWord
SmRemoveFromVocab
SmUndefineVocab
SmWordCorrection


IBM ViaVoice SDK for Windows


SmQueryAddedWordsEx

Access Functions:

SmGetWords


Remarks:

Calling SmQueryAddedWords is equivalent to calling SmQueryAddedWordsEx with a start
argument of 0.

If there are more added words than the limit SM_MAX_WORDS, this function may be called
repeatedly, specifying a start argument of 0 the first time and incrementing the start argument by
the number of words returned. When 0 words are returned, all added words have been retrieved.

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmQueryAlternates

Purpose

SmQueryAlternates requests a list of alternative words.

This function requests a list of alternative choices for a firm word or a group of firm words that has
been incorrectly recognized. Errors are usually one-for-one substitutions, in which case only one
word needs to be specified on the call to SmGetAlternates. A word may, however, be recognized
incorrectly as two or more words. In that case, two or more words might need to be specified in
order to get an alternative list containing the correct word.

The following restrictions apply when calling SmQueryAlternates:

.
Microphone must be off
.
Speech recognition engine must not be decoding speech to text. In other words, the application
must have received SM_UTTERANCE_COMPLETED from the engine.
.
SM_SAVE_AUDIO must be enabled with SmSet.
Note:

For this call to be valid, the application must first enable audio saving through

SmSet(SM_SAVE_AUDIO, TRUE).

Syntax

int SmQueryAlternates (short ntags, long tags[], SM_MSG *reply);


Parameters

ntags


input - The number of words (tags) for which alternatives are requested.

tags


input -The tags of the word for which alternatives are requested.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

IBM ViaVoice SDK for Windows


SmQueryAlternates

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_QUERY_ALTERNATES_REPLY


SmGetAlternates


SmGetRc


SmGetTags


Task Related Functions and Callbacks

SmNqueryAlternatesCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmQueryBinary

Purpose
SmQueryBinary queries the value of a specified speech recognition engine parameter.
This function is used instead of SmQuery to query values of arbitrary length and data type.

Syntax

int SmQueryBinary (short item, SM_MSG *reply);


Parameters

item


input - The parameter to be queried, which can be any of the following:

. SM_AUDIO_SOURCE -Specifies querying value in audio library.
. SM_MNR_VALUE -Specifies querying mnr value.
reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

If item is SM_AUDIO_SOURCE return values depend on audio library implementation of
AudioQuerySource.

If item is SM_MNR_VALUE return mnr value.

Reply Structure Functions by Message Type

SM_QUERY_BINARY_REPLY
SmGetRc
SmGetBinaryItemValue


Task Related Functions and Callbacks

SmSetBinary
SmNsetBinaryCallback


IBM ViaVoice SDK for Windows


SmQueryDefault

SmQueryDefault

Purpose

SmQueryDefault queries the default value for a user, enrollment, task ID speech attribute, or the
default topics.

Syntax

int SmQueryDefault (long item, SM_MSG *reply);


Parameters

item


input -Type of default ID speech attribute. Valid values include the following:

. SM_DEFAULT_USERID
. SM_DEFAULT_ENROLLID
. SM_DEFAULT_TASK
. SM_DEFAULT_TOPICS
reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_OK


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_QUERY_DEFAULT_REPLY
SmGetEnrollId
SmGetEnrollIds
SmGetRc
SmGetScripts
SmGetTask
SmGetTasks
SmGetUserId
SmGetUserIds
SmGetDefaultTopics


Task Related Functions and Callbacks

SmConnect
SmOpen
SmSetDefault
SmQueryUserDefault
SmSetUserDefault
SmNqueryDefaultCallback
SmNqueryUserDefaultCallback
SmNsetDefaultCallback
SmNsetUserDefaultCallback


Remarks:

The default enrollid, taskid, and topics are stored on a per-user basis. SmQueryDefault called
with an item value of SM_DEFAULT_USERID will return the value of the default userid. It can be
accessed in the reply structure using the function SmGetUserId or SmGetUserIds.
SmQueryDefault called with other item values will return default enrollid, taskid, or topics for the
default userid. The value of the default enrollid can be accessed in the reply structure using the
functions SmGetEnrollId or SmGetEnrollIds. The value of the default taskid can be accessed in
the reply structure using the functions SmGetTask or SmGetTasks. The value of the default topics
can be accessed in the reply structure using the function SmGetDefaultTopics. Since multiple
default topics can be associated with a userid the default topics will be returned concatenated in a
blank delimited string. To query the default enrollid, task or topics for a user other than the default
user, the function SmQueryUserDefault is provided.

IBM ViaVoice SDK for Windows


SmQueryEnabledVocabs

SmQueryEnabledVocabs

Purpose
SmQueryEnabledVocabs queries currently enabled vocabularies.
This function obtains a list of all currently enabled vocabularies.

Syntax

int SmQueryEnabledVocabs (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_QUERY_ENABLED_VOCABS_REPLY
SmGetRc
SmGetVocabList


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Task Related Functions and Callbacks

SmAddToVocab
SmDefineVocab
SmDisableVocab
SmEnableVocab
SmQueryAddedWords
SmQueryVocabs
SmQueryWord
SmRemoveFromVocab
SmUndefineVocab
SmNaddToVocabCallback
SmNdefineVocabCallback
SmNdisableVocabCallback
SmNenableVocabCallback
SmNqueryAddedWordsCallback
SmNqueryEnabledVocabsCallback
SmNqueryVocabsCallback
SmNqueryWordsCallback
SmNremoveFromVocabCallback
SmNundefineVocabCallback


IBM ViaVoice SDK for Windows


SmQueryEnrollIds

SmQueryEnrollIds

Purpose

SmQueryEnrollIds queries user enrollment IDs. This function returns a list of the enrollment IDs
previously generated for a user by an enrollment procedure. Each time a user enrolls for the
recognition system a new enrollment ID is generated for that user. When speech recognition is
performed, one of the enrollment IDs from the user's enrollment ID list must be specified for the
SmConnect function.

SmQueryEnrollIds returns the sample rate associated with each queried enrollid. The new access
function SmGetSampleRates is provided to access the array of sample rates.

Syntax

int SmQueryEnrollIds (char *user_id, char *enroll_id, char *language,
SM_MSG *reply);


Parameters

user_id


input -The name of the user whose enrollment ID list is to be returned.

enroll_id


input - The enrollment ID queried, or NULL if all enrollments are queried.

language


input -The language for the enrollment ID, or NULL if all languages are queried.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_BAD_ENROLLID
SM_RC_BAD_USERID
SM_RC_SERVER_MALLOC_ERROR


Reply Structure Functions by Message Type

SM_QUERY_ENROLLIDS_REPLY
SmGetAlphabets
SmGetDescriptions
SmGetEnrollIds
SmGetLanguages
SmGetPercentages
SmGetRc
SmGetSampleRates
SmGetScripts
SmGetStates


Task Related Functions and Callbacks

SmNrequestNewEnrollIdCallback


IBM ViaVoice SDK for Windows


SmQueryLanguages

SmQueryLanguages

Purpose

SmQueryLanguages queries the available languages.

This function returns a list of available languages that can be used to initialize the speech

recognition engine.

Syntax

int SmQueryLanguages (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_SERVER_MALLOC_ERROR


Reply Structure Functions by Message Type

SM_QUERY_LANGUAGES_REPLY


SmGetDescriptions


SmGetLanguages


SmGetRc


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Task Related Functions and Callbacks

SmNqueryLanguagesCallback


IBM ViaVoice SDK for Windows


SmQueryPhraseAlternatives

SmQueryPhraseAlternatives

Purpose

SmQueryPhraseAlternatives will be called by a client application to request the next recognition
phrase alternative for a grammar vocabulary.

Syntax

int SmQueryPharaseAlternatives (unsigned long flags, SM_MSG *reply);


Parameters

flags


Reserved.

reply


The pointer to a reply structure or to SmAsynchronous indicating that the call is made

asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_QUERY_PHRASE_ALTERNATIVES_REPLY
SmGetVocabName
SmGetFirmWords
SmGetAnnotations
SmGetWordTimes
SmGetFlags


Task Related Functions and Callbacks

SmNqueryPhraseAlternativesReply


Access Functions

SmGetFirmWords
SmGetFlags
SmGetVocabName
SmGetAnnotations
SmGetWordTimes


Remarks:

This function is called repeatedly to get recognition phrase alternatives. A new flag will be defined
for the flag field of the SM_QUERY_PHRASE_ALTERNATIVES_REPLY message. When this
flag is set, it indicates no more alternatives are available.

SM_PHRASE_NO_ALTERNATIVES_AVAILABLE

This flag can be accessed by calling the access function SmGetFlags against the
SM_QUERY_PHRASE_ALTERNATIVES_REPLY message. The maximum phrase alternatives
calculated is 10.

The Nbest feature will be activated by a parameter in the parameter file (.par).

DC - nbest

This parameter will specify the number of alternatives to be recognized by the engine. Valid values
are 1-10. Note that this is a global setting. If this parameter is set, the engine will calculate
alternatives for all clients connected to the engine.

IBM ViaVoice SDK for Windows


SmQueryPronunciation

SmQueryPronunciation

Purpose

SmQueryPronunciation queries the existence of a pronunciation.

This function provides a method for a requesting application to determine whether an associated
pronunciation exists for a given spelling. This query is applied to the pronunciations that have been
added to the user's personal pronunciation pool and the temporary pool. The query returns if it
found the pronunciation, but will not tell you where the pronunciations exist.

If a specified word does not exist in the current pool, the backup dictionary will be searched. If the
word is found in the backup dictionary, it will be added to the temporary pool, except that when
SmAddToVocab specifies a dictation vocabulary such as “text,” the word will be added to the
personal pool.

Syntax

int SmQueryPronunciation (char *spelling, SM_MSG *reply );


Parameters

spelling


input -A spelling for which a pronunciation is sought.

reply


input/output - A pointer to a reply structure or to SmAsynchronous indicating that the call is made
asynchronously.

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_NOT_INVOCAB
SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_QUERY_PRONUNCIATION_REPLY


SmGetRc


SmGetSpelling


SmGetSpellings


Task Related Functions and Callbacks

SmAddPronunciation
SmQueryPronunciations
SmRemovePronunciation
SmNaddPronunciationCallback
SmNqueryPronunciationCallback
SmNqueryPronunciationsCallback
SmNremovePronunciationCallback


IBM ViaVoice SDK for Windows


SmQueryPronunciations

SmQueryPronunciations

Purpose

SmQueryPronunciations queries a listing of added pronunciations.

This function provides a method for an application to request a list of word pronunciations for a

given spelling that have been added to the user's pronunciation pool within the buffer limits.

Syntax

int SmQueryPronunciations (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST
SM_RC_SERVER_ERROR
SM_RC_SERVER_FILE_OPEN_ERROR


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_QUERY_PRONUNCIATIONS_REPLY


SmGetPronunciations


SmGetRc


SmGetSpellings


Task Related Functions and Callbacks

SmAddPronunciation
SmQueryPronunciation
SmRemovePronunciation
SmNaddPronunciationCallback
SmNqueryPronunciationCallback
SmNqueryPronunciationsCallback
SmNremovePronunciationCallback


IBM ViaVoice SDK for Windows


SmQueryPronunciationsEx

SmQueryPronunciationsEx

Purpose

A new SMAPI function, SmQueryPronunciationsEx extends SmQueryPronunciations. This
function accepts an argument which specifies a starting point. It will return words beginning from
this starting point up to the limit SM_MAX_WORDS (500). If the specified starting point is
greater than the number of added words, no words will be returned.

Syntax

int SmQueryPronunciationsEx (unsigned long flags, unsigned long start,
SM_MSG *reply);


Parameters

flags


Reserved.

start


Specifies 0-origin starting place.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST
SM_RC_SERVER_MALLOC_ERROR


Reply Structure Functions by Message Type

SM_QUERY_PRONUNCIATIONS_REPLY
SmGetSpellings
SmGetPronunciations


Task Related Functions and Callbacks

SmAddPronunciation
SmQueryPronunciation
SmRemovePronunciation
SmNaddPronunciationCallback
SmNqueryPronunciationCallback
SmNqueryPronunciationsCallback
SmNqueryPronunciationsExCallback
SmNremovePronunciationCallback


Remarks:

Calling SmQueryPronuciations is equivalent to calling SmQueryPronunciationsEx with a start
argument of 0.

If there are more added pronunciations than the limit SM_MAX_WORDS, this function may be
called repeatedly, specifying a start argument of 0 the first time and incrementing the start
argument by the number of pronunciations returned. When 0 pronunciations are returned, all
pronunciations have been retrieved.

Access Functions:

SmGetSpellings
SmGetPronunciations


IBM ViaVoice SDK for Windows


SmQueryScripts

SmQueryScripts

Purpose:

SmQueryScripts returns information about available scripts. The scripts about which information
is returned can be filtered by userid/enrollid, or task.

Syntax:

int SmQueryScripts (char *user_id, char *enrollid, char *task,
SM_MSG *reply );


Parameters:

user_id


Required if enrollid specified. Specifies user identifier.

enrollid


Required if user_id specified. Specifies enrollment identifier.

task


Optional: if not NULL specifies task for which data on associated scripts will be returned.

reply


SmAsynchronous or pointer to reply structure.

Remarks:

The Enroll stanza of the .eid file contains a Language tag. So specifying a userid/enrollid specifies
a language. Each .scr file contains a language tag in the script stanza. If a userid/enrollid pair is
specified SmQueryScripts will gather information about those scripts whose language tag
matches the language tag in the .eid file.

Filtering by task will be deferred for this first implementation.

The value of the name tag in the script stanza of the script files will be used to create the array of
script names returned.

The value of the description tag in the script stanza of the script files will be used to create the
array of descriptions returned.

The value of the type tag in the script stanza of the script files will be used to set the isolated/
continuous flag in the array of flags returned.

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

The value of the sentences tag in the script stanza of the script files will be used to create the array
of sizes returned.

The value of the increment tag in the script stanza of the script files will be used to create the array
of increments returned.

Access Functions:

SmGetDescriptions (Returns array of descriptions)
SmGetIncrements (Returns array of increments)
SmGetScriptFlags (Returns array of flags)
SmGetScripts (Returns array of script names)
SmGetSizes (Returns array of sizes)
SmGetStates (Returns array of statuses)
SmGetTasks (Returns array of task names)
SmGetTrained (Returns array of trained)


IBM ViaVoice SDK for Windows


SmQuerySessions

SmQuerySessions

Purpose
SmQuerySessions queries sessions and returns a list of connected recognition sessions.

Syntax

int SmQuerySessions (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_OK


Reply Structure Functions by Message Type

SM_QUERY_SESSIONS_REPLY
SmGetApplications
SmGetEnrollIds
SmGetRc
SmGetTasks
SmGetUserIds


Task Related Functions and Callbacks

SmDetachSessions
SmNdetachSessionsCallback
SmNquerySessionsCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmQuerySpeechData

Purpose
SmQuerySpeechData queries the estimated size of speech data for the current session.

Syntax

int SmQuerySpeechData (SM_MSG *reply);


Parameters

reply

input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is

made asynchronously.

Return Values

SM_RC_OK


Reply Structure Functions by Message Type

SM_QUERY_SPEECH_DATA_REPLY
SmGetSpeechDataSize


IBM ViaVoice SDK for Windows


SmQueryTasks

SmQueryTasks

Purpose

SmQueryTasks queries a speech recognition engine domain list.

This function returns a list of the domains that can be used for dictation and enrollment. A domain
consists of a set of vocabularies, word-usage models, and other associated parameters used during
a recognition session. A domain name must be specified when the speech recognition engine is
initialized for a user.

Syntax

int SmQueryTasks (char *language, SM_MSG *reply);


Parameters

language


input - The language used for the domain. If specified as NULL, all domains are returned,
regardless of language.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

For synchronous call and callbacks:

SM_RC_SERVER_MALLOC_ERROR


Reply Structure Functions by Message Type

SM_QUERY_TASKS_REPLY
SmGetAlphabets
SmGetDescriptions
SmGetLanguages
SmGetRc
SmGetTasks


Task Related Functions and Callbacks

SmNqueryTasksCallback


IBM ViaVoice SDK for Windows


SmQueryTopics

SmQueryTopics

Purpose

SmQueryTopics will be called by a client application to request information about the current
topics or a specified topic. It accepts a taskid argument and will return information about only
those topics associated with that task.

Syntax

int SmQueryTasks (unsigned long flags, char *taskid, char *topic,
SM_MSG *reply);


Parameters

flags


Valid values: SM_INSTALLED_TOPICS, SM_ACTIVE_TOPICS

taskid


Name of task for which associated topics will be returned.

topic


Optional topic name

reply


The pointer to a reply structure or to SmAsynchronous indicating that the call is made
asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

For synchronous call and callbacks:

SM_RC_SERVER_MALLOC_ERROR
SM_RC_SERVER_FILE_OPEN_ERROR


Reply Structure Functions by Message Type

SM_QUERY_TOPICS_REPLY
SmGetDescriptions
SmGetSpellings
SmGetFlags
SmGetPreferred


Task Related Functions and Callbacks

SmQueryUserDefault
SmNqueryTopicsCallback
SmNqueryUserDefaultCallback
SmNsetUserDefaultCallback


Remarks:

If the flags value SM_INSTALLED_TOPIC is specified, information about all installed topics will
be returned. The topics will be returned in sorted order such that the topics which are designed to
be used the this task (for example, the preferred topics) will appear first. The npreferred field refers
to these topics. The entire array of topics is accessed using SmGetTopics. The npreferred field is
accessed using SmGetPreferred.

If the flags value SM_ACTIVE_TOPICS is specified, information about only the current active
topics will be returned.

Access Functions:

SmGetTopics (Returns array of topic names)
SmGetPreferred (Returns number of preferred)
SmGetDescriptions (Returns array of topic descriptions)
SmGetFlags (Returns flags)


IBM ViaVoice SDK for Windows


SmQueryUserDefault

SmQueryUserDefault

Purpose

The default enrollid, taskid, and topics are stored by the engine on a per-user basis. This new
function, SmQueryUserDefault is used to query one of these defaults for a particular user.

Syntax

int SmQueryUserDefault (char *user_id, long item, SM_MSG *reply);


Parameters

user_id


Specifies which default to query. Valid values:

SM_DEFAULT_ENROLLID


Specifies request for default enrollid.

SM_DEFAULT_TASK


Specifies a request for default task.

SM_DEFAULT_TOPICS


Specifies request for default topics.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_QUERY_USER_DEFAULT_REPLY
SmGetTask
SmGetTasks
SmGetUserId
SmGetUserIds
SmGetEnrollId
SmGetEnrollIds
SmGetDefaultTopics


Task Related Functions and Callbacks

SmConnect
SmOpen
SmSetUserDefault
SmNconnectCallback
SmNqueryUserDefaultCallback
SmNconnectCallback
SmNsetUserDefaultCallback


Remarks:

If the item SM_DEFAULT_TOPICS is specified, the item_value returned in the reply structure
will be a string of the default topics for the specified userid concatenated with blank delimiters (for
example, “topic1 topic2 topic3”).

Access Functions:

SmGetUserId (Returns userid for which default was queried.)
SmGetEnrollid(s) (Returns enrollid if requested item was


SM_DEFAULT_ENROLLID)
SmGetTask(s) (Returns task if requested item was SM_DEFAULT_TASK)
SmGetDefaultTopics (Returns topics if requested item was SM_DEFAULT_TOPICS)


IBM ViaVoice SDK for Windows


SmQueryUserInfo

SmQueryUserInfo

Purpose
SmQueryUserInfo queries user ID or enrollment ID information.
This function retrieves information associated with a user ID or an enrollment ID. Only one value

can be queried at a time.

Syntax

int SmQueryUserInfo (char *user_id, char *enroll_id, char *itemname,
SM_MSG *reply);


Parameters

user_id


input - The name of the user whose information is retrieved.

enroll_id


input - The enrollment ID of the user whose information is retrieved. This parameter is NULL if
information on the user ID is retrieved.

itemname


input - The queried item name. The special predefined itemname parameter,
SM_USER_DIRECTORY, returns the full path of the location where user files are stored. An
application can store its files in the same location.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_BAD_ENROLLID
SM_RC_BAD_ITEM
SM_RC_BAD_USERID


Reply Structure Functions by Message Type

SM_QUERY_USER_INFO_REPLY


SmGetEnrollId


SmGetEnrollIds


SmGetNameValue


SmGetRc


SmGetUserId


SmGetUserIds


Task Related Functions and Callbacks

SmQueryUsers
SmSetUserInfo
SmNqueryUsersCallback
SmNqueryUserInfoCallback
SmNsetUserInfoCallback


IBM ViaVoice SDK for Windows


SmQueryUsers

SmQueryUsers

Purpose
SmQueryUsers queries a user list.
This function returns a list of users allowed to use the speech recognition engine. To establish a

speech session, a user from this list must be supplied in the SmNuserId speech attribute.

Syntax

int SmQueryUsers (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_SERVER_MALLOC_ERROR


Reply Structure Functions by Message Type

SM_QUERY_USERS_REPLY
SmGetAlphabets
SmGetDescriptions
SmGetRc
SmGetUserIds
SmGetUsers


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Task Related Functions and Callbacks

SmQueryUserInfo
SmSetUserInfo
SmNqueryUsersCallback
SmNqueryUserInfoCallback
SmNsetUserInfoCallback


IBM ViaVoice SDK for Windows


SmQueryVocabs

SmQueryVocabs

Purpose

SmQueryVocabs queries currently defined vocabularies.

This function obtains the list of all defined speech recognition engine vocabularies that belong to
the current session. This includes predefined vocabularies and those defined after initialization
with the SmDefineVocab or SmDefineVocabEx function.

Syntax

int SmQueryVocabs (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_QUERY_VOCABS_REPLY


SmGetRc


SmGetVocabList


Task Related Functions and Callbacks

SmAddToVocab
SmDefineVocab
SmDisableVocab
SmEnableVocab
SmQueryAddedWords
SmQueryEnabledVocabs
SmQueryWord
SmRemoveFromVocab
SmUndefineVocab
SmNaddToVocabCallback
SmNdefineVocabCallback
SmNdisableVocabCallback
SmNenableVocabCallback
SmNqueryAddedWordsCallback
SmNqueryEnabledVocabsCallback
SmNqueryVocabsCallback
SmNqueryWordsCallback
SmNremoveFromVocabCallback
SmNundefineVocabCallback


IBM ViaVoice SDK for Windows


SmQueryWord

SmQueryWord

Purpose
SmQueryWord checks for a specified word in all active vocabularies.

Syntax

int SmQueryWord (SM_WORD *word, SM_MSG *reply);


Parameters

word


input - The queried word.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_NOT_INVOCAB


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_QUERY_WORD_REPLY


SmGetRc


SmGetVocabList


SmGetWords


Task Related Functions and Callbacks

SmAddToVocab
SmDefineVocab
SmDisableVocab
SmEnableVocab
SmPlayWords
SmQueryAddedWords
SmQueryEnabledVocabs
SmQueryVocabs
SmRemoveFromVocab
SmUndefineVocab
SmWordCorrection
SmNaddToVocabCallback
SmNdefineVocabCallback
SmNdisableVocabCallback
SmNenableVocabCallback
SmNplayWordsCallback
SmNplayWordsStatusCallback
SmNqueryAddedWordsCallback
SmNqueryEnabledVocabsCallback
SmNqueryVocabsCallback
SmNqueryWordsCallback
SmNremoveFromVocabCallback
SmNundefineVocabCallback
SmNwordCorrectionCallback


IBM ViaVoice SDK for Windows


SmReceiveMsg

SmReceiveMsg

Purpose

SmReceiveMsg receives a message from the speech recognition engine.

This function provides the method through which speech-aware Windows applications receive
asynchronous messages, including unsolicited asynchronous messages such as
SM_RECOGNIZED_TEXT, from the speech recognition engine. This function receives one
complete message from the speech recognition engine.

For details, see "Session Sharing" in the SMAPI Developer's Guide.

Syntax

int SmReceiveMsg (unsigned long ap_val, SM_MSG *msg);


Parameters

ap_val


input - For Windows applications, pass lParam here.

msg


output - The pointer to the reply structure.

Return Values

SM_RC_OK
SM_RC_REPLY_NULL
SM_RC_SM_NOT_OPEN


Reply Structure Functions by Message Type

SmGetRc
SmGetRcName


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmRecognizeNextWord

Purpose

SmRecognizeNextWord enables the recognition of the next word.

This function searches for the next word to decode. When running, the engine searches the
currently enabled vocabularies to find a word that matches the incoming speech. The vocabulary
that contains the best match determines what happens next:

.
If the matching word comes from a dictation vocabulary, the engine sends the firm and infirm
words to the application in an SM_RECOGNIZED_TEXT message and continues decoding.
.
If the matching word comes from a command vocabulary, the engine sends the word and some
alternative choices to the application in an SM_RECOGNIZED WORD message. The engine
then halts and waits for the application to request another word.
If a recognized word occurs in two or more vocabularies enabled at the same time, the engine
selects the word from the more recently enabled command vocabulary. Command vocabularies
always override dictation vocabularies; when a recognized word occurs in both a command and
dictation vocabulary enabled at the same time, the engine selects the command-vocabulary word.

Syntax

int SmRecognizeNextWord (SM_MSG *reply);


Parameters

reply


input/output -The pointer to the reply structure or to the SmAsynchronous value indicating that
the call is made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP


IBM ViaVoice SDK for Windows


SmRecognizeNextWord

SM_RC_SM_NOT_OPEN
SM_RC_OK


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_RECOGNIZED_WORD
SmGetAlternates
SmGetFirmWords
SmGetRc
SmGetTimes


SM_RECOGNIZE_NEXT_WORD_REPLY
SmGetRc


For command vocabularies with microphone off and audio input stream processed:

SM_UTTERANCE_COMPLETED
SmGetRc
SmGetUtteranceNumber


Task Related Functions and Callbacks

SmHaltRecognizer
SmMicOff
SmMicOn
SmQuery
SmSet
SmNhaltRecognizerCallback
SmNmicOffCallback
SmNmicOnCallback
SmNqueryCallback
SmNrecognizeNextWordCallback
SmNrecognizedTextCallback
SmNrecognizedWordCallback
SmNsetCallback
SmNutteranceCompletedCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmReleaseFocus

Purpose
SmReleaseFocus releases speech focus.
This function releases speech focus for the application calling this API. If the application does not

have the speech focus, this function returns SM_RC_NOT_VALID_REQUEST; otherwise it
returns SM_RC_OK.
If the call is made asynchronously the reply can be dispatched through either of the following:


. SM_RELEASE_FOCUS
. SmNreleaseFocusCallback
Syntax

int SmReleaseFocus (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_NOT_VALID_REQUEST
SM_RC_OK


Reply Structure Functions by Message Type

SM_RELEASE_FOCUS
SmGetRc
SM_FOCUS_LOST


Task Related Functions and Callbacks

SmRequestFocus
SmNfocusGrantedCallback
SmNfocusRequestedCallback
SmNreleaseFocusCallback
SmNrequestFocusCallback


IBM ViaVoice SDK for Windows


SmRemoveCallback

SmRemoveCallback

Purpose
SmRemoveCallback removes a single callback routine for a specific callback.

Syntax

int SmRemoveCallback (char *reply_name, SmHandler *handler,
caddr_t client_data);


Parameters

reply_name


input - The name of the type of message.

handler


input -The function name of the routine that handles the message.

client_data


input - The data passed back to the handler when it is called.

Return Values

SM_RC_ENOMEM
SM_RC_NOT_VALID_REQUEST
SM_RC_OK
SM_RC_SM_NOT_OPEN


Task Related Functions and Callbacks

SmAddCallback
SmDispatch


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmRemoveFromVocab

Purpose

SmRemoveFromVocab removes words from a dynamic vocabulary.

This function removes words previously added, using SmAddToVocab, to either dynamic
vocabularies created by SmDefineVocab or added to predefined vocabularies. This function can be
used to dynamically change command vocabularies in an application. Pronunciations for the
specified words are not removed by this call and can be reused later by words added to this or any
other vocabulary.

This call is valid only when the speech recognition engine is not accepting dictation.

Syntax

int SmRemoveFromVocab (char *vocab, short nvocwords,
SM_VOCWORD *vocwords[], SM_MSG *reply);


Parameters

vocab


input -The name of the vocabulary from which words are removed.

nvocwords


input - The number of words removed from the vocabulary. Limited to SM_MAX_VOCWORDS.

vocwords


input - The spellings of the words removed from the vocabulary.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

IBM ViaVoice SDK for Windows


SmRemoveFromVocab

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_BAD_VOCAB
SM_RC_NOT_VALID_REQUEST
SM_RC_SERVER_FILE_OPEN_ERROR
SM_RC_SERVER_FILE_WRITE_ERROR


Reply Structure Functions by Message Type

SM_REMOVE_FROM_VOCAB_REPLY


SmGetRc


SmGetVocabName


Task Related Functions and Callbacks

SmAddToVocab
SmDefineVocab
SmDisableVocab
SmEnableVocab
SmQueryAddedWords
SmQueryEnabledVocabs
SmQueryVocabs
SmQueryWord
SmUndefineVocab
SmNaddToVocabCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmNdefineVocabCallback
SmNdisableVocabCallback
SmNenableVocabCallback
SmNqueryAddedWordsCallback
SmNqueryEnabledVocabsCallback
SmNqueryVocabsCallback
SmNqueryWordsCallback
SmNremoveFromVocabCallback
SmNundefineVocabCallback


IBM ViaVoice SDK for Windows


SmRemovePronunciation

SmRemovePronunciation

Purpose

SmRemovePronunciation removes a pronunciation from the user's personal pronunciation pool.
You cannot remove pronunciations from the permanent pool.

Syntax

int SmRemovePronunciation (char *spelling, char *pronunciation,
SM_MSG *reply);


Parameters

spelling


input - The word spelling which references the pronunciation.

pronunciation


input - The sounds-like spelling of the pronunciation to be removed.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST
SM_RC_NOT_YET
SM_RC_SERVER_ERROR


Reply Structure Functions by Message Type

SM_REMOVE_PRONUNCIATION_REPLY


SmGetRc


SmGetSpelling


SmGetSpellings


Task Related Functions and Callbacks

SmAddPronunciation
SmCorrectText
SmCorrectTextCancel
SmNewContext
SmQueryPronunciation
SmQueryPronunciations
SmWordCorrection
SmNaddPronunciationCallback
SmNcorrectTextCallback
SmNcorrectTextCancelCallback
SmNnewContextCallback
SmNqueryPronunciationCallback
SmNqueryPronunciationsCallback
SmNremovePronunciationCallback
SmNwordCorrectionCallback


IBM ViaVoice SDK for Windows


SmRequestFocus

SmRequestFocus

Purpose

SmRequestFocus requests speech focus.

An application requests speech focus with a SmRequestFocus function call. If the call is made
asynchronously, the reply can be dispatched through either of the following:

SM_REQUEST_FOCUS

SmNrequestFocusCallback
If the request is accepted, an asynchronous message is sent after the engine grants focus. This
event can be dispatched through either of the following:

SM_FOCUS_GRANTED
SmNfocusGrantedCallback
Important notes on return code values include the following:


SM_RC_FOCUS_DENIED means the application with speech focus has grabbed the focus
and changes are blocked by the engine.
SM_RC_FOCUS_GRANTED means the requesting application had previously been granted
speech focus and no asynchronous notification message is generated by the engine.


Syntax

int SmRequestFocus (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_FOCUS_DENIED
SM_RC_FOCUS_GRANTED
SM_RC_OK


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_REQUEST_FOCUS


SmGetRc
SM_FOCUS_GRANTED


Task Related Functions and Callbacks

SmReleaseFocus
SmNfocusGrantedCallback
SmNfocusRequestedCallback
SmNreleaseFocusCallback
SmNrequestFocusCallback


IBM ViaVoice SDK for Windows


SmRequestMicOff

SmRequestMicOff

Purpose

SmRequestMicOff requests that the microphone be turned off.

This function requests the speech recognition engine to request the application with speech focus
to turn off the microphone. If no application has speech focus, then SM_RC_NO_FOCUS_APP is
returned.

Syntax

int SmRequestMicOff (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_NO_FOCUS_APP
SM_RC_OK


Reply Structure Functions by Message Type

SM_REQUEST_MIC_OFF_REPLY
SmGetRc
SM_REQUEST_MIC_OFF


Task Related Functions and Callbacks

SmRequestMicOn
SmNrequestMicOffCallback
SmNrequestMicOnCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmRequestMicOn

Purpose

SmRequestMicOn requests that the microphone be turned on.

This function requests the speech recognition engine to request the application with speech focus
to turn on the microphone. If no application has speech focus, then SM_RC_NO_FOCUS_APP is
returned.

Syntax

int SmRequestMicOn (SM_MSG *reply);


Parameters

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_NO_FOCUS_APP
SM_RC_OK


Reply Structure Functions by Message Type

SM_REQUEST_MIC_ON_REPLY
SmGetRc
SM_REQUEST_MIC_ON


Task Related Functions and Callbacks

SmRequestMicOff
SmNrequestMicOffCallback
SmNrequestMicOnCallback


IBM ViaVoice SDK for Windows


SmRestoreSpeechData

SmRestoreSpeechData

Purpose

SmRestoreSpeechData overwrites the current session files and resets the running utterance
number. Since this can take a long time, we suggest you call this asynchronously. Only valid in
recognition mode.

Note:

For this call to be valid, the application must first enable audio saving through
SmSet(SM_SAVE_AUDIO, TRUE). For more information on saving and restoring speech
sessions, reference “Writing ViaVoice Applications to Save and Restore Audio” in the SMAPI
Developer’s Guide.

Syntax

int SmRestoreSpeechData (char *archive, long version, SM_MSG *reply);


Parameters

archive


input - File name specified on SmSaveSpeechData.

version


input - Value defined by the application at save time and checked by the engine when the session is
restored.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_OK


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Reply Structure Functions by Message Type

SM_RESTORE_SPEECH_DATA_REPLY
SmGetSpeechDataArchive
SmGetSpeechDataSize
SmGetSpeechDataVersion


Task Related Functions and Callbacks

SmSaveSpeechData


IBM ViaVoice SDK for Windows


SmSaveSpeechData

SmSaveSpeechData

Purpose

SmSaveSpeechData saves current session speech data to a file. Since this can take a long time, we
suggest you call this asynchronously.

Note:
For this call to be valid, the application must first enable audio saving through
SmSet(SM_SAVE_AUDIO, TRUE). For more information on saving and restoring speech sessions,
reference “Writing ViaVoice Applications to Save and Restore Audio” in the SMAPI Developer’s
Guide.

Syntax

int SmSaveSpeechData (char *archive, long version, long flags,
SM_MSG *reply);


Parameters

archive


input - File name where data will be stored.

version


input - Identifies the data file.

flags


input - Identifies how the data should be saved, using one of the following values:

SM_NORMAL_FILE


The speech data is written to the file specified by the file name. This file will contain only

engine data.

SM_COMPOUND_FILE


The speech data is written to the Windows compound file specified by the file name, using
IStorage/IStream. The data is saved in a section named "VTDSessionArchive." This allows an
application to save both engine state and application state data in the same file.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Return Values

SM_RC_OK


Reply Structure Functions by Message Type

SM_SAVE_SPEECH_DATA_REPLY
SmGetSpeechDataArchive
SmGetSpeechDataOptions
SmGetSpeechDataSize
SmGetSpeechDataVersion


Task Related Functions and Callbacks

SmRestoreSpeechData


IBM ViaVoice SDK for Windows


SmSet

SmSet

Purpose
SmSet sets the value of a specified speech recognition engine parameter.

Syntax

int SmSet (short item, long value, SM_MSG *reply);


Parameters

item


input -The parameter set, which can be any one of the following:

SM_API_DEBUG


Values that can be set include the following: 0 is debugging off, 1 to 5 provide progressively
more debug information. A value of 1 or 2 provides flow of control information.

SM_API_DISPLAY


Reserved.

SM_API_LOG


The values are:
0=Off
1=Message headers
2=Message headers + content
3=Message headers + content + internal engine messages
Values above 3 are reserved.


SM_API_TIMING


Reserved.

SM_AUDIO_DEVICE


Selects the type of audio hardware.

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SM_AUDIO_CONFIGURATION


(Not applicable to Windows. Instead use Audio Setup program.)
Query the input source of the audio hardware where audio data is collected. The returned value
is bit mapped and can be any combination of the following values:


. SM_AUDIO_INPUT_MIC_HI_GAIN
. SM_AUDIO_INPUT_MIC_LO_GAIN
. SM_AUDIO_INPUT_LINE_LEFT
. SM_AUDIO_INPUT_LINE_RIGHT
. SM_AUDIO_INPUT_VARIABLE_GAIN
. SM_AUDIO_OUTPUT_LINE_LEFT
. SM_AUDIO_OUTPUT_LINE_RIGHT
. SM_AUDIO_OUTPUT_INTERNAL_SPEAKER
. SM_AUDIO_OUTPUT_VARIABLE_GAIN
Refer to the SMLIMITS.H file for bounds on input and output values.
SM_AUDIO_INPUT_MODE


(Not applicable to Windows. Instead use Audio Setup program.)
Sets the input source of the audio hardware where audio data is collected. Only one value can
be specified per call and values include the following:


. SM_AUDIO_INPUT_LINE_LEFT
. SM_AUDIO_INPUT_LINE_RIGHT
. SM_AUDIO_INPUT_MIC_HI_GAIN
. SM_AUDIO_INPUT_MIC_LO_GAIN
. SM_AUDIO_OUTPUT_MODE (Not applicable to Windows. Instead use the Audio Setup
program.)
If supported by the underlying audio, this parameter indicates the current output destination.
Only one value can be specified per call and values include the following:

. SM_AUDIO_OUTPUT_LINE_LEFT
. SM_AUDIO_OUTPUT_LINE_RIGHT
. SM_AUDIO_OUTPUT_INTERNAL_SPEAKER
IBM ViaVoice SDK for Windows


SmSet

.
SM_AUDIO_INPUT_GAIN (Not applicable to Windows. Instead use Audio Setup
program.)
.
If supported by underlying audio, this parameter allows you to set current gain setting.
Refer to the SMLIMITS.H file for bounds on input and output values.
SM_AUDIO_OUTPUT_GAIN


(Not applicable to Windows. Instead use Audio Setup program.)

If supported by underlying audio, this parameter allows you to set current gain setting. Refer to
the SMLIMITS.H file for bounds on input and output values. The IBM VoiceType Dictation
adapter does not support the value, SM_AUDIO_INPUT_LINE_RIGHT.

SM_AVAILABLE_AUDIO_DEVICES


For the default, SPCH_DEFAULT_SYSTEM_AUDIO. If using MWAVE,
SPCH_MWAVE_AUDIO.


SM_COMPLETE_COMMAND_TIMEOUT


These timeout parameters are used to control the behavior of finite state grammars. In
particular, they specify how much silence is needed at the end of commands before the engine
will make a recognition decision to accept or reject the command. The amount of silence
required to accept or reject a phrase that is unambiguously complete. Default value is 25
(csecs). Can be overridden by task dependent .par value.

SM_CONNECTION_ID


Sets the value of the WPARAM parameter for WM_CONTROL messages received from the
engine. If SM_PM_ENABLE is TRUE all asynchronous API messages from the engine are
WM_CONTROL messages. The WPARAM parameter is the value of the
SM_CONNECTION_ID.

SM_ENABLE_EXCLUSIVE_VOCABS


Sets the calling application's vocabularies. As part of the new global vocabulary mechanism,
applications have been given control of these as well as the navigator vocabularies. The SmSet
item SM_ENABLE_EXCLUSIVE_VOCABS now takes four values:

.
SM_EXCLUDE_NONE
.
SM_EXCLUDE_ALL
.
SM_EXCLUDE_GLOBALS
.
SM_EXCLUDE_ALLBUTNAVGLOBALS
IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

The first two correspond to the old 0/1 values, so old clients will work as before. The third is
not very useful but would let a client hide any of these new globals. The fourth provides the
"super-global" function so that dictation clients can hide all vocabularies except those the
navigator defines as global.

SM_ENGINE_DEBUG


Reserved. Values that can be set include the following: 0 is disabled, greater than 0 provides
progressively more information.

SM_ENGINE_DISPLAY


Reserved. Values that can be set include the following: 0 is disabled, greater than 0 provides
progressively more information.

SM_ENGINE_LOG


Reserved. Values that can be set include the following: 0 is disabled, greater than 0 provides
progressively more information.

SM_IMMEDIATE_FIRMUP_MODE


This formerly unused item will now enable quick-firm-up mode, causing the engine to firm-up
the next command or short phrase terminated by silence. No infirm words are sent while it is
active and it is reset when the first firm word is sent.

Currently there are no new notifications, so the last 3 modes produce the same
SM_NOTIFY_FOCUS_APP_EXCLUSIVE engine state notification:


. SM_NOTIFY_NAVIGATOR_EXCLUSIVE
. SM_NOTIFY_FOCUS_APP_EXCLUSIVE
. SM_NOTIFY_NONE_EXCLUSIVE
SM_NOTIFY_AUDIO_LEVEL


Sets the returning of audio-level data during recognition or enrollment. The value is either
TRUE (1) or FALSE (0). See “SmGetAudioLevel” on page 200.

SM_NOTIFY_COMMAND_WORD


Sets whether the application is notified when a command word is recognized by having the
engine send a SM_COMMAND_WORD reply message. The value is either TRUE (1) or
FALSE (0).

SM_NOTIFY_ENGINE_STATE


Sets whether the application is notified of a speech recognition engine state change. The value
is either TRUE (1) or FALSE (0). See “SmGetEngineState” on page 205.

IBM ViaVoice SDK for Windows


SmSet

SM_NOTIFY_FOCUS_STATE


Sets whether the application is notified of a speech focus state change. The value is either
TRUE (1) or FALSE (0). See “SmGetFocusState” on page 216.

SM_NOTIFY_MIC_STATE


Sets whether the application is notified of a microphone state change. The value is either
TRUE (1) or FALSE (0). See “SmGetMicState” on page 221.

SM_OPTIMIZE_PERFORMANCE


Sets the speech recognition value for the engine depending on your requirements. Only one
value can be specified per call and values include the following:

. SM_OPTIMIZE_SPEED (fast)
. SM_OPTIMIZE_DEFAULT (balanced)
. SM_OPTIMIZE_ACCURACY (accurate)
SM_PARTIAL_COMMAND_TIMEOUT


These timeout parameters are used to control the behavior of finite state grammars. In
particular, they specify how much silence is needed at the end of commands before the engine
will make a recognition decision to accept or reject the command. The amount of silence
required to accept or reject a phrase that is both partially complete and complete. Default value
is 250 (csecs). It can be overridden by task dependent .par value.

For example, consider the grammar:
command = move up 3 move up five


 Now consider the following acoustic scenarios:
1.MOVE
2.MOVE UP
3.MOVE UP FIVE
1.The engine will accept silences up to 0.5 seconds, waiting for the UP, before rejecting

the phrase as incomplete.


2.The engine will accept silences up to 0.5 seconds, waiting for the optional FIVE, before
accepting the phrase MOVE UP.
3.Then engine will wait only 0.1 seconds after the FIVE to accept the phrase.


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

For the example given, it seems that you would like to increase the
SM_PARTIAL_COMMAND_TIMEOUT in order to allow longer pauses within phrases.
Note that increasing this parameter will also increase the decision time for "ambiguously
complete" phrases.

SM_REDUCED_CPU_MODE


Sets the CPU mode of the speech recognition engine. The value is either TRUE (1) for reduced
CPU mode, or FALSE (0) for normal CPU mode. See “SmGetEngineState” on page 205.

SM_REJECTION_THRESHOLD


The speech recognition engine rejects out-of-vocabulary words or background noise during
monitored enrollment or command recognition. However, there is a trade-off between
correctly rejecting these words/noises, and incorrectly rejecting properly spoken words.

SM_REJECTION_THRESHOLD allows an application to adjust this trade-off. The limits for
the value of this parameter are SM_MIN_REJECTION_THRESHOLD and
SM_MAX_REJECTION_THRESHOLD, which are defined in SMLIMITS.H. At low settings
of SM_REJECTION_THRESHOLD, the engine allows more matches through with fewer
rejections. This causes more background noises or incorrect word matches to be recognized as
speech. Fewer correct words are rejected. At high rejection threshold values, the engine is
biased toward requiring a closer match, resulting in more rejections, and potentially more
rejections of correct words. This parameter also determines how close the match must be
between spoken acoustics and pronunciations in the SmAddPronunciation and
SmWordCorrection calls. See SMLIMITS.H for minimum and maximum limits.

SM_RELOAD_ACOUSTICS


This flag will be specified as an argument to the SmSet function. It will be used by a client
application to request that the engine reload acoustic data after speaker clustering or
microphone adaptation.

SM_SAVE_AUDIO


Enables the saving of speech data during recognition based on the following flags:

SM_SAVE_AUDIO_ADAPTATION -Saves audio data required for training.

SM_SAVE_AUDIO_ALTERNATES Saves audio data required for alternates

(SmQueryAlternates).

SM_SAVE_AUDIO_DEFAULT Saves all audio data for playback, add pronunciation and
alternates. DEFAULT is mapped to PLAYBACK|ALTERNATES|TRAINWORD to
preserve compatibility with older applications which asserted TRUE.

IBM ViaVoice SDK for Windows


SmSet

SM_SAVE_AUDIO_PLAYBACK - Saves audio data required for playback
(SmPlayWords)

SM_SAVE_AUDIO_PLAYBACKHIQ - Saves audio data required for high quality
playback.

SM_SAVE_AUDIO_TRAINWORD -Saves audio data required for trainword
(SmAddPronunciation).

SM_ENGINE_TIMING


Reserved

value


input - The value to set the parameter to.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_BAD_MODE
SM_RC_BAD_VALUE
SM_RC_NOT_YET
SM_RC_SERVER_FILE_OPEN_ERROR
SM_RC_SERVER_ERROR
SM_RC_EXISTS_IN_NOTIFY
SM_RC_NOT_IN_NOTIFY


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_SET_REPLY
SmGetRc
SmGetItemValue


For SM_NOTIFY_MIC_STATE parameter equal TRUE:

SM_MIC_STATE
SmGetMicState
SmGetRc


For SM_NOTIFY_FOCUS_STATE parameter equal TRUE:

SM_FOCUS_STATE
SmGetApplication
SmGetFocusState
SmGetRc


For SM_NOTIFY_ENGINE_STATE parameter equal TRUE:

SM_ENGINE_STATE
SmGetEngineState
SmGetRc


For SM_NOTIFY_COMMAND_WORD parameter equal TRUE:

SM_COMMAND_WORD
SmGetApplication
SmGetFirmWords
SmGetRc


For SM_NOTIFY_AUDIO_LEVEL parameter equal TRUE:

SM_AUDIO_LEVEL
SmGetAudioLevel
SmGetRc


IBM ViaVoice SDK for Windows


SmSet

Task Related Functions and Callbacks

SmHaltRecognizer
SmMicOff
SmMicOn
SmQuery
SmRecognizeNextWord
SmNhaltRecognizerCallback
SmNmicOffCallback
SmNmicOnCallback
SmNqueryCallback
SmNrecognizeNextWordCallback
SmNrecognizedTextCallback
SmNrecognizedWordCallback
SmNsetCallback
SmNutteranceCompletedCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmSetArg

Purpose
SmSetArg is a macro that fills an SmArg structure when given its components.
This function sets the components of the arg parameter. The pointer to arg or to a list of similarly

created arguments can then be passed to a number of functions, such as SmOpen and SmConnect.
For further information on attributes, reference “SMAPI Attributes” on page 305. Also, see
"Establishing a Speech Session" in the SMAPI Developer's Guide.

Syntax

void SmSetArg (SmArg arg, char *name, long value);


Parameters

arg


input - The argument.

name


input -The name of the attribute.

value


input - The value of the attribute.

Return Values

 None

Task Related Functions and Callbacks

SmConnect
SmOpen
SmNconnectCallback


IBM ViaVoice SDK for Windows


SmSetBinary

SmSetBinary

Purpose
SmSetBinary sets the value of a specified speech recognition engine parameter.
This function is used instead of SmSet to set values of arbitrary length and data type.

Syntax

int SmSetBinary (short item, short length, void *value, SM_MSG *reply);


Parameters

item


input -The parameter to be set, which can be any of the following:

SM_AUDIO_SOURCE -Specifies setting value in audio library.
SM_MNR_VALUE - Specifies setting mnr value.


length


input - The length in bytes of the data pointed to by the argument value.

value


input - Points to data to which item is to be set.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

If item is SM_AUDIO_SOURCE return values depend on audio library implementation of
AudioSetSource.

If item is SM_MNR_VALUE return value is SM_RC_OK.

Reply Structure Functions by Message Type

SM_SET_BINARY_REPLY
SmGetRc
SmGetBinaryItemValue


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Task Related Functions and Callbacks

SmQueryBinary
SmNsetBinaryCallback


IBM ViaVoice SDK for Windows


SmSetDefault

SmSetDefault

Purpose

SmSetDefault sets a default value for a user, enrollment, task ID speech attribute, or the default
topics. The default user, enrollment, or task ID is used by the speech recognition engine when
SM_USE_DEFAULT is specified for the speech attribute as arguments when calling SmOpen and
SmConnect. The default topics are always used by the speech recognition engine.

Syntax

int SmSetDefault (long item, char *item_value, SM_MSG *reply);


Parameters

item


input -Type of default ID speech attribute. Valid values include the following:

SM_DEFAULT_USERID
SM_DEFAULT_ENROLLID
SM_DEFAULT_TASK
SM_DEFAULT_TOPICS


item_value


input -Value for default ID speech attribute.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_OK


Reply Structure Functions by Message Type

SM_SET_DEFAULT_REPLY
SmGetRc


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Task Related Functions and Callbacks

SmConnect
SmOpen
SmQueryDefault
SmQueryUserDefault
SmSetUserDefault
SmNqueryDefaultCallback
SmNqueryUserDefaultCallback
SmNsetDefaultCallback
SmNsetUserDefaultCallback


Remarks:

The default enrollid, taskid, and topics are stored on a per-user basis. SmSetDefault called with an
item value of SM_DEFAULT_USERID will set the value of the default userid. SmSetDefault
called with other item values will set the default enrollid, taskid or topics for the default userid. To
set the default enrollid, task or topics for a user other than the default user, the function
SmSetUserDefault is provided.

IBM ViaVoice SDK for Windows


SmSetDirectory

SmSetDirectory

Purpose

SmSetDirectory sets the name of files or directories used by the engine.

In this release, SmSetDirectory defines the output.wav file name, used when SmPlayWords is
subsequently called with the SM_PLAY_WORDS_SAVE_WAVFILE option flag asserted. The
fully qualified file name is passed in the directory_name string.

Syntax

int SmSetDirectory(short *file_class, char *directory_name, SM_MSG *reply);


Parameters

file_class


input - Indicates type of file name being set (Reserved for future use)

directory_name


input - String containing the file/directory name being set.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_OK
SM_RC_BAD_VALUE (if file name is not valid)


Reply Structure Functions by Message Type

SM_SET_DEFAULT_REPLY
SmGetRc


Task Related Functions and Callbacks

SmConnect
SmOpen
SmQueryDefault


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmSetUserDefault

Purpose

SmSetUserDefault is a new function. The default enrollid, task id, and topics will be used to set
one of these defaults at a time for a particular user.

Syntax

int SmSetUserDefault (char *user_id, long item, char *item_value,
SM_MSG *reply);


Parameters

user_id


Userid for which default is set.

item


Specifies which default is set. Valid values:

SM_DEFAULT_ENROLLID


Specifies setting default enrollid

SM_DEFAULT_TASK


Specifies setting default task

SM_DEFAULT_TOPICS


Specifies setting default topics.

itemvalue


New default value to set.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

IBM ViaVoice SDK for Windows


SmSetUserDefault

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST
SM_RC_SERVER_FILE_OPEN_ERROR


Reply Structure Functions by Message Type

SM_SET_USER_DEFAULT_REPLY


Task Related Functions and Callbacks

SmConnect
SmOpen
SmQueryUserDefault
SmNconnectCallback
SmNqueryUserDefaultCallback
SmNconnectCallback
SmNsetUserDefaultCallback


Remarks:

If the item SM_DEFAULT_TOPICS is specified, the item_value argument must be a string of the
default topics for the specified userid concatenated with blank delimiters (for example, “topic1
topic2 topic3”).

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmSetUserInfo

Purpose

SmSetUserInfo sets user information.

This function stores any information that pertains to a user ID or an enrollment ID. It is the
responsibility of the speech-aware application to select a proper item name (tag) that uniquely
identifies stored information. This item is used later by the SmQueryUserInfo function for
retrieving the stored information. This function allows an application to associate string
information with a particular user ID or enrollment ID.

Syntax

int SmSetUserInfo (char *user_id, char *enroll_id, char *itemname,
char *itemvalue, SM_MSG *reply);


Parameters

user_id


input - The name of the user whose information is stored.

enroll_id


input - The enrollment ID of the user whose information is to be stored. This parameter is NULL if
the information stored is related to the user ID.

itemname


input -The name of the information item to be stored.

itemvalue


input - The value of the information item to be stored.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

IBM ViaVoice SDK for Windows


SmSetUserInfo

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN
SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_BAD_ENROLLID
SM_RC_BAD_ITEM
SM_RC_BAD_USERID


Reply Structure Functions by Message Type

SM_SET_USER_INFO_REPLY


SmGetEnrollId


SmGetEnrollIds


SmGetRc


SmGetUserId


SmGetUserIds


Task Related Functions and Callbacks

SmQueryUserInfo
SmQueryUsers
SmNqueryUsersCallback
SmNqueryUserInfoCallback
SmNsetUserInfoCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmUndefineVocab

Purpose

SmUndefineVocab deletes a dynamic vocabulary.

This function deletes a vocabulary defined by a call to SmDefineVocab or SmDefineVocabEx.
After the vocabulary is deleted, no calls to SmEnableVocab, SmDisableVocab, SmAddToVocab,
or SmRemoveFromVocab can be made for the specified vocabulary. The specified vocabulary
must be disabled to be deleted.

SmUndefineVocab releases the image of the private area of the FSG file. SmUndefineVocab is
valid only when the speech recognition engine is not decoding speech to text. See "Setting Up
Vocabularies" in the SMAPI Developer's Guide for examples of conditions when the engine is not
decoding speech to text.

Syntax

int SmUndefineVocab (char *vocab, SM_MSG *reply);


Parameters

vocab


input - The name of the vocabulary undefined.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

Return Values

SM_RC_BAD_VOCAB
SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_SM_NOT_OPEN


IBM ViaVoice SDK for Windows


SmUndefineVocab

SM_RC_OK
SM_RC_INVALID_PARM_MAX_LEN


For synchronous call and callbacks:

SM_RC_NOT_VALID_REQUEST


Reply Structure Functions by Message Type

SM_UNDEFINE_VOCAB_REPLY
SmGetRc
SmGetVocabName


Task Related Functions and Callbacks

SmAddToVocab
SmDefineVocab
SmDisableVocab
SmEnableVocab
SmQueryAddedWords
SmQueryEnabledVocabs
SmQueryVocabs
SmQueryWord
SmRemoveFromVocab
SmNaddToVocabCallback
SmNdefineVocabCallback
SmNdisableVocabCallback
SmNenableVocabCallback
SmNqueryAddedWordsCallback
SmNqueryEnabledVocabsCallback
SmNqueryVocabsCallback
SmNqueryWordsCallback
SmNremoveFromVocabCallback
SmNundefineVocabCallback


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

SmWordCorrection

Purpose

SmWordCorrection corrects a misrecognized word.

This function notifies the speech recognition engine that an incorrectly recognized word or
sequence of words was corrected by the user.

The user corrects the word by providing the correct spelling. This call specifies whether the
pronunciation for this word is to be added to the user's personal pronunciation pool and whether
the corrected spelling is to be added to the user's personal text vocabulary extension. The speech
recognition engine uses this information to assist future recognition.

If an SmWordCorrection call fails and the call is immediately repeated with exactly the same
parameters, the engine will automatically apply more lenient threshold parameters the second time
(reference “SmSet” on page 167 for a detailed description of the
SM_REJECTION_THRESHOLD parameter).

This call is valid only when the speech recognition engine is not decoding speech to text. See
"Changing the Engine Decoding State" in the SMAPI Developer's Guide for examples of
conditions when the engine is not decoding speech to text.

Notes:

-For this call to be valid, the application must first enable audio saving through
SmSet(SM_SAVE_AUDIO, TRUE). For more information on saving and restoring speech
sessions, reference “Writing ViaVoice Applications to Save and Restore Audio” in the SMAPI
Developer’s Guide.
-If you get an RC_OK return value for a synchronous call, you need to check the status by
performing an SmGetStatus function.

Syntax

int SmWordCorrection (short ntags, long tags[], short nspells,
char *spellings[], char *pronunciations[], short new_pronunciation,
SM_MSG *reply);


Parameters

ntags


input - The number of tagged words corrected.

IBM ViaVoice SDK for Windows


SmWordCorrection

tags


input - An array of tags for the words corrected.

nspells


input -The number of new words to replace the words in error.

spellings


input - An array of new spellings for the words corrected.

pronunciations


input -An array of spoken-like spellings for the words that were corrected if their pronunciation is
different than the spellings would suggest. Specify NULL if the spoken-like spelling is the same as
the true spelling.

new_pronunciation


input -A flag to indicate whether the corrected word is a new pronunciation for a word already in
the recognition vocabulary. The following flag values are valid:

SM_CHECK_SPELLING


Check the spelling of the new word before adding it to the recognition vocabulary as a new
word. SM_CHECK_SPELLING is valid only with SM_DEFAULT_ADDWORD.
SM_FORCE_ADDWORD and SM_REPLACE_ADDWORD override the spelling check.

SM_FORCE_ADDWORD


The corrected word is a new pronunciation and needs to be added as a new word even if the

word already exists in the vocabulary.

SM_NO_ADDWORD


The corrected word need not be added to the recognition vocabulary as a new word.

SM_DEFAULT_ADDWORD


The user needs to decide whether to add the corrected word to the recognition vocabulary. The
speech recognition engine produces a pronunciation if one does not already exist.

SM_REPLACE_ADDWORD


The new pronunciation needs to replace any existing pronunciations of the corrected word.

reply


input/output -The pointer to a reply structure or to SmAsynchronous indicating that the call is
made asynchronously.

IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

Return Values

SM_RC_DEALLOCATING_SH_MEM
SM_RC_EALLOC
SM_RC_EBADHANDLE
SM_RC_ENOCONN
SM_RC_ENOMEM
SM_RC_ENOMSG
SM_RC_ENOSERVER
SM_RC_EUNEXP
SM_RC_INVALID_PARM_MAX_LEN
SM_RC_OK
SM_RC_RECORDING_REQUIRED
SM_RC_SM_NOT_OPEN


For synchronous call and callbacks:

SM_RC_MULTIPLE_SPELLINGS
SM_RC_NOT_VALID_REQUEST
SM_RC_RECORDING_REQUIRED


Reply Structure Functions by Message Type

SM_WORD_CORRECTION_REPLY


SmGetPronunciations


SmGetRc


SmGetSpellings


SmGetStatus


SmGetTags


Task Related Functions and Callbacks

SmCorrectText
SmCorrectTextCancel
SmNewContext
SmNcorrectTextCallback
SmNcorrectTextCancelCallback
SmNnewContextCallback
SmNplayWordsCallback


IBM ViaVoice SDK for Windows


SmWordCorrection

SmNplayWordsStatusCallback
SmNqueryAddedWordsCallback
SmNqueryWordsCallback
SmNremovePronunciationCallback
SmNwordCorrectionCallback
SmPlayWords
SmQueryAddedWords
SmQueryWord
SmRemovePronunciation


IBM SMAPI Reference


Function Calls to the Speech Recognition Engine

IBM ViaVoice SDK for Windows


Chapter 4 Data Access Functions

This chapter lists and describes the function calls that retrieve data from reply messages. These
function calls do not interact with the engine; they provide local access to the logical contents of a
message that has already been received.

SmGetAlphabets

Purpose

SmGetAlphabets retrieves a list of alphabets related to specific enroll IDs or tasks.

SmGetAlphabets retrieves a list of alphabet strings. This function can extract data from the
following reply message structures:

. SM_QUERY_ENROLLIDS_REPLY
. SM_QUERY_TASKS_REPLY
The alphabet identifies the base technology used in the engine. Enrollment data must match engine
technology. The current engine is using a ranks based technology (alphabet="R".). The previous
engine used a Z-label based technology (alphabet="Z".).
Syntax

int SmGetAlphabets (SM_MSG reply, unsigned long *nalphabets,
char ***alphabets);


Parameters

reply


input - The reply structure from a SMAPI function.

nalphabets


output - The pointer to the number of alphabets.

alphabets


output - The pointer to a list of alphabets.

IBM SMAPI Reference


Data Access Functions

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Task Related Functions and Callbacks

SmQueryEnrollIds
SmQueryTasks


IBM ViaVoice SDK for Windows


SmGetAlternates

SmGetAlternates

Purpose
SmGetAlternates retrieves alternative words.
SmGetAlternates retrieves the list of alternative words from the reply message. This function can

extract data from the following reply message structures:

. SM_QUERY_ALTERNATES_REPLY
. SM_RECOGNIZED_WORD
Syntax
int SmGetAlternates (SM_MSG reply, unsigned long *nwords, SM_WORD **words);


Parameters

reply


input - The reply structure from a SMAPI function.

nwords


output - The pointer to the number of alternative words.

words


output -The pointer to a list of alternative words.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure Functions by Message Type

SmQueryAlternates


IBM SMAPI Reference


Data Access Functions

SmGetAnnotations

Purpose

SmGetAnnotations retrieves annotations.

SmGetAnnotations extracts the base vocabulary name from the reply message, uses this name to
access the image of the private area of the FSG file, and uses the offsets stored in SM_WORD to
access the annotation data. This function can extract data from the following reply message
structures:

. SM_RECOGNIZED_PHRASE
. SM_QUERY_PHRASE_ALTERNATIVES_REPLY
Annotations are stored in an SM_ANNOTATION structure. SmGetAnnotations returns a pointer
to this structure. SM_ANNOTATION is defined as:
struct _SM_ANNOTATION (
long type; // Type of annotation
union
{
long numeric; // Return numeric annotations
char *string; // Return string annotations
void *other; // Reserved
} annodata;
);

Types of annotations are defined as :

. SM_ANNOTATION_NONE
. SM_ANNOTATION_NUMERIC
. SM_ANNOTATION_STRING
. SM_ANNOTATION_OTHER (Reserved)
The SM_ANNOTATION structure has a one-to-one correspondence with the corresponding
SM_WORD structure. Lack of an annotation on a particular word is indicated by an annotation of
type SM_ANNOTATION_NONE.

IBM ViaVoice SDK for Windows


SmGetAnnotations

Syntax

int SmGetAnnotations (SM_MSG reply, unsigned long *nwords,
SM_ANNOTATION **annotations);


Parameters

reply


input - The reply structure from a SMAPI function.

nwords


output - The pointer to the number of annotations.

annotations


output - The pointer to an annotation structure.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_SERVER_FILE_READ_ERROR


Reply Structure Functions by Message Type

SmDefineGrammar
SmUndefineVocab


IBM SMAPI Reference


Data Access Functions

SmGetApplication

Purpose

SmGetApplication retrieves the name of the application.

SmGetApplication extracts the application name from the following reply messages:

. SM_COMMAND_WORD
. SM_FOCUS_STATE
Syntax
int SmGetApplication (SM_MSG reply, char **application);


Parameters

reply


input - The reply structure from a SMAPI function.

application


output - The pointer to the name of the application.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure

SmNcommandWordCallback
SmNfocusStateCallback


IBM ViaVoice SDK for Windows


SmGetApplications

SmGetApplications

Purpose
SmGetApplications retrieves the names of the applications that have established a session.
SmGetApplications extracts the application names from the SM_QUERY_SESSIONS_REPLY

reply message sent by the speech recognition engine to the application.

Syntax

int SmGetApplications (SM_MSG reply, unsigned long *nsessions,
char ***reco_sessions);


Parameters

reply


input - The reply structure from a SMAPI function.

nsessions


output - A pointer to the number of sessions that have been established with the speech recognition
engine.

reco_sessions


output - A pointer to a list of applications that have established sessions with the speech
recognition engine.


Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure Functions by Message Type

SmNquerySessionsCallback


IBM SMAPI Reference


Data Access Functions

SmGetAudioLevel

Purpose

SmGetAudioLevel retrieves the level of the audio signal during recognition.

SmGetAudioLevel provides information about the level of audio received by the speech
recognition engine when the microphone is on. If previously requested by the
SM_AUDIO_INPUT_LEVEL parameter supplied to the SmSet function, packets of audio level
values are periodically sent to the speech recognition engine, which in turn calls
SmNaudioLevelCallback and/or sends a message to your window procedure. Audio-level
information can then be obtained using this function. Audio-level values range from
0(SM_MIN_AUDIO_LEVEL) to 10(SM_MAX_AUDIO_LEVEL) with acceptable volume
ranges from 2 to 7. The average rate sent by the engine is 5 audio-level values per second. This
function can extract data from the following reply message structures:

. SM_AUDIO_LEVEL
Syntax
int SmGetAudioLevel (SM_MSG reply, short *volume);


Parameters

reply


input - The reply structure from a SMAPI function.

volume


output - The pointer to a short. Volume can range from SM_MIN_AUDIO_LEVEL to
SM_MAX_AUDIO_LEVEL inclusive.


Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmNaudioLevelCallback


IBM ViaVoice SDK for Windows


SmGetBinaryItemValue

SmGetBinaryItemValue

Purpose
SmGetBinaryItemValue retrieves the value of item of arbitrary length and data type.
SmGetBinaryItemValue can extract data from the following reply message structures:

. SM_SET_BINARY_REPLY
. SM_QUERY_BINARY_REPLY
Syntax
int SmGetBinaryItemValue (SM_MSG sm_reply, unsigned long *item,
unsigned long *length, void ***value);


Parameters

sm_reply


input - The reply structure from a SMAPI function.

item


output - A pointer to the name of the item.

length


output - A pointer to the length of the data pointed by the value argument.

value


output -A pointer to the value of the item.

Return Values

SM_RC_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure Functions by Message Type

SmSetBinary
SmQueryBinary


IBM SMAPI Reference


Data Access Functions

SmGetCodePage

Purpose
SmGetCodepage returns the Windows codepage used for character strings in/out of the engine.
SmGetCodepage can extract data from the following reply message structures:

. SM_CONNECT_REPLY (Recognition Mode Only)
Syntax

int SmGetCodepage (SM_MSG reply, unsigned long *codepage);


Parameters

reply


input - The reply structure from a SMAPI function.

codepage


output -Returns the Windows codepage used for character strings in/out of the engine.

Return Values

SM_RC_OK
SM_RC_REPLY_NULL
SM_RC_SM_EINVAL_MSG_TYPE


IBM ViaVoice SDK for Windows


SmGetDescriptions

SmGetDescriptions

Purpose
SmGetDescriptions retrieves a list of enrollment enroll IDs, scripts, tasks, or users.
SmGetDescriptions can extract data from the following reply message structures:

. SM_QUERY_ENROLLIDS_REPLY
. SM_QUERY_SCRIPTS_REPLY SM_QUERY_TASKS_REPLY
. SM_QUERY_USERS_REPLY
. SM_QUERY_LANGUAGES_REPLY
. SM_QUERY_TOPICS_REPLY
Syntax
int SmGetDescriptions (SM_MSG reply, unsigned long *ndescriptions,
char ***descriptions);


Parameters

reply


input - The reply structure from a SMAPI function.

ndescriptions


output -The pointer to the number of descriptions.

descriptions


output - The pointer to a list of descriptions.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


IBM SMAPI Reference


Data Access Functions

Reply Structure Functions by Message Type

SmQueryEnrollIds
SmQueryLanguages
SmQueryTasks
SmQueryUsers


IBM ViaVoice SDK for Windows


SmGetEngineState

SmGetEngineState

Purpose

SmGetEngineState retrieves the engine state.

SmGetEngineState extracts the engine state from an SM_ENGINE_STATE reply message sent
by the speech recognition engine to an application. SM_ENGINE_STATE reply messages are
controlled by the SM_NOTIFY_ENGINE_STATE parameter of the SmSet function.

Syntax

int SmGetEngineState (SM_MSG reply, unsigned long *engine_state);


Parameters

reply


input - The reply structure from a SMAPI function.

engine_state


output - The pointer to an unsigned long. Values include the following:

. SM_NOTIFY_NORMAL_CPU
. SM_NOTIFY_REDUCED_CPU
. SM_NOTIFY_ENGINE_BUSY
. SM_NOTIFY_ENGINE_IDLE
. SM_NOTIFY_NAVIGATOR_EXCLUSIVE
. SM_NOTIFY_FOCUS_APP_EXCLUSIVE
. SM_NOTIFY_NONE_EXCLUSIVE
. SM_NOTIFY_RECOGNIZED_SPEECH
. SM_NOTIFY_SPEECH_START
. SM_NOTIFY_SPEECH_STOP
. SM_NOTIFY_SPEECH_TOO_HIGH
. SM_NOTIFY_SPEECH_TOO_LOW
. SM_NOTIFY_PRONUNCIATIONS_ADDED
IBM SMAPI Reference


Data Access Functions

. SM_NOTIFY_PRONUNCIATIONS_DELETED
. SM_NOTIFY_ENGINE_SETTINGS_CHANGED for the following parameters:
. SM_REJECTION_THRESHOLD
. SM_AUDIO_CONFIGURATION
. SM_AUDIO_DEVICE
. SM_AUDIO_INPUT_GAIN
. SM_AUDIO_INPUT_MODE
. SM_AUDIO_OUTPUT_GAIN
. SM_AUDIO_OUTPUT_MODE
. SM_NOTIFY_APPLICATION_CONNECTED
. SM_NOTIFY_APPLICATION_DISCONNECTED
Return Values
SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure Functions by Message Type

SmNengineStateCallback


IBM ViaVoice SDK for Windows


SmGetEnrollId

SmGetEnrollId

Purpose

SmGetEnrollId retrieves an enrollment ID.

SmGetEnrollId is valid only for reply message structures that contain one enrollment ID. Use
SmGetEnrollIds for reply message structures with multiple enrollment IDs. SmGetEnrollId can
extract data from the following reply message structures:

. SM_CONNECT_REPLY
. SM_QUERY_DEFAULT_REPLY
. SM_QUERY_USER_DEFAULT_REPLY
. SM_QUERY_USER_INFO_REPLY
. SM_SET_USER_INFO_REPLY
Syntax
int SmGetEnrollId (SM_MSG reply, char **enroll_id);


Parameters

reply


input - The reply structure from a SMAPI function.

enroll_id


output - The pointer to an enrollment ID.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure Functions by Message Type

SmQueryDefault
SmQueryEnrollIds
SmQueryUserInfo
SmSetUserInfo


IBM SMAPI Reference


Data Access Functions

SmGetEnrollIds

Purpose

SmGetEnrollIds retrieves a list of enrollment IDs.

SmGetEnrollIds extracts data from the following reply message structures:

. SM_QUERY_DEFAULT_REPLY
. SM_QUERY_SESSIONS_REPLY
. SM_CONNECT_REPLY
. SM_QUERY_ENROLLIDS_REPLY
. SM_QUERY_USER_DEFAULT_REPLY
. SM_QUERY_USER_INFO_REPLY
. SM_SET_USER_INFO_REPLY
Syntax
int SmGetEnrollIds (SM_MSG reply, unsigned long *nenroll_ids,
char ***enroll_ids);


Parameters

reply


input - The reply structure from a SMAPI function.

nenroll_ids


output -The pointer to the number of enrollment IDs.

enroll_ids


output - The pointer to a list of enrollment IDs.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


IBM ViaVoice SDK for Windows


SmGetEnrollIds

Reply Structure Functions by Message Type

SmQueryEnrollIds
SmQueryUserInfo
SmSetUserInfo


IBM SMAPI Reference


Data Access Functions

SmGetEventId

Purpose

SmGetEventId retrieves the event ID.

SmGetEventId can extract data from the following reply message structures:

. SM_EVENT_NOTIFY_REPLY
. SM_EVENT_SYNCH
Syntax
int SmGetEventId (SM_MSG reply, unsigned long *event_id);


Parameters

reply


input - The reply structure from a SMAPI function.

event_id


output - The pointer to the event ID.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure Functions by Message Type

SmEventNotify
SmNeventSynchCallback


IBM ViaVoice SDK for Windows


SmGetEventOptions

SmGetEventOptions

Purpose
SmGetEventOptions retrieves options for an event.
SmGetEventOptions can extract data from the following reply message structure:

. SM_EVENT_SYNCH
Syntax
int SmGetEventOptions (SM_MSG reply, unsigned long *options);


Parameters

reply


input - The reply structure from a SMAPI function.

options


output - The pointer to options.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure Functions by Message Type

SmNeventSynchCallback


IBM SMAPI Reference


Data Access Functions

SmGetFirmWords

Purpose

SmGetFirmWords retrieves firm words.

SmGetFirmWords extracts the SM_WORD from the following reply message structures:

. SM_RECOGNIZED_PHRASE
. SM_RECOGNIZED_TEXT
. SM_RECOGNIZED_WORD
. SM_COMMAND_WORD
. SM_QUERY_PHRASE_ALTERNATIVES_REPLY
Syntax
int SmGetFirmWords (SM_MSG reply, unsigned long *nwords, SM_WORD **words);


Parameters

reply


input - The reply structure from a SMAPI function.

nwords


output -The pointer to the number of firm words.

words


output - The pointer to a list of firm words.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure Functions by Message Type

SmNrecognizedTextCallback
SmNrecognizedWordCallback
SmNcommandWordCallback


IBM ViaVoice SDK for Windows


SmGetFlags

SmGetFlags

Purpose

SmGetFlags is used to retrieve a single flags field from a reply structure. It is valid only for the
following message types:

. SM_AUTO_COMPLETE_REPLY
. SM_CONNECT_REPLY
. SM_DISCARD_SPEECH_DATA_REPLY
. SM_QUERY_PHRASE_ALTERNATIVES_REPLY
. SM_QUERY_PRONUNCIATIONS_REPLY
. SM_QUERY_TOPICS
. SM_QUERY_TASKS_REPLY
Syntax
int SmGetFlags (SM_MSG reply, unsigned long *flags);


Parameters

reply


input - The reply structure from a SMAPI function.

flags


output - Receives flags field.

Return Values

SM_RC_OK
SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryPhraseAlternatives
SmConnect


IBM SMAPI Reference


Data Access Functions

Related Functions:

SmAutoComplete
SmDiscardSpeechData
SmQuerAddedWordsEx
SmQuerPhraseAlternatives
SmQueryPronunciationsEx
SmQueryTopics


IBM ViaVoice SDK for Windows


SmGetFocusChangeReason

SmGetFocusChangeReason

Purpose
SmGetFocusChangeReason returns a reason code on focus changes.
SmGetFocusChangeReason extracts the reason from the SM_FOCUS_STATE reply structure.

The change reason is only available when the focus state notification is for
SM_NOTIFY_FOCUS_RELEASED.
The "change reason" flags can be:


.
SM_NOTIFY_FOCUS_CHANGE_ON_RELEASE (The application released the focus, by
itself)
.
SM_NOTIFY_FOCUS_CHANGE_ON_REQUEST (The application released focus due to
request)
Syntax

int SmGetFocusChangeReason (SM_MSG reply, unsigned long *reason);


Parameters

reply


input - The reply structure from a SMAPI function.

reason


output - The pointer to the reason change.

Return Values

SM_RC_OK
SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmGetFocusState
SmNFocusStateCallback


IBM SMAPI Reference


Data Access Functions

SmGetFocusState

Purpose

SmGetFocusState retrieves the focus state.

SmGetFocusState extracts the focus state from the SM_FOCUS_STATE reply message sent by
the speech recognition engine to an application. SM_FOCUS_STATE reply messages are
controlled by the SmSet SM_NOTIFY_FOCUS_STATE parameter. The name of the application
causing the focus change can be extracted from SM_FOCUS_STATE with SmGetApplication.

Syntax

int SmGetFocusState (SM_MSG reply, unsigned long *focus_state);


Parameters

reply


input - The reply structure from an API function.

focus_state


output - The pointer to an unsigned long. Values include the following:

. SM_NOTIFY_FOCUS_REQUESTED
. SM_NOTIFY_FOCUS_GRANTED
. SM_NOTIFY_FOCUS_DENIED
. SM_NOTIFY_FOCUS_RELEASED
Return Values
None

Reply Structure - Related Functions and Callbacks

SmGetFocusChangeReason
SmNfocusStateCallback


IBM ViaVoice SDK for Windows


SmGetGrammarPath

SmGetGrammarPath

Purpose
SmGetGrammarPath retrieves the full path name of an FSG file.
SmGetGrammarPath extracts data from the following reply message structure:

. SM_DEFINE_GRAMMAR_REPLY
Syntax
int SmGetGrammarPath (SM_MSG reply, char **grammar_path);


Parameters

reply


input - The reply structure from a SMAPI function.

grammar_path


output -The pointer to the full path name.

Return Values

SM_RC_OK
SM_RC_REPLY_NULL
SM_RC_SM_EINVAL_MSG_TYPE


Reply Structure - Related Functions and Callbacks

SmDefineGrammar


IBM SMAPI Reference


Data Access Functions

SmGetIncrements

Purpose

SmGetIncrements is used to retrieve an array of increment values from a reply structure. It is
valid only for the following message types:

. SM_QUERY_SCRIPTS_REPLY
Syntax
int SmGetIncrements (SM_MSG reply, unsigned long *nincrements,
short **increments);


Parameters

reply


input - The reply structure from a SMAPI function.

nincrements


output - Receives number of elements in array of increments returned.

increments


output - Receives array of increments.

Return Values

SM_RC_OK
SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_REPLY_NULL


Reply Structure Related Functions and Callbacks

SmQueryScripts


Related Functions:

SmQueryScripts


IBM ViaVoice SDK for Windows


SmGetItemValue

SmGetItemValue

Purpose

SmGetItemValue retrieves the value for an item.

SmGetItemValue can extract data from the following reply message structures:

. SM_QUERY_REPLY
. SM_SET_REPLY
Syntax
int SmGetItemValue (SM_MSG reply, unsigned long *item,
unsigned long *value);


Parameters

reply


input - The reply structure from a SMAPI function.

item


output - The pointer to the name of the item.

value


output - The pointer to the value of the item.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQuery
SmSet


IBM SMAPI Reference


Data Access Functions

SmGetLanguages

Purpose
SmGetLanguages retrieves a list of languages.

SmGetLanguages can extract data from the following reply message structures:

. SM_CONNECT_REPLY
. SM_QUERY_ENROLLIDS_REPLY
. SM_QUERY_LANGUAGES_REPLY
. SM_QUERY_TASKS_REPLY
Syntax
int SmGetLanguages (SM_MSG reply, unsigned long *nlanguages,
char ***languages);


Parameters

reply


input - The reply structure from a SMAPI function.

nlanguages


output - The pointer to the number of languages.

languages


output - The pointer to a list of languages.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryEnrollIds
SmQueryLanguages
SmQueryTasks
SmConnect


IBM ViaVoice SDK for Windows


SmGetMicState

SmGetMicState

Purpose
SmGetMicState gets the microphone state.
SmGetMicState extracts the microphone state from one of the following messages sent by the

speech recognition engine to the application:

. SM_REPORT_ENGINE_ERROR
. SM_FOCUS_GRANTED
. SM_MIC_STATE
SM_REPORT_ENGINE_ERROR is unsolicited, and SM_FOCUS_GRANTED and
SM_MIC_STATE are sent if the application issues SmSet for SM_NOTIFY_FOCUS_STATE and
SM_NOTIFY_MIC_STATE, respectively.
Syntax

int SmGetMicState (SM_MSG reply, unsigned long *mic_state)


Parameters

reply


input - The reply structure from a SMAPI function.

mic_state


output - Pointer to an unsigned long, which can be any of the following:
SM_NOTIFY_MIC_ON
SM_ENGINE_MIC_OFF


Return Values

None

Reply Structure - Related Functions and Callbacks

SmNmicStateCallback


IBM SMAPI Reference


Data Access Functions

SmGetMsgName

Purpose
SmGetMsgName retrieves the name of the audio message.
SmGetMsgName can extract data from the following reply message structures:

. SM_PLAY_MESSAGE_STATUS
Syntax
int SmGetMsgName (SM_MSG reply, char **message_name);


Parameters

reply


input - The reply structure from a SMAPI function.

message_name


output - The pointer to the name of the audio message.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmNplayMessageStatusCallback


IBM ViaVoice SDK for Windows


SmGetMsgType

SmGetMsgType

Purpose
SmGetMsgType retrieves the type of message from the reply structure associated with the input.
The values for SMAPI message types are defined in the SMCOMM.H file and in the section

“SMAPI Message Types” on page 375.
SmGetMsgType can extract data from all defined reply message structures.


Syntax

int SmGetMsgType (SM_MSG reply, int *message_type);


Parameters

reply


input - The reply structure from a SMAPI function.

message_type


output - The message type.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


IBM SMAPI Reference


Data Access Functions

SmGetNameValue

Purpose

SmGetNameValue retrieves a name and its value.

SmGetNameValue retrieves a name (tag) of user information and its corresponding value. This

function can extract data from the following reply message structures:

. SM_QUERY_USER_INFO_REPLY
Syntax
int SmGetNameValue (SM_MSG reply, char **name, char **value);


Parameters

reply


input - The reply structure from a SMAPI function.

name


output -The pointer to the name.

value


output - The pointer to the value of the name.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryUserInfo


IBM ViaVoice SDK for Windows


SmGetNumberWordMsgs

SmGetNumberWordMsgs

Purpose
SmGetNumberWordMsgs gets the number of words from a message.

SmGetNumberWordMsgs retrieves the number of SM_RECOGNIZED_WORD messages that
have been sent since the last SM_RECOGNIZE_NEXT_WORD function call request. The value
returned is 0 or 1. This is used with a synchronous SM_HALT_RECOGNIZER_REPLY
message to tell if any unprocessed command words are still queued.

Syntax

int SmGetNumberWordMsgs (SM_MSG *reply, unsigned long *nwords);


Parameters

reply


input - The reply structure from a SMAPI function.

nwords


output - Pointer to an unsigned long that will be filled in with the number of words.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


IBM SMAPI Reference


Data Access Functions

SmGetOptions

Purpose

SmGetOptions is used to retrieve an options field from a reply structure. It is valid only for the
following message types:

. SM_DEFINE_VOCABULARY_REPLY
Syntax
int SmGetOptions (SM_MSG *reply, unsigned long *options);


Parameters

reply


input reply structure from a SMAPI function.

options


output -output - receives options field.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmDefineVocabEx


Related Functions:

SmDefineVocabEx


IBM ViaVoice SDK for Windows


SmGetPercentages

SmGetPercentages

Purpose

SmGetPercentages retrieves percentages of the completeness of processing for specified
enrollments.
SmGetPercentages can extract data from the following reply message structure:

. SM_QUERY_ENROLLIDS_REPLY
A query of enrollids for a given user returns an array of enrollids, with related fields, including
percent-complete. This procedure provides an array of the percent-complete values.
Syntax

int SmGetPercentages (SM_MSG reply, unsigned long *npercentages,
short **percentages);


Parameters

reply


input - The reply structure from a SMAPI function.

npercentages


output - The pointer to the number of percentages.

percentages


output -The pointer to a list of percentages.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryEnrollIds


IBM SMAPI Reference


Data Access Functions

SmGetPhraseScore

Purpose

SmGetPhraseScore is used to retrieve the phrase score from a reply structure. It is valid only for
the following message types:

. SM_RECOGNIZED_PHRASE
Syntax
int SmGetPhraseScore (SM_MSG reply, short *score);


Parameters

reply


inputinput -Reply structure from a SMAPI function.

score


output - Receives score of phrase.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmNrecognizedPhraseCallback


IBM ViaVoice SDK for Windows


SmGetPhraseState

SmGetPhraseState

Purpose
SmGetPhraseState retrieves phrase state flags.
SmGetPhraseState can extract data from the following reply message structure:

. SM_RECOGNIZED_PHRASE
Syntax
int SmGetPhraseState (SM_MSG reply, unsigned long *phrase_state);


Parameters

reply


input - The reply structure from a SMAPI function.

phrase_state


output - The pointer to an unsigned long which can be either of the following:

You can get both of the following as output:

. SM_PHRASE_HALTED
The engine is in a halted state and is waiting for the application to tell it what to do next.

. SM_PHRASE_ACCEPTED
The engine has accepted the phrase.
OR
You can get both of the following as output:


. SM_PHRASE_HALTED
The engine is in a halted state and is waiting for the application to tell it what to do next.

. SM_PHRASE_REJECTED
The engine has rejected the phrase, with the best guess phrase returned in the SM_WORD
array.

IBM SMAPI Reference


Data Access Functions

Return Values

SM_RC_OK
SM_RC_REPLY_NULL
SM_RC_SM_EINVAL_MSG_TYPE


Reply Structure - Related Functions and Callbacks

SmNRecognizedPhraseCallback


IBM ViaVoice SDK for Windows


SmGetPreferred

SmGetPreferred

Purpose

SmGetPreferred is used to retrieve the number of preferred topics from a reply structure. It is
valid only for the following message types:

. SM_QUERY_TOPICS_REPLY
Syntax
int SmGetPreferred (SM_MSG reply, short *preferred);


Parameters

reply


input - Reply structure from a SMAPI function.

preferred


output - Receives number of preferred topics.

Related Functions:

SmQueryTopics


Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryTopics


IBM SMAPI Reference


Data Access Functions

SmGetPronunciations

Purpose
SmGetPronunciations retrieves pronunciations.
SmGetPronunciations can extract data from the following reply message structures:

. SM_QUERY_PRONUNCIATIONS_REPLY
. SM_WORD_CORRECTION_REPLY
. SM_QUERY_PRONUNCIATION_REPLY
. SM_RECOGNIZED_TEXT
Syntax
int SmGetPronunciations (SM_MSG reply, unsigned long *npronun,
char ***pronuns);


Parameters

reply


input - The reply structure from a SMAPI function.

npronun


output - The pointer to the number of pronunciations.

pronuns


output - The pointer to a list of pronunciations.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryPronunciations
SmWordCorrection


IBM ViaVoice SDK for Windows


SmGetRc

SmGetRc

Purpose

SmGetRc retrieves the return code for the SMAPI functions.
Syntax

int SmGetRc (SM_MSG reply, int *rc);


Parameters

reply


input - The reply structure from a SMAPI function.

rc


output - The pointer to the return code.

Return Values

SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

All functions.

IBM SMAPI Reference


Data Access Functions

SmGetRcDescription

Purpose

SmGetRcDescription retrieves the ASCII string describing the return code.

SmGetRcDescription remaps return codes to ASCII strings that describe the return code and,
potentially, the associated failure. Messages are in US English only for diagnostic purposes. This
function returns a pointer to an ASCII character string that describes the return code in the
parameter rc_description. For example, for the symbolic return code
"SM_RC_ACOUSTICS_TOO_LONG", the associated return code description character string
would be "The acoustics specified are too long." For a list of all return code character strings,
reference “SMAPI Message Explanations” on page 379.

Syntax

int SmGetRcDescription (SM_MSG reply, char **rc_description);


Parameters

reply


input - The reply structure from a SMAPI function.

rc_description


output - Pointer to a character string.

Return Values

SM_RC_OK
SM_RC_REPLY_NULL


IBM ViaVoice SDK for Windows


SmGetRcName

SmGetRcName

Purpose

SmGetRcName returns the symbolic name of the return code as a string.

SmGetRcName retrieves the ASCII strings containing the symbol associated with the return code
as a string. For example, for a return code value of 49, the associated symbolic return code name
character string would be SM_RC_ACOUSTICS_TOO_LONG. For a list of all return code
values, reference “SMAPI Return Codes and Messages” on page 369.

Syntax

int SmGetRcName (SM_MSG reply, char **rc_name);


Parameters

reply


input - Any return code associated with any Sm call.

rc_name


output - Pointer to a character string.

Return Values

SM_RC_OK
SM_RC_REPLY_NULL


IBM SMAPI Reference


Data Access Functions

SmGetSampleRates

Purpose

SmGetSampleRates is used to retrieve an array of sample rates from a reply structure. It is valid
only for the following message types:

. SM_QUERY_ENROLLIDS_REPLY
Syntax
int SmGetSampleRates (SM_MSG reply, unsigned long *nrates,
short **sample_rates);


Parameters

reply


input - Reply structure from SMAPI function

nrates


output - Receives number of elements in array of sample_rates.

sample_rates


output - Receives array of sample_rates.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryEnrollids


Related Functions

SmQueryEnrollids


IBM ViaVoice SDK for Windows


SmGetScriptFlags

SmGetScriptFlags

Purpose

SmGetScriptFlags is used to retrieve an array of script flags from a reply structure. It is valid only
for the following message types:

. SM_QUERY_SCRIPTS_REPLY
Syntax
int SmGetScriptFlags (SM_MSG reply, unsigned long *nflags, long **flags);


Parameters

reply


input - Reply structure from SMAPI function

nflags


output - Receives number of elements in array of flags.

flags


output - Receives array of flags.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryScripts


Related Functions

SmQueryScripts


IBM SMAPI Reference


Data Access Functions

SmGetScripts

Purpose

SmGetScripts retrieves a list of enrollment scripts.

SmGetScripts can extract data from the following reply message structures:

. SM_QUERY_SCRIPTS_REPLY
. SM_QUERY_ENROLLIDS_REPLY
Syntax
int SmGetScripts (SM_MSG reply, unsigned long *nscripts, char ***scripts);


Parameters

reply


input - The reply structure from a SMAPI function.

nscripts


output - The pointer to the number of scripts.

scripts


output -The pointer to a list of scripts.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryEnrollIds


IBM ViaVoice SDK for Windows


SmGetService

SmGetService

Purpose

SmGetService retrieves a pointer to the argument name describing the service requested from the
speech recognition engine.
SmGetService can extract data from the following reply message structures:

. SM_CONNECT_REPLY
. SM_DISCONNECT_REPLY
Syntax
int SmGetService (SM_MSG reply, char **service);


Parameters

reply


input - The reply structure from a SMAPI function.

service


output - The pointer to the service name.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmConnect
SmDisconnect


IBM SMAPI Reference


Data Access Functions

SmGetSessionId

Purpose
SmGetSessionId retrieves the session ID from the reply structure.
SmGetSessionId can extract data from the following reply message structure:

. SM_CONNECT_REPLY
Syntax
int SmGetSessionId (SM_MSG reply, char **session_id);


Parameters

reply


input - The reply structure from a SMAPI function.

session_id


output - The pointer to the ID of the session.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmConnect


IBM ViaVoice SDK for Windows


SmGetSeverity

SmGetSeverity

Purpose

SmGetSeverity retrieves the severity associated with an unsolicited
SM_REPORT_ENGINE_ERROR message.


Syntax

int SmGetSeverity (SM_MSG reply, unsigned long *severity);


Parameters

reply


input - The reply structure from a SMAPI function.

severity


output -Pointer to an unsigned long that will be filled in with the severity. Values include the
following:

SM_ENGINE_INFO


Informational message/can be ignored.

SM_ENGINE_WARNING


Non-terminal error detected by engine.

SM_ENGINE_ERROR


Currently unused, but can be used in the future.

SM_ENGINE_TERMINAL_ERROR


Engine terminated due to unrecoverable error.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


IBM SMAPI Reference


Data Access Functions

SmGetSizes

Purpose

SmGetSizes is used to retrieve an array of size values from a reply structure. It is valid only for the
following message types:

. SM_QUERY_SCRIPTS_REPLY
Syntax
int SmGetSizes (SM_MSG reply, unsigned long *nsizes, short **sizes);


Parameters

reply


input - Reply structure from a SMAPI function.

nsizes


output - Receives number of elements in array of sizes Non-terminal error detected by engine.

sizes


output - Receives array of sizes.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryScripts


Related Functions:

SmQueryScripts


IBM ViaVoice SDK for Windows


SmGetSpeechDataArchive

SmGetSpeechDataArchive

Purpose

SmGetSpeechDataArchive retrieves the name of the archive file.

SmGetSpeechDataArchive extracts data associated with the following reply message structures:

. SM_SAVE_SPEECH_DATA_REPLY
. SM_RESTORE_SPEECH_DATA_REPLY
Syntax
int SmGetSpeechDataArchive (SM_MSG reply, char **archive);


Parameters

reply


input - The reply structure from a SMAPI function.

archive


output -The pointer to the archive name.

Return Values

SM_RC_OK
SM_RC_REPLY_NULL
SM_RC_SM_EINVAL_MSG_TYPE


Reply Structure - Related Functions and Callbacks

SmSaveSpeechData
SmRestoreSpeechData


IBM SMAPI Reference


Data Access Functions

SmGetSpeechDataOptions

Purpose
SmGetSpeechDataOptions retrieves the options flags.
SmGetSpeechDataOptions extracts data associated with the following reply message structure:

. SM_SAVE_SPEECH_DATA_REPLY
Syntax
int SmGetSpeechDataOptions (SM_MSG reply, long *options);


Parameters

reply


input - The reply structure from a SMAPI function.

options


output -The pointer to the options flags, which can be one of the following:

SM_NORMAL_FILE


This indicates that the speech data was written to a flat file. It will contain only engine data.

SM_COMPOUND_FILE


This indicates that the speech data is written to a Windows compound file, and the data is
saved in a section named "VTDSessionArchive." The file can contain both engine state and
application state data.

Return Values

SM_RC_OK
SM_RC_REPLY_NULL
SM_RC_SM_EINVAL_MSG_TYPE


Reply Structure - Related Functions and Callbacks

SmSaveSpeechData


IBM ViaVoice SDK for Windows


SmGetSpeechDataSize

SmGetSpeechDataSize

Purpose

SmGetSpeechDataSize retrieves the size of the speech data archive.

SmGetSpeechDataSize extracts data associated with the following reply message structures:

. SM_SAVE_SPEECH_DATA_REPLY
. SM_QUERY_SPEECH_DATA_REPLY
Syntax
int SmGetSpeechDataSize (SM_MSG reply, unsigned long *size);


Parameters

reply


input - The reply structure from a SMAPI function.

size


output - The pointer to the size of the speech data archive.

Return Values

SM_RC_OK
SM_RC_REPLY_NULL
SM_RC_SM_EINVAL_MSG_TYPE


Reply Structure - Related Functions and Callbacks

SmQuerySpeechData
SmSaveSpeechData


IBM SMAPI Reference


Data Access Functions

SmGetSpeechDataVersion

Purpose

SmGetSpeechDataVersion retrieves the version identifier.

SmGetSpeechDataVersion extracts data associated with the following reply message structures:

. SM_SAVE_SPEECH_DATA_REPLY
. SM_RESTORE_SPEECH_DATA_REPLY
Syntax
int SmGetSpeechDataVersion (SM_MSG reply, long *version);


Parameters

reply


input - The reply structure from a SMAPI function.

version


output - The pointer to the version identifier.

Return Values

SM_RC_OK
SM_RC_REPLY_NULL
SM_RC_SM_EINVAL_MSG_TYPE


Reply Structure - Related Functions and Callbacks

SmRestoreSpeechData
SmSaveSpeechData


IBM ViaVoice SDK for Windows


SmGetSpelling

SmGetSpelling

Purpose

SmGetSpelling gets the spelling from a message.

SmGetSpelling extracts data and retrieves the spelling associated with the following reply

message structures:

. SM_ADD_PRONUNCIATION_REPLY
. SM_AUTO_COMPLETE_REPLY
. SM_QUERY_PRONUNCIATION_REPLY
. SM_QUERY_SPELLING_REPLY
. SM_QUERY_TOPICS_REPLY
. SM_QUERY_USER_DEFAULT_REPLY
. SM_REMOVE_PRONUNCIATION_REPLY
Syntax
int SmGetSpelling (SM_MSG reply, char **spelling);


Parameters

reply


input - The reply structure from a SMAPI function.

spelling


output - Pointer to a character string.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


IBM SMAPI Reference


Data Access Functions

Reply Structure - Related Functions and Callbacks

SmAddPronunciation
SmQueryPronunciation
SmRemovePronunciation
SmWordCorrection


IBM ViaVoice SDK for Windows


SmGetSpellings

SmGetSpellings

Purpose

SmGetSpellings retrieves spellings.

SmGetSpellings extracts data and retrieves the spelling associated with the following reply

message structures:

. SM_ADD_PRONUNCIATION_REPLY
. SM_QUERY_PRONUNCIATIONS_REPLY
. SM_REMOVE_PRONUNCIATION_REPLY
. SM_WORD_CORRECTION_REPLY
Syntax
int SmGetSpellings (SM_MSG reply, unsigned long *nspellings,
char ***spellings);


Parameters

reply


input - The reply structure from a SMAPI function.

nspellings


output -The pointer to the number of spellings.

spellings


output - The pointer to a list of spellings.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


IBM SMAPI Reference


Data Access Functions

Reply Structure - Related Functions and Callbacks

SmAddPronunciation
SmQueryPronunciations
SmRemovePronunciation
SmWordCorrection


IBM ViaVoice SDK for Windows


SmGetStates

SmGetStates

Purpose
SmGetStates retrieves enrollment statuses.
SmGetStates can extract data from the following reply message structure:

. SM_QUERY_ENROLLIDS_REPLY
. SM_QUERY_SCRIPTS_REPLY
Syntax
int SmGetStates (SM_MSG reply, unsigned long *nstati, short **stati);


Parameters

reply


input - The reply structure from a SMAPI function.

nstati


output -The pointer to the number of statuses.

stati


output -The pointer to a list of statuses. Values include the following:

. SM_STAT_ENROLLMENT_RECORDING
. SM_STAT_ENROLLMENT_RUNNING
. SM_STAT_ENROLLMENT_COMPLETE
. SM_STAT_ENROLLMENT_FAILED
. SM_STAT_ENROLLMENT_BUSY
Return Values
SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure Functions by Message Type

SmQueryEnrollIds


IBM SMAPI Reference


Data Access Functions

SmGetStatus

Purpose

SmGetStatus retrieves the status.

SmGetStatus can extract data from the following reply message structures:

. SM_DISCARD_SPEECH_DATA_REPLY
. SM_PLAY_MESSAGE_STATUS
. SM_PLAY_UTTERANCE_STATUS
. SM_PLAY_WORDS_STATUS
. SM_WORD_CORRECTION_REPLY
The SmGetStatus function retrieves the status from the reply structure. This status and its
meaning depend on the related function that was called just before the SmGetStatus call. The
following statuses are possible:
. For SmNplayMessageCallback and SmNplayUtteranceCallback:
SM_STAT_PLAY_START


The message, utterance, or word playback started.

SM_STAT_PLAY_STOP


The message, utterance, or word playback stopped.

. For SmNplayWordsStatusCallback:
SM_STAT_PLAY_START


The message, utterance, or word playback started.

SM_STAT_PLAY_STOP


The message, utterance, or word playback stopped.

SM_STAT_BAD_AUDIO


The connection to the audio source was lost during playback.

SM_STAT_BAD_TAG


An invalid tag value was specified for the word.

. For an SmWordCorrection call:
SM_RC_ADDED
The word was added to the vocabulary.


IBM ViaVoice SDK for Windows


SmGetStatus

SM_RC_INVOCAB


The word is already in the vocabulary.

SM_RC_NOT_INVOCAB


The word is not in the IBM ViaVoice spelling dictionary.

SM_RC_NOT_ADDED


The word has not been added to the vocabulary.

Syntax

int SmGetStatus (SM_MSG reply, int *status);


Parameters

reply


input - The reply structure from a SMAPI function.

status


output - The pointer to the status.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmWordCorrection
SmNplayMessageStatusCallback
SmNplayUtteranceStatusCallback
SmNplayWordsStatusCallback


IBM SMAPI Reference


Data Access Functions

SmGetTags

Purpose
SmGetTags retrieves tags from the reply structure.
SmGetTags can extract data from the following reply message structures:

. SM_PLAY_WORDS_STATUS
. SM_QUERY_ALTERNATES_REPLY
. SM_WORD_CORRECTION_REPLY
Syntax
int SmGetTags (SM_MSG reply, unsigned long *ntags, long **tags);


Parameters

reply


input - The reply structure from a SMAPI function.

ntags


output -The pointer to the number of tags.

tags


output -The pointer to a list of tags.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryAlternates
SmWordCorrection
SmNplayWordsStatusCallback


IBM ViaVoice SDK for Windows


SmGetTask

SmGetTask

Purpose

SmGetTask retrieves a domain from the reply structure.

SmGetTask is valid only for reply message structures that contain one domain. Use SmGetTasks
for reply message structures with multiple domains. SmGetTask can extract data from the
following reply message structures:

. SM_CONNECT_REPLY
. SM_QUERY_DEFAULT_REPLY
. SM_QUERY_TASKS_REPLY
. SM_QUERY_USER_DEFAULT_REPLY
Syntax
int SmGetTask (SM_MSG reply, char **domain);


Parameters

reply


input - The reply structure from a SMAPI function.

domain


output - The pointer to a domain.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryDefault
SmQueryTasks


IBM SMAPI Reference


Data Access Functions

SmGetTaskFlags

Purpose
SmGetTaskFlags retrieves attribute information about tasks.

SmGetTaskFlags extracts the task attribute flags from the SM_QUERY_TASKS_REPLY reply
message sent by the speech recognition engine to the application

Syntax

int SmGetTaskFlags (SM_MSG reply, unsigned long *nflags,
unsigned long **flags);


Parameters

reply


input - The reply structure from a SMAPI function.

nflags


output -A pointer to the number of flags in the list of return flags.

flags


output - A pointer to a list of task flags. Each flag in the list contains information about one or
more of the following attributes of a task:

. SM_TASK_CONTINUOUS -This task supports continuous dictation
. SM_TASK_NUMBER_FMT - This task supports number formatting
Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure Functions by Message Type

SMQueryTasks


Task Related Functions and Callbacks

SmNqueryTasksCallback


IBM ViaVoice SDK for Windows


SmGetTasks

SmGetTasks

Purpose
SmGetTasks retrieves domains from the reply structure.
SmGetTasks extracts data from the following reply message structures:

. SM_CONNECT_REPLY
. SM_QUERY_DEFAULT_REPLY
. SM_QUERY_SCRIPTS_REPLY
. SM_QUERY_SESSIONS_REPLY
. SM_QUERY_TASKS_REPLY
. SM_QUERY_USER_DEFAULT_REPLY
Syntax
int SmGetTasks (SM_MSG reply, unsigned long *ndomains, char ***domains);


Parameters

reply


input - The reply structure from a SMAPI function.

ndomains


output -The pointer to the number of domains.

domains


output -The pointer to a list of domains.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryTasks


IBM SMAPI Reference


Data Access Functions

SmGetTimes

This API call is ONLY here for compatibility purposes. If you are writing a new application, you
should use SmGetWordTimes instead to return the start and end times for text, word, and phrase
messages.

Purpose

SmGetTimes retrieves time values of spoken words.

SmGetTimes retrieves an array of time values sent with words received in the last
SM_RECOGNIZED_TEXT or SM_RECOGNIZED_WORD message from the speech
recognition engine. Each time, expressed in milliseconds, specifies the time elapsed from the
beginning of the utterance to the beginning of the spoken word. This function can extract data from
the following reply message structures:

. SM_RECOGNIZED_TEXT
. SM_RECOGNIZED_WORD
Syntax
int SmGetTimes(SM_MSG reply, unsigned long *ntimes, unsigned long **times);


Parameters

reply


input - The reply structure from a SMAPI function.

ntimes


output - The pointer to the number of times in the list.

times


output - The pointer to a list of times.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


IBM ViaVoice SDK for Windows


SmGetTimes

Reply Structure - Related Functions and Callbacks

SmNrecognizedTextCallback
SmNrecognizedWordCallback
SmNaudioEventCallback


IBM SMAPI Reference


Data Access Functions

SmGetTopics

Purpose

SmGetTopics is used to retrieve an array of topics from a reply structure. It is valid only for the
following message types:

. SM_QUERY_TOPICS_REPLY
. SM_SET_TOPICS_REPLY
Syntax
int SmGetTopics (SM_MSG reply, unsigned long *ntopics, char ***topics);


Parameters

reply


input -reply structure from a SMAPI function.

ntopics


output - receives number of elements in array of topics

trained


output - receives array of topics.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryTopics


Related Functions:

SmQueryTopics


IBM ViaVoice SDK for Windows


SmGetTrained

SmGetTrained

Purpose

SmGetTrained is used to retrieve an array of trained values from a reply structure. It is valid only
for the following message types:

. SM_QUERY_SCRIPTS_REPLY
Syntax
int SmGetTrained (SM_MSG reply, unsigned long *ntrained, short **trained);


Parameters

reply


input -reply structure from a SMAPI function.

ntrained


output - receives number of elements in array of trained

trained


output - receives array of trained.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryScripts


Related Functions:

SmQueryScripts


IBM SMAPI Reference


Data Access Functions

SmGetUserId

Purpose

SmGetUserId retrieves a user ID from the reply structure.

SmGetUserId is valid only for reply message structures that contain one user ID. Use
SmGetUserIds for reply message structures with multiple user IDs. SmGetUserId can extract
data from the following reply message structures:

. SM_CONNECT_REPLY
. SM_QUERY_DEFAULT_REPLY
. SM_QUERY_USER_INFO_REPLY
. SM_QUERY_USER_DEFAULT_REPLY
. SM_REQUEST_NEW_ENROLLID_REPLY
. SM_REQUEST_NEW_USERID_REPLY
. SM_SET_USER_INFO_REPLY
Syntax
int SmGetUserId (SM_MSG reply, char **user_id);


Parameters

reply


input - The reply structure from a SMAPI function.

user_id


output - The pointer to a user ID.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


IBM ViaVoice SDK for Windows


SmGetUserId

Reply Structure - Related Functions and Callbacks

SmQueryDefault
SmQueryUserInfo
SmQueryUsers
SmSetUserInfo


IBM SMAPI Reference


Data Access Functions

SmGetUserIds

Purpose
SmGetUserIds retrieves user IDs from the reply structure.

SmGetUserIds can extract data from the following reply message structures:

. SM_QUERY_DEFAULT_REPLY
. SM_QUERY_SESSIONS_REPLY
. SM_QUERY_USER_DEFAULT_REPLY
. SM_QUERY_USER_INFO_REPLY
. SM_QUERY_USERS_REPLY
. SM_REQUEST_NEW_ENROLLID_REPLY
. SM_REQUEST_NEW_USERID_REPLY
. SM_SET_USER_INFO_REPLY
Syntax
int SmGetUserIds(SM_MSG reply, unsigned long *nuser_ids, char ***user_ids);


Parameters

reply


input - The reply structure from a SMAPI function.

nuser_ids


output - The pointer to the number of user IDs.

user_ids


output -The pointer to a list of user IDs.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


IBM ViaVoice SDK for Windows


SmGetUserIds

Reply Structure - Related Functions and Callbacks

SmQueryUserInfo
SmQueryUsers
SmSetUserInfo


IBM SMAPI Reference


Data Access Functions

SmGetUsers

Purpose
SmGetUsers retrieves users from the reply structure.
SmGetUsers can extract data from the following reply message structure:

. SM_QUERY_USERS_REPLY
. SM_REQUEST_NEW_USERID_REPLY
Syntax
int SmGetUsers (SM_MSG reply, unsigned long *nusers, char ***users);


Parameters

reply


input - The reply structure from a SMAPI function.

nusers


output - The pointer to the number of users.

users


output -The pointer to a list of users.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryUsers


IBM ViaVoice SDK for Windows


SmGetUtteranceNumber

SmGetUtteranceNumber

Purpose

SmGetUtteranceNumber retrieves the utterance number from the reply structure.

SmGetUtteranceNumber can extract data from the following reply message structures:

. SM_MIC_ON_REPLY
. SM_PLAY_UTTERANCE_STATUS
. SM_UTTERANCE_COMPLETED
Syntax
int SmGetUtteranceNumber (SM_MSG reply, unsigned long *nutterance);


Parameters

reply


input - The reply structure from a SMAPI function.

nutterance


output - The pointer to the utterance number.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmMicOn
SmNplayUtteranceStatusCallback
SmNutteranceCompletedCallback


IBM SMAPI Reference


Data Access Functions

SmGetVocabList

Purpose
SmGetVocabList function retrieves a vocabulary list from the reply structure.
SmGetVocabList can extract data from the following reply message structures:

. SM_QUERY_ENABLED_VOCABS_REPLY
. SM_QUERY_VOCABS_REPLY
. SM_QUERY_WORD_REPLY
. SM_SET_VOCABS_REPLY
Syntax
int SmGetVocabList (SM_MSG reply, unsigned long *nvocabs,
char ***vocabs);


Parameters

reply


input - The reply structure from a SMAPI function.

nvocabs


output - The pointer to the number of vocabularies in the vocabulary list.

vocabs


output -The pointer to a list of vocabularies.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryEnabledVocabs
SmQueryVocabs
SmQueryWord


IBM ViaVoice SDK for Windows


SmGetVocabName

SmGetVocabName

Purpose
SmGetVocabName retrieves the vocabulary name from the reply structure.
SmGetVocabName extracts data from the following reply message structures:

. SM_ADD_TO_VOCAB_REPLY
. SM_DEFINE_GRAMMAR_REPLY
. SM_DEFINE_VOCAB_REPLY
. SM_DEFINE_VOCABULARY_REPLY
. SM_DISABLE_VOCAB_REPLY
. SM_ENABLE_VOCAB_REPLY
. SM_QUERY_PHRASE_ALTERNATES_REPLY
. SM_RECOGNIZED_PHRASE
. SM_REMOVE_FROM_VOCAB_REPLY
. SM_UNDEFINE_VOCAB_REPLY
Syntax
int SmGetVocabName (SM_MSG reply, char **vocabname);


Parameters

reply


input - The reply structure from a SMAPI function.

vocabname


output - The pointer to the name of the vocabulary.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


IBM SMAPI Reference


Data Access Functions

Reply Structure - Related Functions and Callbacks

SmAddToVocab
SmDefineVocab
SmDisableVocab
SmEnableVocab
SmRemoveFromVocab
SmUndefineVocab


IBM ViaVoice SDK for Windows


SmGetVocabPath

SmGetVocabPath

Purpose

SmGetVocabPath is used to retrieve a vocabulary path from a reply structure. It is valid only for
the following message types:

. SM_DEFINE_VOCABULARY_REPLY
Syntax
int SmGetVocabPath (SM_MSG reply, char **vocab_path);


Parameters

reply


input - reply structure from a SMAPI function.

vocab_path


output - receives vocabulary path string.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmDefineVocabEx


Related Functions

SmDefineVocabEx


IBM SMAPI Reference


Data Access Functions

SmGetVocWords

Purpose

SmGetVocWords retrieves vocabulary words from the reply structure.

SmGetVocWords extracts data from the following reply message structures:

. SM_ADD_TO_VOCAB_REPLY
. SM_DEFINE_GRAMMAR_REPLY
. SM_DEFINE_VOCAB_REPLY
. SM_DEFINE_VOCABULARY_REPLY
. SM_QUERY_VOCAB_WORDS_REPLY
Following an SmAddToVocab call, SmGetVocWords extracts the vocabulary words that failed to
be added.
Following an SmDefineVocab call, SmGetVocWords extracts the vocabulary words that failed to
be defined.

For a description of the SM_VOCWORD data type, reference “SM_VOCWORD” on page 302.

Syntax

int SmGetVocWords (SM_MSG reply, unsigned long *nwords,
SM_VOCWORD **words);


Parameters

reply


input - The reply structure from a SMAPI function.

nwords


output -The pointer to the number of vocabulary words. Limited to SM_MAX_VOCWORDS.

words


output -The pointer to a list of vocabulary words.

IBM ViaVoice SDK for Windows


SmGetVocWords

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmAddToVocab
SmDefineVocab


IBM SMAPI Reference


Data Access Functions

SmGetWords

Purpose
SmGetWords retrieves words from the reply structure.
SmGetWords can extract data from the following reply message structures:

. SM_QUERY_ADDED_WORDS_REPLY
. SM_QUERY_WORD_REPLY
Syntax
int SmGetWords (SM_MSG reply, unsigned long *nwords, SM_WORD **words);


Parameters

reply


input - The reply structure from a SMAPI function.

nwords


output - The pointer to the number of words.

words


output -The pointer to a list of words.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmQueryAddedWords
SmQueryWord


IBM ViaVoice SDK for Windows


SmGetWordTimes

SmGetWordTimes

Purpose

SmGetWordTimes retrieves the most likely start and end times for recognized words from the
reply structure.

During recognition, the speech recognition engine computes the most likely start and end times for
each recognized word. These times are used for playback and for computing alternates for word
correction.

The times returned by SmGetWordTimes are reported in frame time since the beginning of an
utterance, not clock time. Frame time is essentially in centiseconds (hundredths of a second), but
there can be slight differences in frame time versus clock time depending on the sample rate. For
example, at 11025Hz sampling, a frame is represented by 110 samples, so there is a drift of 11000/
11025 between frame time and clock time.

SmGetWordTimes can extract data from the following reply message structures:

. SM_ADD_PRONUNCIATION_REPLY
. SM_QUERY_PHRASE_ALTERNATIVES_REPLY
. SM_RECOGNIZED_PHRASE
. SM_RECOGNIZED_TEXT
. SM_RECOGNIZED_WORD
Syntax
int SmGetWordTimes (SM_MSG reply, unsigned long *ntimes,
unsigned long **stimes, unsigned long **etimes);


Parameters

reply


input - The reply structure from one of the supported messages.

ntimes


output - The pointer to the number of times in the list.

stimes


output -The pointer to the list of start times.

IBM SMAPI Reference


Data Access Functions

etimes


output -The pointer to the list of end times.

Return Values

SM_RC_SM_EINVAL_MSG_TYPE
SM_RC_OK
SM_RC_REPLY_NULL


Reply Structure - Related Functions and Callbacks

SmNrecognizedPhraseCallback
SmNrecognizedTextCallback
SmNrecognizedWordCallback


IBM ViaVoice SDK for Windows


SmReturnRc

SmReturnRc

Purpose

SmReturnRc returns the return code from SM_MSG.

SmReturnRc provides an alternative to SmGetRc for accessing return codes from messages
received from the speech recognition engine. The return value of the function is the return code
value in the given SM_MSG.

Syntax

int SmReturnRc (SM_MSG reply);


Parameters

reply


input - The reply structure from a SMAPI function.

Return Values

SM_RC_OK
SM_RC_REPLY_NULL


Task Related Functions and Callbacks

SmReturnRcDescription
SmReturnRcName


IBM SMAPI Reference


Data Access Functions

SmReturnRcDescription

Purpose

SmReturnRcDescription retrieves the ASCII string describing the return code.

SmReturnRcDescription remaps return codes to ASCII strings that describe the return code and,
potentially, the associated failure. Messages are in US English only for diagnostic purposes. For
example, if this function were passed the return code, SM_RC_ACOUSTICS_TOO_LONG, a
pointer to the associated return code description character string "The acoustics specified are too
long." would be returned. For a list of all return code character strings, reference “SMAPI Message
Explanations” on page 379.

Syntax

char *SmReturnRcDescription (int rc);


Parameters

rc


input - Any return code associated with any Sm call.

Task Related Functions and Callbacks

SmReturnRc
SmReturnRcName


IBM ViaVoice SDK for Windows


SmReturnRCName

SmReturnRCName

Purpose

SmReturnRcName returns the symbolic name of a return code as a string.

SmReturnRcName provides an alternative to SmGetRcName for retrieving an ASCII string
containing the symbol associated with a return code. For example, if this function was passed the
return code, SM_RC_ACOUSTICS_TOO_LONG, a pointer to the associated symbolic return
code name character string "SM_RC_ACOUSTICS_TOO_LONG" would be returned. For a list of
all return code values, reference “SMAPI Return Codes and Messages” on page 369.

Syntax

char *SmReturnRcName (int rc);


Parameters

rc


input - Any return code associated with any Sm call.

Return Values

Function directly returns a pointer to a statically defined character string containing a description
associated with the return code.

Refer to Appendix A. "SMAPI Return Codes and Messages" for a complete list of the character
strings, their associated return values, and their symbolic return code names.

Task Related Functions and Callbacks

SmReturnRc
SmReturnRcDescription


IBM SMAPI Reference


Data Access Functions

IBM ViaVoice SDK for Windows


Chapter 5 Reply Message Structures and
Callbacks

This chapter describes reply structures and callbacks.

Reply Message Structures Received from the Speech
Recognition Engine

An application can receive the following reply message structures, defined in SMCOMM.H, from the
speech recognition engine.

Reply message structures received by the application that are not in response to an API call request are
termed unsolicited.

Reply Message Structure Solicited Unsolicited Explanation
SM_AUTO_COMPLETE_REPLY X Response to an asynchronous
SmAddComplete call. Data can
be extracted with SmGetFlags,
SmGetSpelling or
SmGetSpellings.
SM_ADD_PRONUNCIATION_REPLY X Response to an asynchronous
SmAddPronunciation call. Data
can be extracted with
SmGetSpelling or
SmGetSpellings.
SM_ADD_TO_VOCAB_REPLY X Response to an asynchronous
SmAddToVocab call. Data can
be extracted with
SmGetVocabName or
SmGetVocWords.

IBM SMAPI Reference


Reply Message Structures and Callbacks

Reply Message Structure Solicited Unsolicited Explanation
SM_AUDIO_LEVEL X Controlled by SmSet
SM_NOTIFY_AUDIO_LEVEL,
this message provides the audio
level data. Data can be extracted
with SmGetAudioLevel.
SM_CANCEL_PLAYBACK_REPLY X Response to an asynchronous
SmCancelPlayback call.
SM_COMMAND_WORD X Controlled by SmSet
SM_NOTIFY_COMMAND_W
ORD, this message provides the
name of the application that
currently has focus as well as the
last recognized input word. The
SmGetFirmWords function
extracts the SM_WORD and the
SmGetApplication function
extracts the application name.
SM_CONNECT_REPLY X Response to an asynchronous
SmConnect call. Data can be
extracted with SmGetEnrollId,
SmGetEnrollIds,
SmGetLanguages,
SmGetMsgType,
SmGetNumberUtterances,
SmGetService, SmGetSessionId,
SmGetTask, SmGetTasks,
SmGetUserId, or SmGetUserIds.
SM_CORRECT_TEXT_REPLY X Response to an asynchronous
SmCorrectText call.
SM_DEFINE_GRAMMAR_REPLY X Response to an asynchronous
SmDefineGrammar call. Data
can be extracted with
SmSetGrammarPath.

IBM ViaVoice SDK for Windows


Reply Message Structures Received from the Speech Recognition Engine

Reply Message Structure Solicited Unsolicited Explanation
SM_DEFINE_VOCAB_REPLY X Response to an asynchronous
SmDefineVocab call. Data can
be extracted with
SmGetVocabName or
SmGetVocWords.
SM_DEFINE_VOCABULARY_REPLY X Response to an asynchronous
SmDefineVocab call. Data can
be extracted with
SmGetVocabName,
SmGetVocWords,
SmGetVocabPath, or
SmGetOptions.
SM_DETACH_SESSIONS_REPLY X Response to an asynchronous
SmDetachSessions call.
SM_DISCARD_DATA_REPLY X Response to an asynchronous
SmDiscardData call.
SM_DISCARD_SPEECH_DATA_REPLY X Response to an asynchronous
SmDiscardSpeechData call.
Data can be extracted with
SmGetFlags or SmGetStatus.
SM_DISCONNECT_REPLY X Response to an asynchronous
SmDisconnect call. Data can be
extracted with SmGetMsgType,
or SmGetService.
SM_ENABLE_VOCAB_REPLY X Response to an asynchronous
SmEnableVocab call. Data can
be extracted with
SmGetVocabName.
SM_ENGINE_STATE X SM_NOTIFY_ENGINE_STATE
is controlled by SmSet and this
message indicates current engine
status and synchronizes the
display and the engine state. The
SmGetEngineState function
extracts the data.

IBM SMAPI Reference


Reply Message Structures and Callbacks

Reply Message Structure Solicited Unsolicited Explanation
SM_EVENT_NOTIFY_REPLY X Response to an asynchronous
SmEventNotify call. Data can be
extracted with SmGetEventId.
SM_EVENT_SYNCH X Notification of an occurrence of
event specified in previous
SmEventNotify. Data can be
extracted with SmGetEventId or
SmGetEventOptions.
SM_FOCUS_GRANTED X Asynchronous notification of
focus granted. Data can be
extracted with SmGetMicState.
SM_FOCUS_LOST X Asynchronous notification of
focus lost.
SM_FOCUS_STATE X Controlled by SmSet
SM_NOTIFY_FOCUS_STATE,
this message shows a change in
focus status and includes the
name of the associated
application. The
SmGetFocusState function
extracts the focus state and the
SmGetApplication function
extracts the application name.
SmGetFocusChangeReason
extracts the focus change reason.
SM_HALT_RECOGNIZER_REPLY X Response to an asynchronous
SmHaltRecognizer call. Data
can be extracted with
SmGetNumberWordMsgs.
SM_MIC_OFF_REPLY X Response to an asynchronous
SmMicOff call.
SM_MIC_ON_REPLY X Response to an asynchronous
SmMicOn call. Data can be
extracted with
SmGetUtteranceNumber.

IBM ViaVoice SDK for Windows


Reply Message Structures Received from the Speech Recognition Engine

Reply Message Structure Solicited Unsolicited Explanation
SM_REQUEST_MIC_OFF X Request to turn off the
microphone.
SM_REQUEST_MIC_ON X Request to turn on the
microphone.
SM_MIC_STATE X Controlled by SmSet
SM_NOTIFY_MIC_STATE,
this message indicated whether
the microphone is on or off. Data
can be extracted with
SmGetMicState.
SM_NEW_CONTEXT_REPLY X Response to an asynchronous
SmNewContext call.
SM_PLAY_MESSAGE_REPLY X Response to an asynchronous
SmPlayMessage call. Assuming a
successful call,
SM_PLAY_MESSAGE_STATUS
reply message structures will follow.
SM_PLAY_MESSAGE_STATUS X Notification of the start and
completion of the audio
playback initiated by an
SmPlayMessage call. Data can
be extracted with
SmGetMsgName or
SmGetStatus.
SM_PLAY_UTTERANCE_REPLY X Response to an asynchronous
SmPlayUtterance call. Assuming
a successful call,
SM_PLAY_UTTERANCE_STA
TUS reply message structures
will follow.
SM_PLAY_UTTERANCE_STATUS X Notification of the start and
completion of the audio
playback initiated by an
SmPlayUtterance call. Data can
be extracted with SmGetStatus
or SmGetUtteranceNumber.

IBM SMAPI Reference


Reply Message Structures and Callbacks

Reply Message Structure Solicited Unsolicited Explanation
SM_PLAY_WORDS_REPLY X Response to an asynchronous
SmPlayWords call. Assuming a
successful call,
SM_PLAY_WORDS_STATUS
reply message structures will
follow.
SM_PLAY_WORDS_STATUS X Notification of the start and
completion of the audio
playback initiated by an
SmPlayWords call. Audio
playback may be for one word or
multiple words. Data can be
extracted with SmGetStatus or
SmGetTags.
SM_QUERY_ADDED_WORDS_REPLY X Response to an asynchronous
SmQueryAddedWords call. Data
can be extracted with
SmGetWords.
SM_QUERY_ALTERNATES_REPLY X Response to an asynchronous
SmQueryAlternates call. Data
can be extracted with
SmGetAlternates or SmGetTags.
SM_QUERY_DEFAULT_REPLY X Response to an asynchronous
SmQueryDefault call. Data can
be extracted with
SmGetEnrollId,
SmGetEnrollIds, SmGetScripts,
SmGetTask, SmGetTasks,
SmGetUserId or SmGetUserIds.
SM_QUERY_ENABLED_VOCABS_REPLY X Response to an asynchronous
SmQueryEnabledVocabs call.
Data can be extracted with
SmGetVocabList.

IBM ViaVoice SDK for Windows


Reply Message Structures Received from the Speech Recognition Engine

Reply Message Structure Solicited Unsolicited Explanation
SM_QUERY_ENROLLIDS_REPLY X Response to an asynchronous
SmQueryEnrollIds call. Data can
be extracted with
SmGetAlphabets,
SmGetDescriptions,
SmGetEnrollIds,
SmGetLanguages,
SmGetPercentages,
SmGetScripts, or SmGetStates.
SM_QUERY_LANGUAGES_REPLY X Response to an asynchronous
SmQueryLanguages call. Data
can be extracted with
SmGetLanguages.
SM_QUERY_PHRASE_ALTERNATIVES_REPLY X Response to an asynchronous
SmQueryPhraseAlternatives
call. Data can be extracted with
SmGetFirmWords,
SmGetVocabName,
SmGetAnnotations,
SmGetWordTimes, and
SmGetPhraseState.
SM_QUERY_PRONUNCIATION_REPLY X Response to an asynchronous
SmQueryPronunciation call.
Data can be extracted with
SmGetSpelling or
SmGetSpellings.
SM_QUERY_PRONUNCIATIONS_REPLY X Response to an asynchronous
SmQueryPronunciationsEx call.
Data can be extracted with
SmGetPronunciations or
SmGetSpellings.
SM_QUERY_REPLY X Response to an asynchronous
SmQuery call. Data can be
extracted with SmGetItemValue.

IBM SMAPI Reference


Reply Message Structures and Callbacks

Reply Message Structure Solicited Unsolicited Explanation
SM_QUERY_SESSIONS_REPLY X Response to an asynchronous
SmQuerySessions call. Data can
be extracted with
SmGetApplications,
SmGetEnrollIds, or
SmGetUserIds.
SM_QUERY_SPEECH_DATA_REPLY X Response to an asynchronous
SmQuerySpeechData call. Data
can be extracted with
SmGetSpeechDataSize.
SM_QUERY_TASKS_REPLY X Response to an asynchronous
SmQueryTasks call. Data can be
extracted with SmGetAlphabets,
SmGetDescriptions,
SmGetLanguages or
SmGetTasks.
SM_QUERY_TOPICS_REPLY X Response to an asynchronous
SmQueryTopics call. Data can
be extracted from SmGetTopics,
SmGetPreferred,
SmGetDescriptions, or
SmGetFlags.
SM_QUERY_USER_DEFAULT_REPLY X Response to an asynchronous
SmQueryUserDefault call. Data
can be extracted with
SmGetUserId, SmGetUserIds,
SmGetEnrollId,
SmGetEnrollIds, SmGetTask,
SmGetTasks, or
SmGetDefaultTopics.
SM_QUERY_USER_INFO_REPLY X Response to an asynchronous
SmQueryUserInfo call. Data can
be extracted with
SmGetEnrollId,
SmGetEnrollIds,
SmGetNameValue,
SmGetUserId, or SmGetUserIds.

IBM ViaVoice SDK for Windows


Reply Message Structures Received from the Speech Recognition Engine

Reply Message Structure Solicited Unsolicited Explanation
SM_QUERY_USERS_REPLY X Response to an asynchronous
SmQueryUsers call. Data can be
extracted with
SmGetDescriptions,
SmGetUserIds, or SmGetUsers.
SM_QUERY_VOCABS_REPLY X Response to an asynchronous
SmQueryVocabs call. Data can
be extracted with
SmGetVocabList.
SM_QUERY_WORD_REPLY X Response to an asynchronous
SmQueryWord call. Data can be
extracted with SmGetVocabList
or SmGetWords.
SM_RECOGNIZED_PHRASE X Includes firm words sent during
grammar vocabulary
recognition. Data can be
extracted with
SmGetFirmWords,
SmGetVocabName,
SmGetPhraseState,
SmGetAnnotations, and
SmGetWordTimes.
SM_RECOGNIZED_TEXT X Includes infirm or firm words or
both sent during dictation
vocabulary recognition. Data can
be extracted with
SmGetFirmWords,
SmGetInfirmWords,
SmGetTimes, and
SmGetWordTimes.
SM_RECOGNIZED_WORD X Includes firm words sent during
command vocabulary
recognition. Data can be
extracted with SmGetAlternates,
SmGetFirmWords, SmGetTimes
and SmGetWordTimes.

IBM SMAPI Reference


Reply Message Structures and Callbacks

Reply Message Structure Solicited Unsolicited Explanation
SM_RECOGNIZE_NEXT_WORD_REPLY X Response to an asynchronous
SmRecognizeNextWord call.
SM_RELEASE_FOCUS X Response to an asynchronous
SmReleaseFocus call.
SM_REMOVE_FROM_VOCAB_REPLY X Response to an asynchronous
SmRemoveFromVocab call.
Data can be extracted with
SmGetVocabName.
SM_REMOVE_PRONUNCIATION_REPLY X Response to an asynchronous
SmRemovePronunciation call.
Data can be extracted with
SmGetSpelling or
SmGetSpellings.
SM_REPORT_ENGINE_ERROR X Notification that the speech
recognition engine has
encountered an error. Data can
be extracted with
SmGetMicState or
SmGetSeverity.
SM_REQUEST_DETACH X Request to detach sessions.
SM_REQUEST_FOCUS X Response to an asynchronous
SmRequestFocus call.
SM_REQUEST_MIC_OFF_REPLY X Response to an asynchronous
SmRequestMicOff call.
SM_REQUEST_MIC_ON_REPLY X Response to an asynchronous
SmRequestMicOn call.
SM_RESTORE_SPEECH_DATA_REPLY X Response to an asynchronous
SmRestoreSpeechData call. Data
can be extracted using
SmGetSpeechDataArchive.

IBM ViaVoice SDK for Windows


Reply Message Structures Received from the Speech Recognition Engine

Reply Message Structure Solicited Unsolicited Explanation
SM_SAVE_SPEECH_DATA_REPLY X Response to an asynchronous
SmSaveSpeechData call. Data
can be extracted using
SmGetSpeechDataArchive,
SmGetSpeechDataOptions, or
SmGetSpeechDataSize.
SM_SET_DEFAULT_REPLY X Response to an asynchronous
SmSetDefault call.
SM_SET_REPLY X Response to an asynchronous
SmSet call. Data can be
extracted with SmGetItemValue.
SM_SET_USER_DEFAULT_REPLY X Response to an asynchronous
SmSetUserDefault call. No data
returned.
SM_SET_USER_INFO_REPLY X Response to an asynchronous
SmSetUserInfo call. Data can be
extracted with SmGetEnrollId,
SmGetEnrollIds, SmGetUserId
or SmGetUserIds.
SM_UNDEFINE_VOCAB_REPLY X Response to an asynchronous
SmUndefineVocab call. Data can
be extracted with
SmGetVocabName.
SM_UTTERANCE_COMPLETED X Notification that speech-to-text
decoding of the audio input
stream has been completed after
the microphone was turned off.
Data can be extracted with
SmGetUtteranceNumber.
SM_WORD_CORRECTION_REPLY X Response to an asynchronous
SmWordCorrection call. Data
can be extracted with
SmGetPronunciations,
SmGetSpellings, SmGetStatus
or SmGetTags.

IBM SMAPI Reference


Reply Message Structures and Callbacks

Callbacks

The following callbacks are available for processing messages from the router and the speech
recognition engine.

Callback Solicited Unsolicited Message Type
SmNautoCompleteCallback X SM_AUTO_COMPLETE_REPLY
SmNaddPronunciationCallback X SM_ADD_PRONUNCIATION_REPLY
SmNaddToVocabCallback X SM_ADD_TO_VOCAB_REPLY
SmNaudioLevelCallback X SM_AUDIO_LEVEL
SmNcancelPlaybackCallback X SM_CANCEL_PLAYBACK_REPLY
SmNcommandWordCallback X SM_COMMAND_WORD
SmNconnectCallback X SM_CONNECT_REPLY
SmNcorrectTextCallback X SM_CORRECT_TEXT_REPLY
SmNcorrectTextCancelCallback X SM_CORRECT_TEXT_CANCEL_REPLY
SmNdefineGrammarCallback X SM_DEFINE_GRAMMAR_REPLY
SmNdefineVocabCallback X SM_DEFINE_VOCAB_REPLY
SmNdefineVocabExCallback X SM_DEFINE_VOCABULARY_REPLY
SmNdetachRequestedCallback X SM_REQUEST_DETACH
SmNdetachSessionsCallback X SM_DETACH_SESSIONS_REPLY
SmNdisableVocabCallback X SM_DISABLE_VOCAB_REPLY
SmNdiscardDataCallback X SM_DISCARD_DATA_REPLY
SmNdiscardSpeechDataCallback X SM_DISCARD_SPEECH_DATA_REPLY
SmNdisconnectCallback X SM_DISCONNECT_REPLY
SmNenableVocabCallback X SM_ENABLE_VOCAB_REPLY
SmNengineStateCallback X SM_ENGINE_STATE
SmNeventNotifyCallback X SM_EVENT_NOTIFY_REPLY
SmNeventSynchCallback X SM_EVENT_SYNCH
SmNfocusGrantedCallback X SM_FOCUS_GRANTED

IBM ViaVoice SDK for Windows


Callbacks

SmNfocusLostCallback X SM_FOCUS_LOST
SmNfocusStateCallback X SM_FOCUS_STATE
SmNhaltRecognizerCallback X SM_HALT_RECOGNIZER_REPLY
SmNmicOffCallback X SM_REQUEST_MIC_OFF
SmNmicOnCallback X SM_REQUEST_MIC_ON
SmNmicOffRequestedCallback X SM_REQUEST_MIC_OFF_REPLY
SmNmicOnRequestedCallback X SM_REQUEST_MIC_ON_REPLY
SmNmicStateCallback X SM_MIC_STATE
SmNnewContextCallback X SM_NEW_CONTEXT_REPLY
SmNplayMessageCallback X SM_PLAY_MESSAGE_REPLY
SmNplayMessageStatusCallback X SM_PLAY_MESSAGE_STATUS
SmNplayUtteranceCallback X SM_PLAY_UTTERANCE_REPLY
SmNplayUtteranceStatusCallback X SM_PLAY_UTTERANCE_STATUS
SmNplayWordsCallback X SM_PLAY_WORDS_REPLY
SmNplayWordsStatusCallback X SM_PLAY_WORDS_STATUS
SmNqueryAddedWordsCallback X SM_QUERY_ADDED_WORDS_REPLY
SmNqueryAddedWordsExCallback X SM_QUERY_ADDED_WORDS_REPLY
SmNqueryAlternatesCallback X SM_QUERY_ALTERNATES_REPLY
SmNqueryCallback X SM_QUERY_REPLY
SmNqueryDefaultCallback X SM_QUERY_DEFAULT_REPLY
SmNqueryEnabledVocabsCallback X SM_QUERY_ENABLED_VOCABS_REPLY
SmNqueryEnrollIdsCallback X SM_QUERY_ENROLLIDS_REPLY
SmNqueryLanguagesCallback X SM_QUERY_LANGUAGES_REPLY
SmNqueryPhraseAlternativesCallbac
k
X SM_QUERY_ADDED_WORDS_REPLY
SmNqueryPronunciationCallback X SM_QUERY_PRONUNCIATION_REPLY
SmNqueryPronunciationsCallback X SM_QUERY_PRONUNCIATIONS_REPLY
SmNqueryPronunciationsExCallback X SM_QUERY_PRONUNCIATIONS_REPLY
SmNquerySessionsCallback X SM_QUERY_SESSIONS_REPLY
SmNquerySpeechDataCallback X SM_QUERY_SPEECH_DATA_REPLY
SmNqueryTasksCallback X SM_QUERY_TASKS_REPLY

IBM SMAPI Reference


Reply Message Structures and Callbacks

SmNqueryTopicsCallback X SM_QUERY_TOPICS_REPLY
SmNqueryUsersCallback X SM_QUERY_USERS_REPLY
SmNqueryUserDefaultCallback X SM_QUERY_USER_DEFAULT_REPLY
SmNqueryUserInfoCallback X SM_QUERY_USER_INFO_REPLY
SmNqueryVocabsCallback X SM_QUERY_VOCABS_REPLY
SmNqueryWordCallback X SM_QUERY_WORD_REPLY
SmNrecognizeNextWordCallback X SM_RECOGNIZE_NEXT_WORD_REPLY
SmNrecognizedPhraseCallback X SM_RECOGNIZED_PHRASE
SmNrecognizedTextCallback X SM_RECOGNIZE_TEXT
SmNrecognizedWordCallback X SM_RECOGNIZE_WORD
SmNreleaseFocusCallback X SM_RELEASE_FOCUS
SmNremoveFromVocabCallback X SM_REMOVE_FROM_VOCAB_REPLY
SmNremovePronunciationCallback X SM_REMOVE_PRONUNCIATION_REPLY
SmNreportEngineErrorCallback X SM_REPORT_ENGINE_ERROR
SmNrequestFocusCallback X SM_REQUEST_FOCUS
SmNrequestMicOffCallback X SM_REQUEST_MIC_OFF_REPLY
SmNrequestMicOnCallback X SM_REQUEST_MIC_ON_REPLY
SmNrestoreSpeechDataCallback X SM_RESTORE_SPEECH_DATA_REPLY
SmNsaveSpeechDataCallback X SM_SAVE_SPEECH_DATA_REPLY
SmNsetCallback X SM_SET_REPLY
SmNsetDefaultCallback X SM_SET_DEFAULT_REPLY
SmNsetUserDefaultCallback X SM_SET_USER_DEFAULT_REPLY
SmNsetUserInfoCallback X SM_SET_USER_INFO_REPLY
SmNundefineVocabCallback X SM_UNDEFINE_VOCAB_REPLY
SmNutteranceCompletedCallback X SM_UTTERANCE_COMPLETED
SmNwordCorrectionCallback X SM_WORD_CORRECTION_REPLY

IBM ViaVoice SDK for Windows


Reply Structure Functions for Unsolicited Callbacks

Reply Structure Functions for Unsolicited Callbacks

The following is a list of all unsolicited callbacks available for processing messages from the speech
recognition engine. Each callback is followed by a list of the reply structure functions that can be
called from within it.

. SmNaudioLevelCallback
. SmGetRc
. SmGetAudioLevel
. SmGetTimes
. SmNcommandWordCallback
. SmGetRc
. SmGetApplication
. SmGetFirmWords
. SmNdetachRequestedCallback
. SmGetRc
. SmNengineStateCallback
. SmGetRc
. SmGetengineState
. SmGetTimes
IBM SMAPI Reference


Reply Message Structures and Callbacks

. SmNeventSynchCallback
. SmGetRc
. SmGetEventId
. SmGetEventOptions
. SmNfocusGrantedCallback
. SmGetRc
. SmNfocusLostCallback
. SmGetRc
. SmNfocusStateCallback
. SmGetRc
. SmGetFocusChangeReason
. SmGetFocusState
. SmGetApplication
. SmNmicOffRequestedCallback
. SmGetRc
. SmNmicOnRequestedCallback
. SmGetRc
. SmNmicStateCallback
. SmGetRc
. SmGetMicState
. SmNplayMessageStatusCallback
. SmGetRc
. SmGetMsgName
. SmGetStatus
IBM ViaVoice SDK for Windows


Reply Structure Functions for Unsolicited Callbacks

. SmNplayUtteranceStatusCallback
. SmGetRc
. SmGetStatus
. SmGetUtteranceNumber
. SmNplayWordsStatusCallback
. SmGetRc
. SmGetStatus
. SmGetTags
. SmNrecognizedPhraseCallback
. SmGetRc
. SmGetAnnotations
. SmGetFirmWords
. SmGetVocabName
. SmGetPhraseState
. SmNrecognizedTextCallback
. SmGetRc
. SmGetFirmWords
. SmGetInfirmWords
. SmGetTimes
. SmNrecognizedWordCallback
. SmGetRc
. SmGetAlternates
. SmGetFirmWords
. SmGetTimes
IBM SMAPI Reference


Reply Message Structures and Callbacks

. SmNreportEngineErrorCallback
. SmGetRc
. SmGetMicState
. SmGetSeverity
. SmNutteranceCompletedCallback
. SmGetRc
. SmGetUtteranceNumber
IBM ViaVoice SDK for Windows


Chapter 6

Data Types

The following data types are used. They are listed in alphabetic order.

caddr_t

Pointer to character-aligned data.

typedef CHAR caddr_t;
SmArg

Speech argument list structure.

typedef struct _SmArg (CHAR name;
SmArgVal value;
) SmArg;
typedef SmArg SmArg;

Fields:

name


Name of speech argument.

value


Value of speech argument if size of argument is less than or equal to size of (long); otherwise, a
pointer to the speech argument value.

IBM SMAPI Reference


Data Types

SmArgVal

Value of speech argument if size of argument is less than or equal to size of (long); otherwise, a
pointer to the speech argument value.

typedef LONG SmArgVal;


SmHandler

Return value from callback-handler function.

typedef INT SmHandler;


IBM ViaVoice SDK for Windows


SM_ANNOTATION

SM_ANNOTATION


Annotation structure.

typedef struct _SM_ANNOTATION (LONG type;
UNION
{
LONG numeric;
CHAR *string;
VOID *other;

 } annodata;
) SM_WORD;
typedef struct _SM_ANNOTATION SM_ANNOTATION;


Fields:

type


The type of annotation.

numeric


Return numeric annotations.

*string


Pointer to a structure in which to return string annotations.

*other


RESERVED.

IBM SMAPI Reference


Data Types

Sm_Msg

Pointer to message between speech recognition engine and application.

typedef VOID SM_MSG;
SM_VOCWORD

Vocabulary word-attribute structure.

typedef struct _SM_VOCWORD (LONG flags;
SHORT spelling_size;
CHAR *spelling;

 ) SM_VOCWORD;
typedef SM_VOCWORD SM_VOCWORD;


Fields:

flags


Reserved for internal use.

spelling_size


Number of chars in word spelling plus one for terminating NULL.

spelling


Word spelling.

IBM ViaVoice SDK for Windows


SM_WORD
SM_WORD

Word-attribute structure.

typedef struct _SM_WORD (LONG tag;
LONG flags;
LONG score;
SHORT spelling_size;
CHAR *spelling;
SHORT vocab_size;
CHAR *vocab;
) SM_WORD;


 typedef SM_WORD SM_WORD;


Fields:

tag


Unique ID defined by speech recognition engine for this word.

flags


Formatting flags for words from predefined vocabularies.

score


Measure of word's probability. The score is relative and can vary from -100 to 100.

spelling_size


Number of chars in word spelling plus one for terminating NULL.

spelling


Word spelling.

vocab_size


Number of chars in vocabulary name plus one for terminating NULL.

vocab


Vocabulary name.

IBM SMAPI Reference


Data Types

IBM ViaVoice SDK for Windows


Chapter 7

SMAPI Attributes

This chapter lists and describes the SMAPI attributes. These attributes describe the current state of
your application's connection with the speech recognition engine (such as session type). You must set
several of the SMAPI attributes when you open and connect to a speech session. You set the values of
these attributes using SmSetArg or SmSesSetArg. When you set arguments, the engine creates an
internal structure to track the state of your session.

Refer to "Programming Tasks" in the SMAPI Developer’s Guide for more information on the use of
SmSetArg.

System Dependent Definition for Argument Lists

typedef long SmArgVal;
typedef struct {
char *name; /* name of the argument */
SmArgVal value; /* value of the argument */
} SmArg;

Argument Attribute List
Application Information Attributes
SmNapplicationName

The name of your speech-aware application. The speech recognition engine will use this attribute
to identify your application to other speech-aware applications.

IBM SMAPI Reference


SMAPI Attributes

Requested Services

SmNresetServices

Set to true to request that the type of session your application has connected to the speech
recognition engine be reset.

SmNdatabase

Set to true to request a database session with the engine.

SmNrecognize

Set to true to request a recognition session with the engine.

Options Flags

SmNdiscardSessionData

Set to true to discard the engine's temporary directory at session close.

SmNdiscardSessionAdaptation

Set to true to discard language model cache updates.

SmNSaveSessionData

Set to true to save the engine's temporary directory at session close.

SmNSaveSessionAdaptation

Set to true to merge the language model updates into persistent storage.

IBM ViaVoice SDK for Windows


Window Handle

SmNwindowHandle

Set to the window handle in your application that will receive all speech-related messages.

User Definition Arguments

SmNaudioHost

Used to initialize a recognition session. It can be set to use default values. Refer to "Overview of
the Custom Audio DLL's" in the SMAPI Developer's Guide for more information.

SmNconnectID

Used to initialize a recognition session. It can be set to use default values. Refer to "Establishing a
Speech Session" in the SMAPI Developer's Guide for more information.

SmNenrollID

Used to initialize a recognition session. It can be set to use default values. Refer to "Establishing a
Speech Session" in the SMAPI Developer's Guide for more information.

SmNnavigator

Used to define a session as the Navigator session. Refer to "Navigator Session" in the SMAPI
Developer's Guide for more information.

SmNtask

Used to initialize a recognition session. It can be set to use default values. Refer to "Establishing a
Speech Session" in the SMAPI Developer's Guide for more information.

IBM SMAPI Reference


SMAPI Attributes

SmNuserID

Used to initialize a recognition session. It can be set to use default values. Refer to "Establishing a
Speech Session" in the SMAPI Developer's Guide for more information.

IBM ViaVoice SDK for Windows


Chapter 8 DMAPI Overview

This chapter describes the format of the Dictation Macro (DMAPI) function calls that are presented in
Chapter 9. "DMAPI Function Calls". It also lists the calls that comprise DMAPI.

Format of the Function Call Descriptions

The description of each function call contains the following information:

Function Name

The name of the function call.

Purpose

The purpose and description of the function call.

Syntax

The syntax of the function as declared in DMAPI.H.

Parameters

Definitions of the parameters.

Return Values

Return values that are set by DMAPI.

For detailed descriptions of DMAPI errors, see “DMAPI Return Codes and Messages” on page 423.

IBM SMAPI Reference


DMAPI Overview

DMAPI Function Calls

The following section lists all of the DMAPI function calls.

. DmClose
. DmFlushEx
. DmFreeMacro
. DmFreeMacroEx
. DmFreeNames
. DmGetGroupsOnPage
. DmGetLastError
. DmGetKey
. DmGetKeyGroup
. DmGetKeyGroupOption
. DmGetKeyGroupOptionSelection
. DmGetLastError
. DmGetMacro
. DmGetMacroEx
. DmGetNumberOfGroups
. DmGetNumberOfOptions
. DmGetNumberOfSelections
. DmGetTemplate
. DmIsNumberFlagged
. DmKeywordFromType
. DmOpen
. DmQueryDelimiters
. DmQueryMacroNames
IBM ViaVoice SDK for Windows


DMAPI Function Calls

. DmQueryTemplateNames
. DmSetAndStoreKey
. DmSetKey
. DmStartMacroEditor
. DmStoreKey
. DmTypeFromKeyword
. DmUpdate
IBM SMAPI Reference


DMAPI Overview

IBM ViaVoice SDK for Windows


Chapter 9 DMAPI Function Calls

This chapter lists and describes the Dictation Macro API (DMAPI) function calls.

DmClose

Purpose

DmClose closes dictation macros for the specified user, domain, and language. It also frees
internally-allocated resources.

Syntax

unsigned long DmClose (DMHANDLE hmac);


Parameters

hmac


input - The DMAPI handle for the set of macros to be closed.

Return Values

DM_ERR_INVALID_HANDLE
DM_ERR_OK


IBM SMAPI Reference


DMAPI Function Calls

DmFlushEx

Purpose
DmFlushEx makes the number filter firm up on stacked data.

Syntax

unsigned long DmFlushEx (DMHANDLE hmac, unsigned short uExpand,
PDM_MACRO_STRUCT *pmac, unsigned long *num);


Parameters

hmac


input - A macro handle.

uExpand


input - One of the following flags:

DM_EXPAND_NONE - No expansion, just returns the text as it is stored.

DM_EXPAND_NORMAL -Expands the macro and all embedded macros with imm_expand set
If the macro itself is a delayed macro, the text will contain the macro name in the form
<MACRO macroname>.
DM_EXPAND_FULL -Expands the macro and all embedded macros no matter how the
imm_expand flags are set.

pmac


output -A pointer to the macro definition of the word was found or NULL in case of error. If
NULL is returned, the return code gives information about the type of error. Use DmFreeMacro
to free memory used by pointers returned by this function.

num


output -Number of pmac structures returned.

Return Values

DM_ERR_OK
DM_ERR_MALLOC


IBM ViaVoice SDK for Windows


DmFreeMacro

DmFreeMacro

Purpose
DmFreeMacro frees memory associated with a macro or template previously obtained by
DmGetMacro or DmGetTemplate.

Syntax

void DmFreeMacro (PDM_MACRO_STRUCT macro);


Parameters

macro


input - A pointer to the macro definition.

Return Values

None

IBM SMAPI Reference


DMAPI Function Calls

DmFreeMacroEx

Purpose
DmFreeMacroEx frees memory of a macro or template previously obtained by DmGetMacro or
DmGetTemplate.

Syntax

void DmFreeMacroEx (PDM_MACRO_STRUCT macro, unsigned long num);


Parameters

macro


input - A pointer to the macro definition.

num


input - Number of macros in the macro. (See DmGetMacroEx)

Return Values

None

IBM ViaVoice SDK for Windows


DmFreeNames

DmFreeNames

Purpose

DmFreeNames frees memory associated with the fields previously allocated by
DmQueryMacroNames or DmQueryTemplateNames.

Syntax

void DmFreeNames (unsigned short number, char **field);


Parameters

number


input - The number of list entries.

field


input - A pointer to a field of strings that contains the names of macros or templates.

Return Values

None

IBM SMAPI Reference


DMAPI Function Calls

DmGetGroupsOnPage

Purpose
DmGetGroupsOnPage returns the number of groups to display per options page.

Syntax

unsigned long DmGetGroupsOnPage (DMHANDLE hmac, int *page1, int *page2,
int *page3);


Parameters

hmac


input - A macro handle.

page 1 to page 3


output - The number of groups to display on the Options page n, if all are 0, do not show an options
panel at all.

Return Values

DM_ERR_OK


IBM ViaVoice SDK for Windows


DmGetKey

DmGetKey

Purpose

DmGetKey queries the number filter for this value to a key.

Syntax

unsigned long DmGetKey (DMHANDLE hmac, char *key, char **value,
unsigned long *num);


Parameters

hmac


input - The macro handle.

key


input - The key.

value


output - The value.

num


output - The number of values returned.

Return Values

DM_ERR_OK
DM_ERR_MALLOC
DM_ERR_INVALID_KEYWORD


IBM SMAPI Reference


DMAPI Function Calls

DmGetKeyGroup

Purpose

DmGetKeyGroup returns the string to display for a given group number.

Syntax

unsigned long DmGetKeyGroup (DMHANDLE hmac, int group,
char **display_string);


Parameters

hmac


input - The macro handle.

group


input - The group number for which the display_string should be returned.

display_string


output -The ANSI string to display on the Options panel.

Return Values

DM_ERR_OK
DM_ERR_INVALID_KEYWORD


IBM ViaVoice SDK for Windows


DmGetKeyGroupOption

DmGetKeyGroupOption

Purpose

DmGetKeyGroupOption returns the string to display for a given group number/option.

Syntax

unsigned long DmGetKeyGroupOption (DMHANDLE hmac, int group, int option,
char **display_string);


Parameters

hmac


input - The macro handle.

group


input - The group number for which the display_string should be returned.

option


input - The option number for which the display_string should be returned.

display_string


output -The ANSI string to display on the Options panel.

Return Values

DM_ERR_OK
DM_ERR_INVALID_KEYWORD


IBM SMAPI Reference


DMAPI Function Calls

DmGetKeyGroupOptionSelection

Purpose

DmGetKeyGroupOptionSelection returns the string to display for a given group number/option/
selection.

Syntax

unsigned long DmGetKeyGroupOptionSelection (DMHANDLE hmac, int group,
int option, int selection, char **display_string);


Parameters

hmac


input - The macro handle.

group


input - The group number for which the display_string should be returned.

option


input - The option number for which the display_string should be returned.

selection


input - The selection number for which the display_string should be returned.

display_string


output -The ANSI string to display on the Options panel.

Return Values

DM_ERR_OK
DM_ERR_INVALID_KEYWORD


IBM ViaVoice SDK for Windows


DmGetLastError

DmGetLastError

Purpose

DmGetLastError returns additional information about the last error. This call does not change the
internally-stored error information.
DmGetLastError uses a DMERROR structure which contains the following information:
errbuf->errno
The DM_ERR_... value of the last error.
errbuf->string
Additional information about the last error:


DM_ERR_ACT_FILE_PARSE line number
DM_ERR_BAD_EXE_FORMAT file name
DM_ERR_DUPLICATE_MACRO macro name
DM_ERR_EACCESS file name
DM_ERR_EBADF file name
DM_ERR_EMFILE file name
DM_ERR_ENOENT file name
DM_ERR_EXPDLL_LOAD_FAILED DLL name
DM_ERR_EXPDLL_QUERYFUN_FAILED function name
DM_ERR_FILE_READ file name
DM_ERR_INVALID_DOMAIN domain name
DM_ERR_INVALID_LANGUAGE language code
DM_ERR_INVALID_MACRORELEASE release number
DM_ERR_INVALID_MACROVERSION version number
DM_ERR_INVALID_USERID user ID
DM_ERR_LOAD_RESOURCE_DLL name of DLL
DM_ERR_MACRO_NOT_FOUND macro name
DM_ERR_TEMPLATE_NOT_FOUND template name
DM_ERR_UNDEFINED file name


Syntax

void DmGetLastError (PDMERROR errbuf);


Parameters

errbuf


IBM SMAPI Reference


DMAPI Function Calls

output - A pointer to a DMERROR structure.

Return Values

None

IBM ViaVoice SDK for Windows


DmGetMacro

DmGetMacro

Purpose

DmGetMacro gets a macro definition from the current set of macros.

Syntax

unsigned long DmGetMacro(DMHANDLE hmac, char *word, unsigned short uExpand,
PDM_MACRO_STRUCT *pmac);


Parameters

hmac


input - The macro handle.

word


input -The name of the macro.

uExpand


input - The type of expansion to be performed, which can be one of the following:

DM_EXPAND_NONE - The macro should not be expanded, only the text as it is stored will be
returned.
DM_EXPAND_NORMAL -The macro and all embedded macros with imm_expand set to
TRUE will be expanded. Delayed macros will not be expanded. If the macro itself is a delayed
macro, the text will contain the macro name in the form <MACRO macroname>.
DM_EXPAND_FULL - The macro and all embedded macros (regardless of the value of
imm_expand) will be expanded.

pmac


output - If the word was found, a pointer to the macro definition; otherwise, it will be set to NULL.
If NULL is returned, the return code gives information about the type of error. Use DmFreeMacro
to free memory used by pointers returned by this function.

IBM SMAPI Reference


DMAPI Function Calls

Return Values

DM_ERR_EXPDLL_ERR
DM_ERR_EXPDLL_LOAD_FAILED
DM_ERR_EXPDLL_QUERYFUN_FAILED
DM_ERR_EXPDLL_TIMEOUT
DM_ERR_INVALID_HANDLE
DM_ERR_MACRO_NOT_FOUND
DM_ERR_MALLOC
DM_ERR_OK
DM_ERR_SYSTEM_PARM_LONG


IBM ViaVoice SDK for Windows


DmGetMacroEx

DmGetMacroEx

Purpose

DmGetMacroEx gets a macro definition from the current set of macros.

Syntax

unsigned long DmGetMacroEx (DMHANDLE hmac, char *word, char *soundslike,
unsigned long flags, unsigned long tag, unsigned short uExpand,
PDM_MACRO_STRUCT *pmac);


Parameters

hmac


input - The macro handle.

word


input -The name of the macro.

soundslike


input - The soundslike field for spellout function.

flags


input -The number and other flags.

uExpand


input - The type of expansion to be performed, which can be one of the following:

DM_EXPAND_NONE - The macro should not be expanded, only the text as it is stored will
be returned.
DM_EXPAND_NORMAL -The macro and all embedded macros with imm_expand set to
TRUE will be expanded. Delayed macros will not be expanded. If the macro itself is a delayed
macro, the text will contain the macro name in the form <MACRO macroname>.
DM_EXPAND_FULL - The macro and all embedded macros (regardless of the value of
imm_expand) will be expanded.

pmac


output - If the word was found, a pointer to the macro definition; otherwise, it will be set to NULL.
If NULL is returned, the return code gives information about the type of error. Use DmFreeMacro
to free memory used by pointers returned by this function.

IBM SMAPI Reference


DMAPI Function Calls

Return Values

DM_ERR_EXPDLL_ERR
DM_ERR_EXPDLL_LOAD_FAILED
DM_ERR_EXPDLL_QUERYFUN_FAILED
DM_ERR_EXPDLL_TIMEOUT
DM_ERR_INVALID_HANDLE
DM_ERR_MACRO_NOT_FOUND
DM_ERR_MALLOC
DM_ERR_OK
DM_ERR_SYSTEM_PARM_LONG


IBM ViaVoice SDK for Windows


DmGetNumberOfGroups

DmGetNumberOfGroups

Purpose

DmGetNumberOfGroups returns the number of groups for display in the Options panel.
Syntax

unsigned long DmGetNumberOfGroups (DMHANDLE hmac);


Parameters

hmac


input - The macro handle.

Return Values

0 - When no groups are found.
>0 - Represents the number of groups found.


IBM SMAPI Reference


DMAPI Function Calls

DmGetNumberOfOptions

Purpose

DmGetNumberOfOptions returns the number of options for display in the Options panel.

Syntax

unsigned long DmGetNumberOfOptions (DMHANDLE hmac, int group);


Parameters

hmac


input - The macro handle.

group


input - The group number for which the options should be returned.

Return Values

0 - When no options are found.
>0 - Represents the number of options found.


IBM ViaVoice SDK for Windows


DmGetNumberOfSelections

DmGetNumberOfSelections

Purpose

DmGetNumberOfSelections returns the number of selections for display in the Options panel.

Syntax

unsigned long DmGetNumberOfSelections (DMHANDLE hmac, int group,
int option);


Parameters

hmac


input - The macro handle.

group


input -The group number for which the selection should be returned.

option


input - The option number for which the selection should be returned.

Return Values

0 - When no selections are found.
>0 - Represents the number of selections found.


IBM SMAPI Reference


DMAPI Function Calls

DmGetTemplate

Purpose

DmGetTemplate gets a template definition from the current set of templates.

Syntax

unsigned long DmGetTemplate (DMHANDLE hmac, char *word,
unsigned short uExpand, PDM_MACRO_STRUCT *pmac);


Parameters

hmac


Input -The DMAPI handle for the current set of templates.

word


input -The name of the template.

uExpand


input - The type of expansion to be performed, which can be one of the following:

DM_EXPAND_NONE - The template should not be expanded, only the text as it stored will
be returned.
DM_EXPAND_NORMAL -The template and all embedded macros with imm_expand set
to TRUE will be expanded. Delayed macros will not be expanded.
DM_EXPAND_FULL -The template and all embedded macros (regardless of the value of
imm_expand) will be expanded.

pmac


output - If the word was found, a pointer to the template definition; otherwise, it will be set to
NULL. If NULL is returned, the return code gives information about the type of error. Use
DmFreeMacro to free memory used by pointers returned by this function.

IBM ViaVoice SDK for Windows


DmGetTemplate

Return Values

DM_ERR_EXPDLL_ERR
DM_ERR_EXPDLL_LOAD_FAILED
DM_ERR_EXPDLL_QUERYFUN_FAILED
DM_ERR_EXPDLL_TIMEOUT
DM_ERR_INVALID_HANDLE
DM_ERR_MALLOC
DM_ERR_OK
DM_ERR_SYSTEM_PARM_LONG
DM_ERR_TEMPLATE_NOT_FOUND


IBM SMAPI Reference


DMAPI Function Calls

DmIsNumberFlagged

Purpose
DmIsNumberFlagged returns !=0 if the flag is a number flag.

Syntax

unsigned long DmIsNumberFlagged (unsigned long flags);


Parameters

flags


input - The flag returned from the speech engine.

Return Values

0 - Not flagged as a number
>0 - Bits 0-11 contain the number flags


IBM ViaVoice SDK for Windows


DmKeywordFromType

DmKeywordFromType

Purpose
DmKeywordFromType gets the keywords used by the Dictation Macro Editor.

Syntax

unsigned long DmKeyWordFromType (DMHANDLE dmac, unsigned short type,
char **keyword);


Parameters

dmac


input - The macro handle.

type


input - The type from which to get the keyword, which can be one of the KEYBOARD_xx found
below:

KEYWORD_INVALID 0
KEYWORD_NONE 1
KEYWORD_DAYOFWEEK 2
KEYWORD_DATE 3
KEYWORD_TIME 4
KEYWORD_DAY 5
KEYWORD_DAYORDINAL 6
KEYWORD_MONTHOFYEAR 7
KEYWORD_MONTHSHORT 8
KEYWORD_MONTH 9
KEYWORD_YEAR 10
KEYWORD_YEARSHORT 11
KEYWORD_MSGSTRING 14
KEYWORD_DLLCALL 15
KEYWORD_DLLSTRING 16
KEYWORD_SYSTEM 17
KEYWORD_MACRO 18


keyword


The keyword of the input type. The language of the keyword depends on the language associated
with the macro handle.

IBM SMAPI Reference


DMAPI Function Calls

Return Values

DM_ERR_INVALID_KEYTYPE
DM_ERR_OK


IBM ViaVoice SDK for Windows


DmOpen

DmOpen

Purpose
DmOpen opens dictation macros for the specified user, domain, and language.

Syntax

unsigned long DmOpen (void *init, char *username, char *domain, char *lang,
PDMHANDLE hmac);


Parameters

init


input - This parameter is RESERVED and must be set to NULL.

username


input - The user name (5-char. code) for which the macros should be initialized.

domain


input - The domain (5-char. code) for which the macros should be initialized.

lang


input - The language (5-char. code) for which the macros should be initialized. This code should be
retrieved from the speech recognition engine.

hmac


output - The Dictation Macro Editor specific handle which is needed for further calls for this set of
macros.

Return Values

DM_ERR_DUPLICATE_MACRO
DM_ERR_EACCESS
DM_ERR_EBADF
DM_ERR_EMFILE
DM_ERR_ENOENT
DM_ERR_INVALID_DOMAIN
DM_ERR_INVALID_LANGUAGE
DM_ERR_INVALID_MACRO
DM_ERR_INVALID_MACROFILE
DM_ERR_INVALID_USERID


IBM SMAPI Reference


DMAPI Function Calls

DM_ERR_LOAD_RESOURCE_DLL
DM_ERR_MALLOC
DM_ERR_NOTIFY_EXCEEDED
DM_ERR_OK
DM_ERR_UNDEFINED


IBM ViaVoice SDK for Windows


DmQueryDelimiters

DmQueryDelimiters

Purpose

DmQueryDelimiters requests the keyword and template field delimiters used by the Dictation
Macro Editor.

Syntax

void DmQueryDelimiters (unsigned char *FieldStart,
unsigned char *FieldEnd, unsigned char *KeywordStart,
unsigned char *KeywordEnd, unsigned char *EscapeChar);


Parameters

FieldStart


output - The character which indicates the start of a field.

FieldEnd


output - The character which indicates the end of a field.

KeywordStart


output - The character which indicates the start of a keyword.

KeywordEnd


output - The character which indicates the end of a keyword.

EscapeChar


output - The character which indicates the escape character.

Return Values

None

IBM SMAPI Reference


DMAPI Function Calls

DmQueryMacroNames

Purpose
DmQueryMacroNames requests a list of the names of all available dictation macros.
Use DmFreeNames to free memory used by the field returned by this function.

Syntax

unsigned long DmQueryMacroNames (DMHANDLE hmac, unsigned short *number,
char ***names);


Parameters

hmac


input - The macro handle.

number


output - The number of entries in the list.

names

output - A pointer to a field of string pointers containing the names of the macros. If the number of
macros is 0, this pointer is set to NULL.

Return Values

DM_ERR_INVALID_HANDLE
DM_ERR_MALLOC
DM_ERR_OK


IBM ViaVoice SDK for Windows


DmQueryTemplateNames

DmQueryTemplateNames

Purpose
DmQueryTemplateNames requests a list of the names of all available dictation templates.
Use DmFreeNames to free memory used by the field returned by this function.

Syntax

unsigned long DmQueryTemplateNames(DMHANDLE hmac, unsigned short * number,
char ***names);


Parameters

hmac


input - The handle for the current set of templates.

number


output - The number of entries in the list.

names


output - A pointer to a field of string pointers containing the names of the templates. If the number
of templates is 0, this pointer is set to NULL.

Return Values

DM_ERR_INVALID_HANDLE
DM_ERR_MALLOC
DM_ERR_OK


IBM SMAPI Reference


DMAPI Function Calls

DmQuerySetAndStoreKey

Purpose

DmQuerySetAndStoreKey sets the current session and stores for future use the given value to the
given key.

Syntax

unsigned long DmQuerySetAndStoreKey(DMHANDLE hmac, char *key, char *value);


Parameters

key


input -The number dictation key.

value


input - The value associated to the key.

Return Values

DM_ERR_INVALID_KEYWORD
DM_ERR_OK


IBM ViaVoice SDK for Windows


DmSetKey

DmSetKey

Purpose
DmSetKey sets the key for the current session only.

Syntax

unsigned long DmSetKey (DMHANDLE hmac, char *key, char *value);


Parameters

hmac


input - The macro handle.

key


input -The number dictation key.

value


input - The value associated to the key.

Return Values

DM_ERR_INVALID_KEYWORD
DM_ERR_OK


IBM SMAPI Reference


DMAPI Function Calls

DmStartMacroEditor

Purpose

DmStartMacroEditor starts the Dictation Macro Editor. If the Dictation Macro Editor is already
running, DmStartMacroEditor switches focus to the already-running Dictation Macro Editor.

Syntax

unsigned long DmStartMacroEditor (char *lang);


Parameters

lang


input -The language for which the Dictation Macro Editor should be started.

Return Values

DM_ERR_BAD_EXE_FORMAT
DM_ERR_ENOENT
DM_ERR_OK
DM_ERR_OUT_OF_SYSTEM_RES


IBM ViaVoice SDK for Windows


DmStoreKey

DmStoreKey

Purpose
DmStoreKey stores the given value to the given key for future use.

Syntax

unsigned long DmStoreKey (DMHANDLE hmac, char *key, char *value);


Parameters

hmac


input - The macro handle.

key


input -The number dictation key.

value


input - The value associated to the key.

Return Values

DM_ERR_INVALID_KEYWORD
DM_ERR_OK


IBM SMAPI Reference


DMAPI Function Calls

DmTypeFromKeyword

Purpose
DmTypeFromKeyword returns the type constant of the specified keyword.

Syntax

unsigned long DmTypeFromKeyword (DMHANDLE dmac, char *keyword,
unsigned short *type);


Parameters

dmac


input - The handle for the current set of macros.

keyword


input - The keyword from which to get the type. The keyword depends on the language associated
with the macro handle.

type


output - The type of the keyword, which can be one of the following:

KEYWORD_INVALID 0
KEYWORD_NONE 1
KEYWORD_DAYOFWEEK 2
KEYWORD_DATE 3
KEYWORD_TIME 4
KEYWORD_DAY 5
KEYWORD_DAYORDINAL 6
KEYWORD_MONTHOFYEAR 7
KEYWORD_MONTHSHORT 8
KEYWORD_MONTH 9
KEYWORD_YEAR 10
KEYWORD_YEARSHORT 11
KEYWORD_MSGSTRING 14
KEYWORD_DLLCALL 15
KEYWORD_DLLSTRING 16
KEYWORD_SYSTEM 17
KEYWORD_MACRO 18

IBM ViaVoice SDK for Windows


DmTypeFromKeyword

Return Values

DM_ERR_INVALID_KEYWORD
DM_ERR_OK


IBM SMAPI Reference


DMAPI Function Calls

DmUpdate

Purpose

DmUpdate updates the loaded macro database with all changes that have been made to macros or
templates since the last time DmUpdate was called.

Syntax

unsigned long DmUpdate (DMHANDLE hmac, int reserved1, int reserved2);


Parameters

hmac


input - The DME handle for the macro database to be updated.

reserved1


input - RESERVED parameter - must be set to 0.

reserved2


input - RESERVED parameter - must be set to 0.

Return Values

DM_ERR_DUPLICATE_MACRO
DM_ERR_EACCESS
DM_ERR_EBADF
DM_ERR_EMFILE
DM_ERR_ENOENT
DM_ERR_INVALID_HANDLE
DM_ERR_INVALID_MACRO
DM_ERR_INVALID_MACROFILE
DM_ERR_NOUPDATE
DM_ERR_OK
DM_ERR_UNDEFINED


IBM ViaVoice SDK for Windows


Chapter 10

Data Types

The following data types are used by DMAPI. They are listed in alphabetic order.

DMERROR

Error structure returned by DmGetLastError.

typedef struct
{
ULONG errorcode;
UCHAR string[DM_MAX_ERROR_LEN+1];
} DMERROR, *PDMERROR;


 Fields:

errorcode


DMAPI error code.

string


Additional information based on error code.

IBM SMAPI Reference


Data Types

DM_MACRO_STRUCT

Macro structure.

DM_MACRO_STRUCT is used for both "normal" macro definitions and templates. For macros,
numfield is always set to 0 and fields is always NULL. For templates, numfield is greater than 0
and fields points to the field definition(s). Additionally, imm_expand is ignored for templates,
since templates are always expanded immediately.

typedef struct
{
ULONG type;
PCHAR name;
PCHAR text;
PCHAR desc;
CHAR domain[MAX_DOMAIN_LEN];
ULONG joinleft;
ULONG joinright;
ULONG joindigit;
ULONG casing;
ULONG imm_expand;
ULONG numfield;
PDM_TEMPLATE_FIELD *fields;
ULONG affect;

} DM_MACRO_STRUCT, *PDM_MACRO_STRUCT;


Fields:

type


Type of macro (DM_MACTYPE_MACRO or DM_MACTYPE_TEMPLATE)

name


Word to activate macro.

text


Macro text.

IBM ViaVoice SDK for Windows


DM_MACRO_STRUCT

desc


Template description.

domain


Domain name (length is 0 if this is a global macro).

joinleft


Formatting flag: Join to previous word.

joinright


Formatting flag: Join to next word.

joindigit


Formatting flag: Join digits.

casing


Casing of next word (DM_CASE_NONE, DM_CASE_CAPITAL, DM_CASE_UPPERCASE,
DM_CASE_LOWERCASE)

imm_expand


Expand immediately (always TRUE for templates).

numfield


Number of fields (only valid for templates).

fields


Template fields.

affect


TRUE for macros that should be affected by macros (such as "italian 1").

IBM SMAPI Reference


Data Types

DM_TEMPLATE_FIELD


Template field structure.

typedef struct


{
ULONG type;
PCHAR prompt;
PCHAR defaulttext;
ULONG position;
ULONG numsel;
PCHAR *selword;

} DM_TEMPLATE_FIELD, *PDM_TEMPLATE_FIELD;


Fields:

type


Type of field (DM_FLDTYP_TEXT, DM_FLDTYP_SPELL, DM_FLDTYP_DIGIT,
DM_FLDTYP_SELECTION).

prompt


Prompt text for field.

defaulttext


Default text of the field.

position


Position within text.

numsel


Number of selection words if type=DM_FLDTYP_SELECTION.

selword


Field of selection words.

IBM ViaVoice SDK for Windows


Chapter 11 SMAPI Grammar Compiler API
Overview

This chapter describes the format of the Grammar Compiler API function calls that are presented in
Chapter 12. "Grammar Compiler API Function Calls". It also lists the calls that are provided by the
Grammar Compiler DLL (VTBNFC31.DLL).

Format of the Function Call Descriptions

The description of each function call contains the following information:

Function Name

The name of the function call.

Purpose

The purpose and description of the function call.

Syntax

The syntax of the function as declared in VTBNFC.H.

Parameters

Definitions of the parameters.

Return Values

Return values that are set by the Grammar Compiler DLL.

IBM SMAPI Reference


SMAPI Grammar Compiler API Overview

Grammar Compiler API Function Calls

The following function calls are provided as part of the Grammar Compiler DLL:

. VtAddArg
. VtCompileGrammar
. VtGetMessage
. VtSetArg
IBM ViaVoice SDK for Windows


Chapter 12 SMAPI Grammar Compiler API
Function Calls

This chapter lists and describes the SMAPI Grammar Compiler API function calls.

VtAddArg

Purpose

VtAddArg is a macro that adds an argument with the specified attributes to the end of a VtArg
structure. This function sets the components of the arg parameter. The pointer to arg or to a list of
similarly created arguments can then be passed to VtCompileGrammar. VtAddArg increments
an index to point to the last argument in the argument list.

For further information on using the VtArg data structure, see “Data Types” on page 363.

Syntax

void VtAddArg (VtArg arg, long index, char *name, long value);


Parameters

arg


input - The argument.

index


output -The index into the argument structure. VtAddArg increments the index by one.

name


input -The name of the attribute.

value


input - The value of the attribute.

Return Values

None.

IBM SMAPI Reference


SMAPI Grammar Compiler API Function Calls

VtCompileGrammar

Purpose

VtCompileGrammar compiles a BNF file and produces an FSG using the specified parameters.
The Grammar Compiler parameters are provided by setting up an argument list (VtArg). For more
information on creating and using the VtArg structure, see “Data Types” on page 363.

Syntax

int VtCompileGrammar (int nargs, VtArg *args);


Parameters

nargs


input -The number of arguments in the argument list.

args


input - The pointer to an argument structure that indicates the Grammar Compiler parameters to be
used.

Return Values

 - Successful.
Other - Use VtGetMessage to obtain more detailed error information.
IBM ViaVoice SDK for Windows


VtAddArg

VtGetMessage

Purpose

VtGetMessage returns a pointer to a message string that describes the errors encountered during
the last VtCompileGrammar call that returned a non-zero error code.

The messages returned by VtGetMessage are exactly the same messages (errors and warnings)
that are generated by the Grammar Compiler and can be used to determine the cause of the errors
and appropriate action to be taken by the application.

Syntax

int VtGetMessage(char **message);


Parameters

message


input - The pointer to a character string which holds the error information.

Return Values

None.

IBM SMAPI Reference


SMAPI Grammar Compiler API Function Calls

VtGetTranslation

Purpose

VtCompileGrammar gets a translation for a phrase contained in the “words” parameter
according to the FSG file referred to by the “fsg” parameter.

Syntax

int VtGetTranslation (void *fsg, char **words, char **translation);


Parameters

fsg


input - The pointer to an FST file loaded by VtLoadFSG.

words


input - The pointer to a NULL-terminated array of pointers to words that you supply.

translation


input - The pointer to a character pointer that will hold the translation returned by

VtGetTranslation.

Return Values

 - Successful.
Other - Use VtGetMessage to obtain more detailed error information.
IBM ViaVoice SDK for Windows


VtAddArg

Example

char *name = // name of your .fsg file
void *fsg;
int rc = VtLoadFSG(name, &fsg);
char *translation;
int n = // number of words
char **words = new char*[n+1];
for (int i=0; i<n; i++)


 words[i] = // assign the ith word
words[n] = NULL;
rc = VtGetTranslation(fsg, words, &translation);
printf("translation is '%s'/n", translation);
rc = VtUnloadFSG(fsg);


IBM SMAPI Reference


SMAPI Grammar Compiler API Function Calls

VtLoadFSG

Purpose

VtLoadFSG loads an FSG or FST file produced by the command-line compiler VTBNFC.EXE,
or by the compiler API VtCompileGrammar. After loading a grammar with VtLoadFSG, you
may use VtGetTranslation to get translations for recognized phrases returned by the ViaVoice
recognition engine.

Syntax

int VtLoadFSG (char *name, voice **fsg);


Parameters

name


input - The file name of the FST or FSG file you want to load.

fsg


input - The pointer to a void* to receive the loaded grammar.

Return Values

 - Successful.
Other - Use VtGetMessage to obtain more detailed error information.
IBM ViaVoice SDK for Windows


VtAddArg

VtSethArg

Purpose
VtSetArg is a macro that fills a VtArg structure with the specified attributes.
This function sets the components of the arg parameter. The pointer to arg or to a list of similarly

created arguments can then be passed to VtCompileGrammar.
For further information on using the VtArg data type, see “Data Types” on page 363.


Syntax

void VtSetArg (VtArg arg, char *name, long value);


Parameters

arg


input - The argument.

name
input -The name of the attribute.

value


input - The value of the attribute.

Return Values

None.

IBM SMAPI Reference


SMAPI Grammar Compiler API Function Calls

VtUnloadFSG

Purpose

VtUnloadFSG unloads an FSG or FST file that was previously loaded by VtLoadFSG.
Syntax

void VtUnloadFSG (void *fsg);


Parameters

fsg


input - The pointer to an FST loaded by VtLoadFSG.
Return Values

 - Successful.
Other - Use VtGetMessage to obtain more detailed error information.
IBM ViaVoice SDK for Windows


Chapter 13

Data Types

The following data type is used by the SMAPI Grammar Compiler APIs:

VtArg

Argument structure for VtCompileGrammar.

typedef struct {
char *name;
long value;
} VtArg;


Fields:

name


Name of a VtCompileGrammar argument.

value


Value of the VtCompileGrammar argument if the size of the argument is less than or equal to the
size of (long); otherwise, a pointer to the VtCompileGrammar argument value.

VtArg is analogous to SmArg in SMAPI.; therefore, VtSetArg is analogous to SmSetArg.
Possible arguments for VtSetArg (and VtAddArg) are:

VtNbnfFile -The input BNF file.

VtfsgFile - The output FSG file. This is equivalent to -o on the command line.

VtNfsgDirectory -The output directory for multiple roots. This is equivalent to the -d

parameter on the command line.

VtNequalizeArcProbabilities - The non-uniform probability computation. When set to 1, arc
probabilities are equalized. (This is the default if not specified.) When set to 0, arc
probabilities are not equalized. This argument is equivalent to the -n parameter on the
command line.

IBM SMAPI Reference


Data Types

VtNfsgFlags -SmDefineGrammar flags. The possible flag values are:

 SM_PHRASE_ALLOW_SILENCES, SM_PHRASE_SHOW_SILENCES,
SM_PHRASE_NO_SILENCES, SM_PHRASE_ALLOW_INSERTIONS,
SM_PHRASE_SHOW_INSERTIONS, SM_PHRASE_NO_INSERTIONS.

VtNtrMode is specified with a parameter value of 1. It is used to compile grammars that
contain translations to produce an FST file for use by VtLoadFSG. It is equivalent to the “-tr”
for the VTBNFC.EXE command-line compiler.

VtNenMode is specified with a parameter value of 1. It is used to compile grammars that
contain translations to produce an FSG file for use by the engine (SmDefineGrammar). It is
equivalent to the “-en” for the VTBNFC.EXE command-line compiler.

Note:
For more information on command line parameters, refer to "Grammar Compiler" in the IBM
SMAPI Developer's Guide.

IBM ViaVoice SDK for Windows


The following example illustrates how to fill in a VtArg structure before calling VtCompileGrammar
and how to use VtGetMessage if the return from VtCompileGrammar is not equal to zero:

int n = 0;
VtArg args[10];
VtAddArg( args, n, VtNbnfFile, "mygrammar.bnf" );
VtAddArg( args, n, VtNfsgFlags, SM_PHRASE_SHOW_SILENCES |


SM_PHRASE_ALLOW_INSERTIONS);
// Additional parameters specified by additional VtAddArg calls
int rc = VtCompileGrammar( n, args );
if ( rc !=0 )
{


 char *message;
VtGetMessage( &message );
printf( message );


}


Figure 1. Using VtAddArg, VtCompileGrammar, and VtGetMessage

IBM SMAPI Reference


Data Types

IBM ViaVoice SDK for Windows


Chapter 14 VtGeneratePronunciations

This chapter describes the VtGeneratePronunciations API, which is included with the ViaVoice SDK
to enable the unlimited vocabulary capability for SMAPI applications. VtGeneratePronunciations is
provided as a separate DLL (UVOCAB.DLL) which must be included with any application that uses
the function.

Note:

The unlimited vocabulary capability uses the SAPI interface to the text-to-speech engine. As a
result, SMAPI applications that incorporate the VtGeneratePronunciations call must also include
the Microsoft Speech API (SAPI) redistributable files for this function to work. These files are
available from Microsoft.

For more information on the unlimited vocabulary capability, refer to the SMAPI Developer's Guide.

VtGeneratePronunciations

Purpose

VtGeneratePronunciations adds pronunciations for words returned by SmDefineVocab and
SmDefineGrammar that do not have pronunciations in the engine. The baseform pronunciations
that VtGeneratePronuncation builds are obtained from the text-to-speech engine dictionaries,
and are placed in the engine's temporary pronunciation pools.

This function returns TRUE if pronunciations for all words in the list are added to the engine. It
returns FALSE if one or more words failed in phonetization or in being added to the engine. With a
return code of FALSE, an application can reissue SmDefineVocab or SmDefineGrammar to
obtain the list of words that could not be added, if required.

The following restriction applies when calling VtGeneratePronunciations:

. The speech recognition engine must be halted.
IBM SMAPI Reference


VtGeneratePronunciations

Notes:

1.
SmDefineGrammar always fails on one or more missing words. SmDefineVocab will
succeed, even if all words are missing. An application will need to undefine a dynamic
vocabulary before reissuing the SmDefineVocab call to find the list of failed phonetizations.
2.
Users of this function should adhere to the rules and restrictions that COM places on outgoing
calls while handling messages from another process. In particular, this function should not be
called from a message handler while handling a SendMessage that was generated by another
process.
Syntax

BOOL VtGeneratePronunciations (SmSesId session_id, unsigned long nmissing,
SM_VOCWORD *missing);


Parameters

session_id


input - An open SMAPI session ID, returned by SmSesOpen.

Note: Applications using SmOpen do not have explicit access to the session ID; in this case,
specify a default value of 0.

nmissing


input - The number of words missing pronunciations, returned by SmGetVocWords. Limited to
SM_MAX_VOCWORDS.

missing


input - The pointer to an array of SM_VOCWORDS, returned by SmGetVocWords.

Return Values

TRUE -If all words are added to the engine.

FALSE - If one or more words failed in phonetization or in being added to the engine.

IBM ViaVoice SDK for Windows


Appendix A SMAPI Return Codes, Messages,
and Message Types

The return codes and messages, defined in SMRC.H, and the message types, defined in SMCOMM.H,
are generated by the SMAPI.

SMAPI Return Codes and Messages

The following list contains the return code values in numeric order for the SMAPI.

 -28 SM_API_RC_MIN_NAMES
-27 SM_RC_ATTACH_MUTEX_SEM_FAILED
-26 SM_RC_CREATE_MUTEX_SEM_FAILED
-25 SM_RC_OPEN_QUEUE_FAILED
-24 SM_RC_SUB_UNSET_ERROR
-23 SM_RC_CLOSE_EVENT_SEM_FAILED
-22 SM_RC_FREE_MEM_ERROR
-21 SM_RC_QUEUE_CLOSE_ERROR
-20 SM_RC_DEALLOCATING_SH_MEM
-19 SM_RC_ASSOC_EVENT_SEM_FAILED
-18 SM_RC_CREATE_EVENT_SEM_FAILED
-17 SM_RC_CREATE_MBOX_FAILED
-16 SM_RC_EALLBUSY
-15 SM_RC_ENOACCEPT
-14 SM_RC_EBADAPPNAME
-13 SM_RC_EALLOC
-12 SM_RC_ENOMEM
-11 SM_RC_EBADHANDLE
-10 SM_RC_ENOHANDLES
-9 SM_RC_EMSGSIZE
-8 SM_RC_EUNKMSG
-7 SM_RC_ETIMEOUT

IBM SMAPI Reference


 -6 SM_RC_EUNEXP
-5 SM_RC_EINVAL
-4 SM_RC_ENOSERVER
-3 SM_RC_ENOCONN
-2 SM_RC_ENOMSG
-1 SM_RC_EAPIVERSION
0 SM_RC_OK
1 SM_RC_NOT_VALID_REQUEST
2 SM_RC_BAD_MODE
3 SM_RC_NOT_WHILE_MIC_ON
4 SM_RC_MIC_ALREADY_ON
5 SM_RC_MIC_ALREADY_OFF
6 SM_RC_MIC_ON_PENDING
7 SM_RC_MIC_OFF_PENDING
8 SM_RC_NOT_WHILE_PLAYING
10 SM_RC_BAD_AUDIO
11 SM_RC_RECORD_OPEN_ERROR
12 SM_RC_PLAY_OPEN_ERROR
13 SM_RC_AUDIO_IN_USE
14 SM_RC_BAD_AUDIO_PROTOCOL
15 SM_RC_AUDIO_TIMEOUT
16 SM_RC_AUDIO_DISCONNECTED
17 SM_RC_AUDIO_OVERRUN
18 SM_RC_AUDIO_FORCED_MIC_OFF
19 SM_RC_NO_MORE_AUDIO_FILES
20 SM_RC_BAD_AP
28 SM_API_RC_MAX_NAMES
30 SM_RC_BAD_DECO
40 SM_RC_BAD_ADDWORD
41 SM_RC_ADDED
42 SM_RC_NOT_ADDED
43 SM_RC_MULTIPLE_SPELLINGS
44 SM_RC_ILLEGAL_SPELLING

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

 45


SM_RC_ILLEGAL_SPOKENLIKE
46


SM_RC_MISMATCHED_ACOUSTICS
47


SM_RC_BAD_ACOUSTICS
48


SM_RC_SPELLING_TOO_LONG
49


SM_RC_ACOUSTICS_TOO_LONG
50 SM_RC_ADDWORD_LIMIT_EXCEEDED
60 SM_RC_SERVER_ERROR
61 SM_RC_SERVER_MALLOC_ERROR
62 SM_RC_SERVER_FILE_OPEN_ERROR
63 SM_RC_SERVER_FILE_WRITE_ERROR
64 SM_RC_SERVER_FILE_READ_ERROR
65 SM_RC_SERVER_FILE_CLOSE_ERROR
66 SM_RC_SERVER_PROCESS_ERROR
67 SM_RC_SERVER_TERMINATED
70 SM_RC_BAD_TAG
71 SM_RC_BAD_UTTNO
72 SM_RC_BAD_MESSAGE
80 SM_RC_NOT_DELETED
81 SM_RC_NOT_INVOCAB
82 SM_RC_INVOCAB
83 SM_RC_BAD_VOCAB
84 SM_RC_MISSING_EXTERN
90 SM_RC_BAD_USERID
91 SM_RC_BAD_ENROLLID
92 SM_RC_BAD_PASSWORD
93 SM_RC_BAD_TASKID
94 SM_RC_BAD_CLIENT
95 SM_RC_USERID_EXISTS
96


SM_RC_ENROLLID_EXISTS
97


SM_RC_USERID_BUSY
98


SM_RC_ENROLLID_BUSY
99


SM_RC_BAD_SCRIPT
100


SM_RC_BAD_DESCRIPTION
101


SM_RC_ENROLLID_RUNNING
102


SM_RC_ENROLLMENT_NOT_COMPLETE


IBM SMAPI Reference


 103


SM_RC_MISMATCHED_LANGUAGE
104


SM_RC_MISMATCHED_ALPHABET
105


SM_RC_MISMATCHED_SCRIPT
106


SM_RC_BAD_LANGUAGE
107


SM_RC_BAD_NAME
108


SM_RC_INVALID_WINDOW_HANDLE
110 SM_RC_BAD_ITEM
111 SM_RC_BAD_VALUE
120 SM_RC_BUSY_LAST_UTTERANCE
121 SM_RC_B USY_WORD_CORRECTION
130 SM_RC_NO_SPACE
131 SM_RC_NO_SPACE_INIT_RECO
132 SM_RC_NO_SPACE_INIT_ENROLL
133 SM_RC_NO_SPACE_TERM_ENROLL
134 SM_RC_NO_SPACE_MIC_ON
140 SM_RC_INVALID_PARM_MAX_LEN
170 SM_RC_NO_FOCUS_APP
171 SM_RC_FOCUS_GRANTED
172 SM_RC_FOCUS_REQUEST_PENDING
173 SM_RC_FOCUS_DENIED
174 SM_RC_NAV_ALREADY_DEFINED
175 SM_RC_NOT_IN_NOTIFY
176 SM_RC_EXISTS_IN_NOTIFY
178 SM_RC_INCOMPATIBLE_ENROLLMENT
250 SM_RC_MAX_NAMES


1000 SM_RC_NOT_YET


IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

Engine Return Codes and Messages


 200


SM_RC_SM_NOT_OPEN
201


SM_RC_WRONG_SM_VERSION
202


SM_RC_SM_NOT_ACTIVE_CLIENT
203 SM_RC_SM_EINVAL_MSG_TYPE
204 SM_RC_REPLY_NULL
205 SM_RC_NO_MORE_CONNECTIONS
206 SM_RC_NO_TOPLEVEL_WIDGET
207 SM_RC_CONNECTION_CHANGED
208 SM_RC_CALLBACK_LIST_CHANGED
209 SM_RC_ASCII_ALREADY_SET
210 SM_RC_NOTHING_TO_DISPATCH
211 SM_RC_MAX_MSG_QUEUES_EXCEEDED
214 SM_RC_OPEN_SYNCH_QUEUE_FAILED
215 SM_RC_ALREADY_CONNECTED


216 SM_RC_ALREADY_OPENED


IBM SMAPI Reference


Status Codes and Messages


 100


SM_STAT_PLAY_START
101


SM_STAT_PLAY_STOP
102


SM_STAT_BAD_AUDIO
103 SM_STAT_BAD_TAG
104 SM_STAT_BAD_UTTERANCE
105 SM_STAT_BAD_MESSAGE
106 SM_STAT_ENROLLMENT_RECORDING
107 SM_STAT_ENROLLMENT_RUNNING
108 SM_STAT_ENROLLMENT_FAILED
109 SM_STAT_ENROLLMENT_COMPLETE
110 SM_STAT_ENROLLMENT_BUSY


IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SMAPI Message Types

These message values are defined in the SMCOMM.H file.

 /* Recognizer to application */
SM_SET_REPLY 53
SM_QUERY_REPLY 54
SM_QUERY_LANGUAGES_REPLY 55
SM_QUERY_USERS_REPLY 56
SM_QUERY_ENROLLIDS_REPLY 57
SM_QUERY_TASKS_REPLY 58
SM_INIT_RECOGNIZER_REPLY 59
SM_SPARE_PUBLIC_1_REPLY 60
SM_MIC_ON_REPLY 61
SM_MIC_OFF_REPLY 62
SM_REQUEST_MIC_ON_REPLY 63
SM_REQUEST_MIC_OFF_REPLY 64
SM_RECOGNIZE_NEXT_WORD_REPLY 65
SM_PLAY_WORDS_REPLY 66
SM_PLAY_UTTERANCE_REPLY 67
SM_PLAY_MESSAGE_REPLY 68
SM_CANCEL_PLAYBACK_REPLY 69
SM_NEW_CONTEXT_REPLY 70
SM_EVENT_NOTIFY_REPLY 71
SM_QUERY_ALTERNATES_REPLY 72
SM_WORD_CORRECTION_REPLY 73
SM_CORRECT_TEXT_REPLY 74
SM_CORRECT_TEXT_CANCEL_REPLY 75
SM_QUERY_WORD_REPLY 76
SM_ADD_PRONUNCIATION_REPLY 77
SM_REMOVE_PRONUNCIATION_REPLY 78
SM_QUERY_PRONUNCIATIONS_REPLY 79


IBM SMAPI Reference


SM_DEFINE_VOCAB_REPLY 80
SM_ADD_TO_VOCAB_REPLY 81
SM_REMOVE_FROM_VOCAB_REPLY 82
SM_QUERY_ADDED_WORDS_REPLY 83
SM_ENABLE_VOCAB_REPLY 84
SM_DISABLE_VOCAB_REPLY 85
SM_UNDEFINE_VOCAB_REPLY 86
SM_QUERY_VOCABS_REPLY 87
SM_QUERY_ENABLED_VOCABS_REPLY 88
SM_SET_USER_INFO_REPLY 89
SM_QUERY_USER_INFO_REPLY 90
SM_DISCARD_DATA_REPLY 91
SM_HALT_RECOGNIZER_REPLY 92
SM_TERMINATE_RECOGNIZER_REPLY 93
SM_INIT_ENROLLMENT_REPLY 94
SM_TERMINATE_ENROLLMENT_REPLY 95
SM_INIT_DATABASE_REPLY 96
SM_TERMINATE_DATABASE_REPLY 97
SM_QUERY_PRONUNCIATION_REPLY 98
SM_REQUEST_FOCUS_REPLY 99
SM_RELEASE_FOCUS_REPLY 100
SM_QUERY_SESSIONS_REPLY 101
SM_DETACH_SESSIONS_REPLY 102
SM_SET_DEFAULT_REPLY 103
SM_QUERY_DEFAULT_REPLY 104


 /* Unsolicited from recognizer to application */
SM_RECOGNIZED_TEXT 105
SM_RECOGNIZED_WORD 106
SM_UTTERANCE_COMPLETED 107
SM_PLAY_WORDS_STATUS 108
SM_PLAY_UTTERANCE_STATUS 109
SM_PLAY_MESSAGE_STATUS 110
SM_SERVER_STATUS 111
SM_EVENT_SYNCH 112


IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_REPORT_ENGINE_ERROR 113
SM_FOCUS_LOST 114
SM_FOCUS_GRANTED 115
SM_REQUEST_DETACH 116


 /* Unsolicited multicast group messages */
SM_AUDIO_LEVEL 117
SM_COMMAND_WORD 118
SM_MIC_STATE 119
SM_FOCUS_STATE 120
SM_ENGINE_STATE 121


/* Messages sent from application to engine and from engine to application*/
SM_REQUEST_MIC_ON 122
SM_REQUEST_MIC_OFF 123


 /* Messages mapped from init mode to connect */
SM_CONNECT_REPLY 124
SM_DISCONNECT_REPLY 125


 /* Sent from client to engine (for queues) to detach client */
SM_CLIENT_DETACH 126


 /* Messages made public after 3.1 */
SM_DEFINE_GRAMMAR 143
SM_DEFINE_GRAMMAR_REPLY 150


IBM SMAPI Reference


 /* Messages added after 3.1 for converged engine... added here to keep */
/* backward API compatibility */


SM_QUERY_SPEECH_DATA 169


SM_QUERY_SPEECH_DATA_REPLY 170


SM_SAVE_SPEECH_DATA 171


SM_SAVE_SPEECH_DATA_REPLY 172


SM_RESTORE_SPEECH_DATA 173


SM_RESTORE_SPEECH_DATA_REPLY 174


SM_RECOGNIZED_PHRASE 175


IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SMAPI Message Explanations

The following are explanations for the SMAPI messages.

SM_RC_ACOUSTICS_TOO_LONG

The acoustics specified are too long.

Explanation:

The recording made for a specified word is longer than the phonetic representation of the
requested word.

User response:

Enter a phonetic spelling or record the word again.

SM_RC_ADDED

The specified word has been added to the speech vocabulary.

Explanation:

The request to add a word was successfully completed.

User response:

None

IBM SMAPI Reference


SM_RC_ADDWORD_LIMIT_EXCEEDED

The added-word limit has been reached.

Explanation:

Only a specified number of words can be added to a speaker's vocabulary. The speech system has
reached your added-word limit.

User response:

Review your added words and delete the ones that are either unneeded or infrequently used.

SM_RC_ALREADY_CONNECTED

Already connected to speech recognition engine.

Explanation:

Either SmConnect() or SmOpen() was called after the application had already successfully
connected to the engine.

User response:

Correct the application programming error.

SM_RC_ALREADY_OPENED

Already opened for connection to speech recognition engine.

Explanation:

A second call to SmOpen() was made after the application had already successfully opened the
local API data structure.

User response:

Correct the application programming error.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_ASSOC_EVENT_SEM_FAILED

An IPC error: Unable to associate semaphore.

Explanation:

Unable to associate semaphore.

User response:

Submit a problem report.

SM_RC_AUDIO_FORCED_MIC_OFF

The speech system has forced the microphone off.

Explanation:

The speech system turned off the microphone unexpectedly. This event can occur if the speech
system has an internal error or if the disk is full.

User response:

Try the request again. Save the log files of the session and submit a problem report.

SM_RC_AUDIO_IN_USE

The speech system is already in use.

Explanation:

The speech system is being used by another session.

User response:

Correct the application programming error.

IBM SMAPI Reference


SM_RC_AUDIO_OVERRUN

The speech system has overrun its recording buffers.

Explanation:

The speech system was not able to continue sending audio data because the recording buffers are
full.

User response:

Up to 100 seconds of audio can be stored in an internal audio memory buffer. For details, see
"Processing Speech Engine Audio" in the SMAPI Developer's Guide.

SM_RC_BAD_ACOUSTICS

Invalid acoustic data has been found.

Explanation:

The recorded data was not found for the word requested to be added.

User response:

Ensure that the disk is not full, which would cause files to be lost.

SM_RC_BAD_ADDWORD

The add-word process could not be initiated.

Explanation:

The speech recognition engine detected an error with the add word component.

User response:

Save the log files of the session and submit a problem report.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_BAD_AP

The system detected an error with the acoustic processor.

Explanation:

The speech recognition engine detected an error with the acoustic-processor component.

User response:

Save the log files of the session and submit a problem report.

SM_RC_BAD_AUDIO

The system detected an error with the audio source.

Explanation:

An application will get this return if there is a problem with the audio source (for example, if there
is a problem loading code on the adapter card during initialization).

User response:

Try the request again. If the problem persists, save the log files of the session, report the error, and
restart.

SM_RC_BAD_DECO

The system detected an error with the speech recognition engine.

Explanation:

The speech recognition engine detected an error with the decoding-processor component.

User response:

Save the log files of the session and submit a problem report.

IBM SMAPI Reference


SM_RC_BAD_DESCRIPTION

An invalid description has been specified.

Explanation:

An attempt was made to write an enrollment description containing a non-ASCII character or an
enrollment description that exceeded the maximum length.

User response:

Enter a description that is equal to or less than the maximum length and use only valid, printable
ASCII characters.

SM_RC_BAD_ENROLLID

An invalid enrollment identifier has been specified.

Explanation:

The enrollment ID for the specified speaker is not valid.

User response:

Select a valid enrollment ID for the specified user ID.

SM_RC_BAD_ITEM

An invalid item name has been specified.

Explanation:

An attempt was made to write an item name containing a non-ASCII character.

User response:

Enter an item name using only valid, printable ASCII characters.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_BAD_LANGUAGE

An invalid language has been specified, or this language is not installed.

Explanation:

The requested language is not valid or is not installed.

User response:

Specify a valid language for the installed speech recognition engine.

SM_RC_BAD_MESSAGE

An invalid audio message name has been specified.

Explanation:

An invalid audio message name was passed by the application to the SMAPI. This is an application
programming error.

User response:

Correct the application programming error.

SM_RC_BAD_MODE

The request is not valid in this speech recognition engine mode.

Explanation:

The speech recognition engine was initialized for a mode that does not support the requested
function. This is an application programming error.

User response:

Correct the application programming error.

IBM SMAPI Reference


SM_RC_BAD_NAME

An invalid name tag has been specified.

Explanation:

An attempt was made used to use an invalid name.

User response:

Specify a valid name.

SM_RC_BAD_SCRIPT

A bad script has been specified, or no scripts are available.

Explanation:

An attempt was made to use an invalid script for enrollment.

User response:

Specify a valid script.

SM_RC_BAD_TAG

An invalid word tag value has been specified.

Explanation:

An invalid tag value was passed by the application to the SMAPI. This is an application
programming error.

User response:

Correct the application programming error.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_BAD_TASKID

A match could not be found for the specified domain ID.

Explanation:

The domain ID is not valid.

User response:

Select a valid domain ID.

SM_RC_BAD_USERID

A match could not be found for the specified user ID.

Explanation:

The user ID is not valid.

User response:

Select a valid user ID.

SM_RC_BAD_UTTNO

An invalid utterance number has been specified.

Explanation:

An invalid utterance number was passed by the application to the SMAPI. This is an application
programming error.

User response:

Correct the application programming error.

IBM SMAPI Reference


SM_RC_BAD_VALUE

An invalid value has been specified.

Explanation:

An attempt was made to write a value containing a non-ASCII character.

User response:

Enter a value using only valid, printable ASCII characters.

SM_RC_BAD_VOCAB

The specified vocabulary is not valid.

Explanation:

An invalid vocabulary name was passed by the application to the SMAPI. This is an application
programming error.

User response:

Correct the application programming error.

SM_RC_BUSY_LAST_UTTERANCE

The speech recognition engine is busy processing the last utterance.

Explanation:

An attempt was made to play a message or word before all the speech had been processed after an
SmMicOff call.

User response:

Wait a few seconds and repeat the request until you receive a response.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_BUSY_WORD_CORRECTION

The speech recognition engine is busy processing the last word correction.

Explanation:

An attempt was made to correct a word and turn on the microphone before the previous request
was completed.

User response:

Wait a few seconds and repeat the request until you receive a response.

SM_RC_CALLBACK_LIST_CHANGED

The callback list has been changed during the execution of another callback.

Explanation:

The callback list has been modified while executing a callback procedure.

User response:

Correct the application programming error.

SM_RC_CONNECTION_CHANGED

New or closed connection when executing callback procedure.

Explanation:

A new connection to the SMAPI was created or an old one was removed from within a callback
procedure.

User response:

Submit a problem report.

IBM SMAPI Reference


SM_RC_CREATE_EVENT_SEM_FAILED

An IPC error: Unable to create event semaphore.

Explanation:

Unable to create event semaphore.

User response:

Submit a problem report.

SM_RC_CREATE_MBOX_FAILED

An IPC error: Unable to create mbox.

Explanation:

Unable to create mbox.

User response:

Submit a problem report.

SM_RC_DEEALLOCATING_SH_MEM

Unable to deallocate shared memory.

Explanation:

There is not sufficient memory for messages to pass between the SMAPI and the speech
recognition engine.

User response:

Try the request again. If the problem persists, record the error and submit a problem report.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_EALLBUSY

IBM ViaVoice is busy.

Explanation:

IBM ViaVoice is busy.

User response:

Try the request again. If the problem persists, record the error and submit a problem report.

SM_RC_EALLOC

Unable to allocate memory for speech recognition engine messages.

Explanation:

There is not sufficient memory for messages to pass between the SMAPI and the speech
recognition engine.

User response:

Record the error and submit a problem report.

SM_RC_EAPIVERSION

Incorrect API version.

Explanation:

The speech recognition engine and the SMAPI are not compatible.

User response:

Install a complete and compatible version.

IBM SMAPI Reference


SM_RC_EBADAPPNAME

An invalid application name has been specified.

Explanation:

An invalid application name was specified for a session between the SMAPI and the speech
recognition engine.

User response:

Correct the application programming error.

SM_RC_EBADHANDLE

Invalid handle passed to the speech recognition engine.

Explanation:

An invalid internal handle was used by the SMAPI.

User response:

Correct the application programming error.

SM_RC_EINVAL

Invalid value passed to speech recognition engine.

Explanation:

The value passed from the application to the SMAPI could not be passed to the speech recognition
engine.

User response:

Correct the application programming error.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_ENOCONN

No connection to speech recognition engine.

Explanation:

The application is unable to establish a session with the speech recognition engine; most likely,
this is because the speech recognition engine is not running.

User response:

Restart the speech recognition engine. If the system is running, verify that the level of the client
software and the level of the speech recognition engine are compatible.

SM_RC_ENOHANDLES

No handles for speech recognition engine.

Explanation:

An internal resource needed by the SMAPI is not available.

User response:

Restart the speech recognition engine.

SM_RC_ENOMEM

No memory available for speech recognition engine.

Explanation:

No memory is available for the speech recognition engine communications process.

User response:

Restart the speech recognition engine.

IBM SMAPI Reference


SM_RC_ENOMSG

No message available from speech recognition engine.

Explanation:

A request was made to the speech recognition engine but no response was received. A
communications error or a speech recognition engine error prevented the speech recognition
engine from responding to the application request.

User response:

Report the error and try the request again.

SM_RC_ENOSERVER

Unable to find an available speech recognition engine.

Explanation:

All speech recognition engines are being used by other users.

User response:

Wait a few minutes and try again to establish a session.

SM_RC_ENROLLID_BUSY

Enrollment is busy.

Explanation:

The enrollment ID is still being processed.

User response:

An attempt was made to use an enrollment ID that was locked. Try to use the enrollment ID later.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_ENROLLID_EXISTS

The specified enrollment identifier already exists.

Explanation:

An attempt was made to specify an enrollment ID that already exists for the specified user ID.

User response:

Provide a unique enrollment ID to the enrollment program.

SM_RC_ENROLLID_RUNNING

The enrollment data set specified is being processed.

Explanation:

A fully recorded enrollment data set is being processed and will be available for dictation when it
as been processed.

User response:

None.

SM_RC_ENROLLMENT_NOT_COMPLETE

Enrollment has not completed for this identifier.

Explanation:

An enrollment data set that is still being processed offline was specified for decoding.

User response:

Try to use the enrollment data set for dictating after the offline processing is completed.

IBM SMAPI Reference


SM_RC_FREE_MEM_ERROR

An IPC error: Error freeing memory.

Explanation:

Error freeing memory.

User response:

Submit a problem report.

SM_RC_EXISTS_IN_NOTIFY

Application is already in specified group

Explanation:

An application asks to enable a notification group in which the application is already registered.

User response:

None.

SM_RC_FOCUS_DENIED

A focus request has been denied.

Explanation:

The current application with speech focus has "grabbed" the focus and changes are being blocked
by the engine.

User response:

None.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_FOCUS_GRANTED

The application already has the speech focus.

Explanation:

The requesting application has already been granted speech focus and an asynchronous
notification message will not be sent by the engine.

User response:

None.

SM_RC_INCOMPATIBLE_ENROLLMENT

Enrollment was not compatible with the current engine.

Explanation:

An enrollment created for a previous release may not be supported on the current engine.

User response:

Re-enroll.

SM_RC_ILLEGAL_SPOKENLIKE

An invalid spoken-like spelling has been specified.

Explanation:

For a given language, certain ASCII characters are not valid.

User response:

Provide a valid spoken-like spelling for the language you are using.

IBM SMAPI Reference


SM_RC_ILLEGAL_SPELLING

An invalid spelling has been specified.

Explanation:

For a given language, certain ASCII characters are not valid.

User response:

Provide a valid spelling for the language you are using.

SM_RC_INVALID_PARM_MAX_LEN

The specified parameter exceeds the maximum length.

Explanation:

The specified parameter exceeds the maximum length permitted by the speech recognition engine.

User response:

Specify the parameter again.

SM_RC_INVOCAB

The specified word is in the speech recognition engine vocabulary.

Explanation:

The specified word already exists in the speech recognition engine vocabulary.

User response:

None.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_MIC_ALREADY_OFF

The microphone is already off.

Explanation:

A request was made to turn off the microphone, but it is already off.

User response:

None.

SM_RC_MIC_ALREADY_ON

The microphone is already on.

Explanation:

A request was made to turn on the microphone, but it is already on. This is an application
programming error.


User response:

Correct the application programming error.

SM_RC_MIC_OFF_PENDING

A microphone-off request is already in progress.

Explanation:

A request was made to turn off the microphone while it was in the process of being turned off. This
is an application programming error.

User response:

Correct the application programming error.

IBM SMAPI Reference


SM_RC_MIC_ON_PENDING

A microphone-on request is already in progress.

Explanation:

A request was made to turn on the microphone while it was in the process of being turned on. This
is an application programming error.

User response:

Correct the application programming error.

SM_RC_MISMATCHED_ACOUSTICS

An acoustics mismatch has been found.

Explanation:

The recording does not match the spelling provided for the added word.

User response:

Try recording the word again, or specify a spelling that phonetically matches the requested word.

SM_RC_MISMATCHED_ALPHABET

The domain and enrollment identifier specified are in different alphabets.

Explanation:

The domain specified is not for the same alphabet as the enrollment ID.

User response:

Specify a valid domain for the alphabet in which you want to dictate.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_MISMATCHED_LANGUAGE

The domain and enrollment identifier specified are in different languages.

Explanation:

The specified domain is not for the same language as the enrollment ID.

User response:

Specify a valid domain for the language in which you want to dictate.

SM_RC_MISMATCHED_SCRIPT

The script specified does not match the previously specified script.

Explanation:

A partially recorded enrollment used a script that is different from the one currently specified.

User response:

Use the script specified in the last session to continue the enrollment session.

SM_RC_MISSING_EXTERN

A required external vocabulary does not exist.

Explanation:

An external vocabulary referenced in a grammar has not been defined.

User response:

None.

IBM SMAPI Reference


SM_RC_MULTIPLE_SPELLINGS

Multiple spellings specified.

Explanation:

More than one spelling was specified for an added-word or more than one tag was specified. This
is an application programming error.

User response:

Correct the application programming error.

SM_RC_NAV_ALREADY_DEFINED

Navigator application already defined.

Explanation:

A second application has attempted to assert the navigator field.

User response:

None.

SM_RC_NO_FOCUS_APP

No application has the speech focus.

Explanation:

A request has been made to turn the microphone on, but no application has speech focus.

User response:

Request speech focus for an application.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_NO_MORE_CONNECTIONS

Duplicate SmOpen call.

Explanation:

The SmOpen function was called again without previously closing the connection to the SMAPI
through SmClose.

User response:

This is an application programming error.

SM_RC_NO_SPACE

No space is left on the disk.

Explanation:

No space is left on the disk.

User response:

 None.

SM_RC_NO_SPACE_INIT_ENROLL

No space is left on the disk for an enrollment session.

Explanation:

Not enough disk space is available to record the next sentence during enrollment.

User response:

Restart the speech recognition engine.

IBM SMAPI Reference


SM_RC_NO_SPACE_INIT_RECO

No space is left on the disk for a recognition session.

Explanation:

Not enough disk space is available to record the next sentence during dictation.

User response:

None.

SM_RC_NO_SPACE_MIC_ON

No space is left on the disk for PCM.

Explanation:

No space is left on the disk for PCM.

User response:

None.

SM_RC_NO_SPACE_TERM_ENROLL

Not enough disk space to complete training.

Explanation:

Not enough disk space available to complete training.

User response:

Restart the speech recognition engine.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_NOT_ADDED

The specified word has not been added to the speech recognition engine vocabulary.

Explanation:

The add-word request was not successfully completed. For a given language, a request to add a
word might fail.

User response:

Try a new recording of the word or provide a phonetic spelling.

SM_RC_NOT_DELETED

The speech recognition engine was unable to delete the specified added word.

Explanation:

The speech recognition engine attempted to delete a word that is not in the specified vocabulary.

User response:

Correct the application programming error.

SM_RC_NOT_IN_NOTIFY

Application is not in the specified group.

Explanation:

An application asks to disable a notification group in which the application is not registered.

User response:

None.

IBM SMAPI Reference


SM_RC_NOT_INVOCAB

The specified word is not in the speech recognition engine vocabulary.

Explanation:

The specified word does not exist in the speech recognition engine vocabulary.

User response:

None.

SM_RC_NOT_VALID_REQUEST

The engine is not in the proper state to handle this request.

Explanation:

The engine is not in the proper state to handle this request.

User response:

Correct the application programming error.

SM_RC_NOT_WHILE_MIC_ON

The given request is not valid while the microphone is on.

Explanation:

Some requests are not valid when the microphone is on. This is an application programming error.

User response:

Turn off the microphone before making the request.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_NOT_WHILE_PLAYING

The given request is not valid while playing audio.

Explanation:

Some requests are not valid while audio is playing. This is an application programming error.

User response:

Wait until the audio has finished playing before making this request.

SM_RC_NOT_YET

SMAPI function call not supported.

Explanation:

The application made a function call that is not supported by the installed SMAPI. The supporting
function in the speech recognition engine is not present. All applications must match the installed
SMAPI.

User response:

If a new application is installed, ensure that it matches the installed SMAPI or install the required
SMAPI and upgrade the existing applications.

SM_RC_OK

Successful completion.

Explanation:

The most recent application request to the SMAPI was successfully completed.

User response:

None.

IBM SMAPI Reference


SM_RC_OPEN_SYNCH_QUEUE_FAILED

SmOpen failed to get required resources.

Explanation:

A system problem occurred during the SmOpen call when certain system resources are allocated.

User response:

Try the request again. If the problem persists, report the error and restart the speech system. Save
the log files of the session and submit a problem report on the speech recognition engine.

SM_RC_PLAY_OPEN_ERROR

The system was unable to open the play device.

Explanation:

The speech recognition engine was not able to open the play device. Another application is using
the IBM VoiceType Dictation Adapter or the device driver was replaced by another application.

User response:

Try the request again. If the problem persists, report the error and restart the speech system. Save
the log files of the session and submit a problem report on the speech recognition engine.

SM_RC_QUEUE_CLOSE_ERROR

An IPC error: Error closing queue.

Explanation:

Error closing queue.

User response:

Try the request again. If the problem persists, submit a problem report.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_RECORD_OPEN_ERROR

The system was unable to open the recording device.

Explanation:

The speech recognition engine was not able to open the recording device. Another application is
using the IBM VoiceType Dictation Adapter or the device driver was replaced by another
application.

User response:

Try the request again. If the problem persists, report the error and restart the speech system. Save
the log files of the session and submit a problem report on the speech recognition engine.

SM_RC_REPLY_NULL

NULL reply parameter.

Explanation:

The pointer to the reply structure that was given to one of the reply message functions is NULL.

User response:

Correct the application programming error.

SM_RC_SERVER_ERROR

The speech recognition engine detected an internal error.

Explanation:

The speech recognition engine has detected an internal error.

User response:

Save the log files of the session. Ensure that sufficient disk space is available for the system.
Restart the speech recognition engine.

IBM SMAPI Reference


SM_RC_SERVER_FILE_CLOSE_ERROR

The speech recognition engine has an internal close error.

Explanation:

The speech recognition engine was not able to close one of its files.

It is possible that, because of the additional applications running on the speech recognition engine,
the maximum number of open file handles, the microprocessor limits, or the page space limits have
been reached.

User response:

Save the log files of the session. Ensure that sufficient disk space is available for the system.
Restart the speech recognition engine.

SM_RC_SERVER_FILE_OPEN_ERROR

The speech recognition engine has an internal open error.

Explanation:

The speech recognition engine was not able to open one of its files.

It is possible that, because of the additional applications running on the speech recognition engine,
the maximum number of open file handles, the microprocessor limits, or the page space limits have
been reached.

User response:

Save the log files of the session. Ensure that sufficient disk space is available for the system.
Restart the speech recognition engine.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_SERVER_FILE_READ_ERROR

The speech recognition engine has an internal read error.

Explanation:

The speech recognition engine was not able to read one of its files.

It is possible that, because of the additional applications running on the speech recognition engine,
the maximum number of open file handles, the microprocessor limits, or the page space limits have
been reached.

User response:

Save the log files of the session. Ensure that sufficient disk space is available for the system.
Restart the speech recognition engine.

SM_RC_SERVER_FILE_WRITE_ERROR

The speech recognition engine has an internal write error.

Explanation:

The speech recognition engine was not able to write one of its files.

It is possible that, because of the additional applications running on the speech recognition engine,
the maximum number of open file handles, the microprocessor limits, or the page space limits have
been reached.

User response:

Save the log files of the session. Ensure that sufficient disk space is available for the system.
Restart the speech recognition engine.

IBM SMAPI Reference


SM_RC_SERVER_MALLOC_ERROR

The speech recognition engine has an internal malloc error.

Explanation:

The speech recognition engine was not able to allocate memory for its process.

User response:

Save the log files of the session. Ensure that sufficient memory is available for the system. Restart
the speech recognition engine.

SM_RC_SERVER_PROCESS_ERROR

The speech recognition engine has an internal process error.

Explanation:

The speech recognition engine had an unrecoverable error.

It is possible that, because of the additional applications running on the speech recognition engine,
the maximum number of open file handles, the microprocessor limits, or the page space limits have
been reached.

User response:

Save the log files of the session. Ensure that sufficient disk space is available for the system.
Restart the speech recognition engine.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_SERVER_TERMINATED

speech recognition engine terminated.

Explanation:

The speech recognition engine has stopped.

User response:

Save the log files of the session and restart the speech recognition engine.

SM_RC_SM_EINVAL_MSG_TYPE

Invalid message type.

Explanation:

This is a program logic error. The program has used an access function against an invalid message
type.

User response:

Use an access function that is valid for the message type.

SM_RC_SM_NOT_ACTIVE_CLIENT

The speech-aware application is not active.

Explanation:

The speech-aware application is not active.

User response:

Correct the application programming error.

IBM SMAPI Reference


SM_RC_SM_NOT_OPEN

Application has not opened SMAPI using an SmOpen call.

Explanation:

The speech application has not been opened by an SmOpen call.

User response:

Correct the application programming error.

SM_RC_SUB_UNSET_ERROR

An IPC error: Error unsetting memory.

Explanation:

The speech application has not been opened by an SmOpen call.

User response:

Correct the application programming error.

SM_RC_SPELLING_TOO_LONG

The spelling specified is too long.

Explanation:

The specified word is too long.

User response:

The spelling of the specified word is phonetically longer than the recording made for the word.
Enter a phonetic spelling or record the word again.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_RC_USERID_BUSY

User identifier is busy.

Explanation:

An attempt was made to use a user ID that was locked by another client workstation or application.

User response:

Try to use the user ID later.

SM_RC_USERID_EXISTS

User identifier already exists.

Explanation:

An attempt was made to add a user ID that already exists on the speech recognition engine.

User response:

Provide a unique user ID to the program.

SM_RC_WRONG_SM_VERSION

Incompatible versions of compiled/dynamically linked SMAPI.

Explanation:

The version of the SMAPI with which the application has been compiled is different from that of
the installed run-time libraries.

User response:

Compile your application with the same version of the API currently installed on your computer.

IBM SMAPI Reference


SM_STAT_BAD_AUDIO

Bad audio.

Explanation:

The connection to the audio source was lost during playback.

User response:

Try the request again.

SM_STAT_BAD_MESSAGE

Bad message.

Explanation:

An invalid message was specified for playback. This is an application programming error.

User response:

Try again with a valid message.

SM_STAT_BAD_TAG

Bad tag.

Explanation:

An invalid word tag was specified for playback. This is an application programming error.

User response:

Try again with a valid word tag.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_STAT_BAD_UTTERANCE

Bad utterance.

Explanation:

An invalid utterance was specified for playback. This is an application programming error.

User response:

Try again with a valid utterance.

SM_STAT_ENROLLMENT_BUSY

Enroll ID is busy.

Explanation:

This enroll ID is locked through use from a different machine.

User response:

Try to use the enroll ID later.

SM_STAT_ENROLLMENT_COMPLETE

Enrollment complete.

Explanation:

Training completed successfully for this enroll ID. This is informational only.

User response:

None.

IBM SMAPI Reference


SM_STAT_ENROLLMENT_FAILED

Enrollment failed.

Explanation:

The training process failed for this enroll ID.

User response:

Refer to the help for Enrollment.

SM_STAT_ENROLLMENT_RECORDING

Enrollment recording.

Explanation:

The user is recording the enrollment script for this enroll ID. This is informational only.

User response:

None.

SM_STAT_ENROLLMENT_RUNNING

Enrollment running.

Explanation:

The engine is running training for this enroll ID. This is informational only.

User response:

None.

IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

SM_STAT_PLAY_START

Audio play started.

Explanation:

The message, word, or utterance has started playing. This is informational only.

User response:

None.

SM_STAT_PLAY_STOP

Audio play stopped.

Explanation:

The message, word, or utterance has stopped playing. This is informational only.

User response:

None.

IBM SMAPI Reference


ROUTER.MSG Log

Logs used for debugging are disabled by default. Logging is controlled by the value setting of the
parameter api_log_level in the following file:

(IBMVType)/bin/engine.cfg


This file should be used for debugging and diagnostics. The content of the file is not defined as a public
interface.

The value settings for logging are:

0 Disables logging

1 Message headers

2 Message headers + content

3 Message headers + content + internal engine mes


sages
>3 Reserved


After this logging parameter has been changed the engine must be restarted before the new parameter
value can take effect.

Logs of interest are located in the following IBM ViaVoice host-drive directory:

(IBMVType/Temp)


The log file, router.msg, includes a trace of IBM ViaVoice SMAPI calls. Differences between SMAPI
names in this log file and the documentation include the following:

. "SPCH_" prefix in the log file and "Sm" prefix in the documentation.
. Underscore("_") is used in the log file, but not in the documentation.
IBM ViaVoice SDK for Windows


SMAPI Return Codes and Messages

An explanation of reply message structures that can be logged but will not be seen by the application
include the following:

SM_INIT_DATABASE_REPLY

Response to an asynchronous SmConnect that is establishing a database session but is presented to
the application as a SM_CONNECT_REPLY reply message structure.

SM_INIT_RECOGNIZER_REPLY

Response to an asynchronous SmConnect that is establishing a recognition session but is presented
to the application as a SM_CONNECT_REPLY reply message structure.

SM_TERMINATE_DATABASE_REPLY

Response to an asynchronous SmDisconnect that is disconnecting from the speech recognition
engine during a database session but is presented to the application as a
SM_DISCONNECT_REPLY reply message structure.

SM_TERMINATE_RECOGNIZER_REPLY

Response to an asynchronous SmDisconnect that is disconnecting from the speech recognition
engine during a recognition session but is presented to the application as a
SM_DISCONNECT_REPLY reply message structure.

IBM SMAPI Reference


IBM ViaVoice SDK for Windows


Appendix B DMAPI Return Codes
and Messages

These return codes and messages, defined in DMAPI.H, are generated by DMAPI.

DMAPI Return Codes and Messages

The following list contains the return code values in numeric order for DMAPI. Return codes marked
with an asterisk (*) are used internally by the Dictation Macro Editor and are not returned to the

application.
0 DM_ERR_OK
1 DM_ERR_TEMPLATE_NOT_FOUND
2 DM_ERR_MACRO_NOT_FOUND
3 DM_ERR_MALLOC
4 DM_ERR_INVALID_USERID
5 DM_ERR_INVALID_DOMAIN
6 DM_ERR_INVALID_LANGUAGE
7 DM_ERR_INVALID_HANDLE
8 DM_ERR_INVALID_MACRO
9 DM_ERR_INVALID_TEMPLATE *
10 DM_ERR_DUPLICATE_MACRO
11 DM_ERR_FILE_READ *
12 DM_ERR_NOTIFY_EXCEEDED
13 DM_ERR_OPEN_CLIPBOARD_FAILED *
14 DM_ERR_NOT_ENOUGH_SHARED_MEM *
15 DM_ERR_SHARED_MEM_UNDEFINED *
16 DM_ERR_TRANSFER_TO_CLIPBRD *
17 DM_ERR_MISSING_CLIPBRD_FORMAT *
18 DM_ERR_INVALID_MACROFILE
19 DM_ERR_INVALID_MACROVERSION *
20 DM_ERR_INVALID_MACRORELEASE *

IBM SMAPI Reference


21 DM_ERR_MACRO_NESTING *
22 DM_ERR_INVALID_KEYWORD
23 DM_ERR_INVALID_KEYTYPE
24 DM_ERR_INVALID_KEYWORD
25 DM_ERR_EMFILE
26 DM_ERR_ENOENT
29 DM_ERR_UNDEFINED
30 DM_ERR_LOAD_RESOURCE_DLL
31 DM_ERR_EBADF
32 DM_ERR_ENOSPC *
33 DM_ERR_ACT_FILE_PARSE *
34 DM_ERR_INI_FILE_PARSE *
35 DM_ERR_EXPDLL_TIMEOUT
36 DM_ERR_EXPDLL_QUERYFUN_FAILED
37 DM_ERR_EXPDLL_LOAD_FAILED
38 DM_ERR_EXPDLL_ERR
39 DM_ERR_SYSTEM_PARM_LONG
40 DM_ERR_OUT_OF_SYSTEM_RES
41 DM_ERR_BAD_EXE_FORMAT
42 DM_ERR_NOUPDATE
43 DM_ERR_SET_AFFECT_FLAG *
44 DM_ERR_UNEXPECTED_EOF *

IBM ViaVoice SDK for Windows


DMAPI Return Codes and Messages

DMAPI Message Explanations

The following are explanations for the DMAPI messages.

DM_ERR_ACT_FILE_PARSE

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

DM_ERR_BAD_EXE_FORMAT

Explanation:

The specified EXE file is invalid. It may be a non-Win32 EXE, or there may be an error in the EXE
image.

User response:

Correct the application programming error.

DM_ERR_DUPLICATE_MACRO

Explanation:

An attempt was made to load an already existing macro.

User response:

None.

IBM SMAPI Reference


DM_ERR_EACCESS

Explanation:

An error occurred attempting to access a macro file. Either the specified file is a directory, or you
attempted to write to a read-only file.

User response:

Correct the file name and try the call again.

DM_ERR_EBADF

Explanation:

The file is not opened.

User response:

Correct the application programming error.

DM_ERR_EMFILE

Explanation:

No more file handles are available.

User response:

Correct the application programming error.

IBM ViaVoice SDK for Windows


DMAPI Return Codes and Messages

DM_ERR_ENOENT

Explanation:

The specified file or path was not found.

User response:

Try again with a different file or path name.

DM_ERR_ENOSPC

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

DM_ERR_EXPDLL_ERR

Explanation:

An error occurred executing a DLL function.

User response:

Correct the application programming error.

IBM SMAPI Reference


DM_ERR_EXPDLL_LOAD_FAILED

Explanation:

DMAPI was unable to load a DLL.

User response:

Correct the application programming error.

DM_ERR_EXPDLL_QUERYFUN_FAILED

Explanation:

DMAPI was unable to load a function of a DLL.

User response:

Correct the application programming error.

DM_ERR_EXPDLL_TIMEOUT

Explanation:

The execution of a DLL function timed out.

User response:

Make sure that the call does not take longer than two seconds.

IBM ViaVoice SDK for Windows


DMAPI Return Codes and Messages

DM_ERR_FILE_READ

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

DM_ERR_INI_FILE_PARSE

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

DM_ERR_INVALID_DOMAIN

Explanation:

An invalid domain name was passed to DMAPI.

User response:

Correct the domain name and try the call again.

IBM SMAPI Reference


DM_ERR_INVALID_HANDLE

Explanation:

An invalid macro handle was passed to DMAPI.

User response:

Correct the macro handle and try the call again.

DM_ERR_INVALID_KEYTYPE

Explanation:

An invalid key type was passed to DMAPI.

User response:

Correct the type and try the call again.

DM_ERR_INVALID_KEYWORD

Explanation:

An invalid keyword was passed to DMAPI.

User response:

Correct the keyword and try the call again.

IBM ViaVoice SDK for Windows


DMAPI Return Codes and Messages

DM_ERR_INVALID_LANGUAGE

Explanation:

An invalid language code was passed to DMAPI.

User response:

Correct the language code and try the call again.

DM_ERR_INVALID_MACRO

Explanation:

An attempt was made to load an invalid macro. The macro file may be corrupted.

User response:

None.

DM_ERR_INVALID_MACROFILE

Explanation:

The macro file specified is invalid.

User response:

Correct the macro file name and try again.

IBM SMAPI Reference


DM_ERR_INVALID_MACRORELEASE

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

DM_ERR_INVALID_MACROVERSION

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

DM_ERR_INVALID_TEMPLATE

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

IBM ViaVoice SDK for Windows


DMAPI Return Codes and Messages

DM_ERR_INVALID_USERID

Explanation:

An invalid user ID was passed to DMAPI.

User response:

Correct the user ID and try the call again.

DM_ERR_LOAD_RESOURCE_DLL

Explanation:

DMAPI was unable to load the specified DLL.

User response:

Correct the application programming error.

DM_ERR_MACRO_NESTING

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

IBM SMAPI Reference


DM_ERR_MACRO_NOT_FOUND

Explanation:

DMAPI was unable to find the specified macro. Either a macro does not exist by that name, or you
specified an incorrect name.

User response:

Try the call again with a different macro name.

DM_ERR_MALLOC

Explanation:

A memory allocation failure occurred.

User response:

Correct the application programming error.

DM_ERR_MISSING_CLIPBRD_FORMAT

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

IBM ViaVoice SDK for Windows


DMAPI Return Codes and Messages

DM_ERR_NOT_ENOUGH_SHARED_MEMORY

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

DM_ERR_NOTIFY_EXCEEDED

Explanation:

The maximum number of Dictation Macro Editor sessions has been exceeded.

User response:

Close a Dictation Macro Editor session and try the call again.

DM_ERR_NOUPDATE

Explanation:

This error is returned by DmUpdate when no changes have been made to any macros or templates
since the last DmUpdate call.

User response:

None.

IBM SMAPI Reference


DM_ERR_OK

Explanation:

No error occurred.

User response:

None.

DM_ERR_OPEN_CLIPBOARD_FAILED

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

DM_ERR_OUT_OF_SYSTEM_RES

Explanation:

The system is out of memory or other system resources.

User response:

Correct the application programming error.

IBM ViaVoice SDK for Windows


DMAPI Return Codes and Messages

DM_ERR_FILE_SET_AFFECT_FLAG

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

DM_ERR_SHARED_MEM_UNDEFINED

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

DM_ERR_SYSTEM_PARM_LONG

Explanation:

A parameter specified in a system call is too long.

User response:

Correct the error and try the call again.

IBM SMAPI Reference


DM_ERR_TEMPLATE_NOT_FOUND

Explanation:

DMAPI was unable to find the specified template. Either a template does not exist by that name, or
you specified an incorrect name.

User response:

Try the call again with a different template name.

DM_ERR_TRANSFER_TO_CLIPBRD

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

DM_ERR_UNDEFINED

Explanation:

An undefined file access error occurred.

User response:

Correct the application programming error.

IBM ViaVoice SDK for Windows


DMAPI Return Codes and Messages

DM_ERR_UNEXPECTED_EOF

Explanation:

This error code is used internally by the Dictation Macro Editor.

User response:

None.

IBM SMAPI Reference


IBM ViaVoice SDK for Windows


Appendix C Speech Recognition
Engine Error Messages

These error messages are generated by the speech recognition engine. They can be found in the
error.log and engine.log files, which are located in the engine's working directory.

Bad Data in File '%s'

Indicates problems with data found in a successfully opened file. Files have been damaged or
incompatible speech data is being used. Restore the file indicated from backup or reinstall IBM
ViaVoice.

Bad Value '%s' for Tag '%s' in File '%s'

Control data is inconsistent. Files have been damaged or incompatible speech data is being used.
Restore the file indicated from backup or reinstall the IBM ViaVoice.

Duplicate Use of Vocabulary Name '%s'

A duplicate name has been used to define a vocabulary (static or dynamic). This is an application
programming error.

Exceeded Limit of %d %s

A system limit has been exceeded; for example, the maximum number of defined vocabularies is

100.
Failed to Open File '%s'

The specified file failed to open successfully. The file has probably been inadvertently erased.
Restore the file indicated from backup or reinstall IBM ViaVoice.

Missing Tag '%s' in File '%s'

A required control parameter (tag) was not found in the specified file. Control data is inconsistent.
Files have been damaged or incompatible speech data is being used. Restore the file indicated from
backup or reinstall IBM ViaVoice.

IBM SMAPI Reference


Severe Error in %s (%d)

A variety of severe error conditions that typically terminate the recognition session. File write
errors indicate file system problems (for example, the hard disk is full).

Mailbox

Errors might occur if one of the engine tasks fails and communication breaks down. Therefore, this
error is most likely secondary to the primary problem.

Label Buffer Overrun

In these cases the session is not ended, only the microphone is forced off. This situation is caused
by a very long pause in dictation (approximately 30 seconds) or by an ill-behaved application that
turns on the microphone and fails to ask for recognized words.

IBM ViaVoice SDK for Windows


Appendix D Notices

References in this publication to IBM products, programs, or services do not imply that IBM intends to
make these available in all countries in which IBM operates. Any reference to an IBM product,
program, or service is not intended to state or imply that only that IBM product, program, or service
may be used. Subject to IBM's valid intellectual property or other legally protectable rights, any
functionally equivalent product, program, or service may be used instead of the IBM product, program,
or service. The evaluation and verification of operation in conjunction with other products, except
those expressly designated by IBM, are the responsibility of the user.

IBM may have patents or pending patent applications covering subject matter in this document. The
furnishing of this document does not give you any license to these patents. You can send license
inquiries, in writing, to:

IBM Director of Licensing

IBM Corporation

500 Columbus Avenue

Thornwood, NY 10594

U.S.A.
Asia-Pacific users can inquire, in writing, to the IBM Director of Intellectual Property and Licensing,
IBM World Trade Asia Corporation, 2-31 Roppongi 3-chome, Minato-ku, Tokyo 106, Japan.

Licensees of this program who wish to have information about it for the purpose of enabling: (i) the
exchange of information between independently created programs and other programs (including this
one) and (ii) the mutual use of the information which has been exchanged, should contact IBM
Corporation, Department LZKS, 11400 Burnet Road, Austin, TX 78758 U.S.A. Such information may
be available, subject to appropriate terms and conditions, including in some cases, payment of a fee.

IBM SMAPI Reference


Trademarks

The following terms are trademarks of the IBM Corporation in the United States or other countries or
both:

IBM

Lotus

Visual Age

ViaVoice

VoiceType

The following terms are trademarks of other companies:

Intel

Pentium

Intel Corporation

Microsoft, Windows, NT, the Windows 95 logo, Visual Basic, Visual C++, Visual J++ and Developer
Studio are trademarks or registered trademarks of Microsoft Corporation.

Other company, product, and service names, which may be denoted by an asterisk (**), may be
trademarks or service marks of others.

IBM ViaVoice SDK for Windows


Index


A

access functions, data 22
added pronunciations, querying 127, 129
added words, querying 107, 109
adding
new pronunciation 40
single callback routine 39
words to vocabulary 43
administrative functions 27
alphabets, retrieving 193
alternative words, requesting a list 112
alternative words, retrieving 195
annotations, retrieving 196
API
calls, parallel session 29
starter set
command and control 31
dictation 34
application
callbacks executed by 76
closing down and disconnecting engine 34
detaching from speech engine 67
disconnecting speech engine 34
establishing recognition session 35
processing recognized commands 33
receiving reply message structures 281
retrieving name of 198, 199
writing new 31
archive size, retrieving 245
archived file name, retrieving 243
ASCII string, returning 278
associating pronunciation with a spelling 40
attribute handling functions 22
attributes
SMAPI 305
audio
data, discarding 70, 72
file, playing prerecorded 91
functions 28
audio message name, retrieving 222
audio signal, retrieving level 200
available languages, querying 121, 123

B

beginning text dictation at a new document
location 87

C

caddr_t 299
callback
dispatching 76
functions 22
removing routine 153
callbacks
speech engine/router 292
cancelling
request for playback 49
changing text context sent to speech engine 87
checking
specified word in active vocabularies 147
version of SMAPI 46
closing
connection to speech engine 74
codepage, returning 202
command
processing recognized 33
starter set APIs 31
vocabulary. dynamically change 43
communication, closing with speech engine 74
compatibility, checking SMAPI and API 46
connecting to speech engine 52
connection
closing SMAPI 51
detaching all applications from speech
engine 67
functions 25
initializing values 89
control
starter set APIs 31
correcting errors 37
correcting misrecognized word 188
current speech data, saving 165
current vocabularies enabled, querying 117

IBM SMAPI Reference


D

data
access functions 22
discarding audio and error-correction 70, 72
querying speech 134
data access functions
SmGetAlphabets 193
SmGetAlternates 195
SmGetAnnotations 196
SmGetApplication 198
SmGetApplications 199
SmGetAudioLevel 200
SmGetCodePage 202
SmGetDescriptions 203
SmGetEngineState 205
SmGetEnrollId 207
SmGetEnrollIds 208
SmGetEventId 210
SmGetEventOptions 211
SmGetFirmWords 212
SmGetFlags 213
SmGetFocusChangeReason 215
SmGetFocusState 216
SmGetGrammarPath 217
SmGetIncrements 218
SmGetItemValue 219
SmGetLanguages 220
SmGetMicState 221
SmGetMsgName 222
SmGetMsgType 223
SmGetNameValue 224
SmGetNumberWordMsgs 225
SmGetOptions 226
SmGetPercentages 227
SmGetPhraseScore 228
SmGetPhraseState 229
SmGetPreferred 231
SmGetPronunciations 232
SmGetRc 233
SmGetRcDescription 234
SmGetRcName 235
SmGetSampleRates 236
SmGetScriptFlags 237
SmGetScripts 238
SmGetService 239

SmGetSessionId 240
SmGetSeverity 241
SmGetSizes 242
SmGetSpeechDataArchive 243
SmGetSpeechDataOptions 244
SmGetSpeechDataSize 245
SmGetSpeechDataVersion 246
SmGetSpelling 247
SmGetSpellings 249
SmGetStates 251
SmGetStatus 252
SmGetTags 254
SmGetTask 255
SmGetTaskFlags 256
SmGetTasks 257
SmGetTimes 258
SmGetTopics 260
SmGetTrained 261
SmGetUserId 262
SmGetUserIds 264
SmGetUsers 266
SmGetUtteranceNumber 267
SmGetVocabList 268
SmGetVocabName 269
SmGetVocabPath 271
SmGetVocWords 272
SmGetWords 274
SmGetWordTimes 275
SmGtBinaryItemValue 201
SmReturn 277
SmReturnRcDescription 278
SmReturnRcName 279

data type
VtArg 363

data types
caddr_t 299
DM_MACRO_STRUCT 350
DM_TEMPLATE_FIELD 352
DMERROR 349
SM_ANNOTATIONl 301
SM_VOCWORD 302
SM_WORD 303
SmArg 299
SmArgVal 300
SmHandler 300

IBM ViaVoice SDK for Windows


SmMsg 302
database functions 26
default

values
querying 115
setting 179


defined vocabulary
disabling 68
enabling 77

defining

grammar-based vocabulary 57
deleting dynamic vocabulary 186
detaching

one or more sessions 67
dictation

starter set APIs 34
direct calls to speech engine 39
disabling

defined vocabulary 68

discarding
audio data 70, 72
error-correction data 70, 72

disconnecting
engine 34
speech engine 38, 74

dispatching functions 22
DM_MACRO_STRUCT 350
DM_TEMPLATE_FIELD 352
DMAPI

message explanations 425
messages 423
return codes 423


DmClose 313
DMERROR 349
DmFlushEx 314
DmFreeMacro 315
DmFreeMacroEx 316
DmFreeNames 317
DmGetGroupsOnPage 318
DmGetKey 319
DmGetKeyGroup 320
DmGetKeyGroupOption 321
DmGetKeyGroupOptionSelection 322
DmGetLastError 323
DmGetMacro 325
DmGetMacroEx 327
DmGetNumberOfGroups 329

DmGetNumberOfOptions 330
DmGetNumberOfSelections 331
DmGetTemplate 332
DmIsNumberFlagged 334
DmKeywordFromType 335
DmOpen 337
DmQueryDelimiters 339
DmQueryMacroNames 340
DmQuerySetAndStoreKey 342
DmQueryTemplateNames 341
DmSetKey 343
DmStartMacroEditor 344
DmStoreKey 345
DmTypeFromKeyword 346
DmUpdate 348
domains, querying list 135, 137
dynamic actions

change, command vocabularies 43
creating
new vocabulary 60, 63
defining
new vocabulary 57
dynamic vocabulary, deleting 186

E

enabling

defined vocabulary 77

vocabularies 32, 35
enabling recognition of next word 150
engine

directing to process speech 33, 36

disconnecting 34

disconnecting from 38

establishing a recognition session 32

establishing recognition session 35
engine messages

SMAPI 373
engine return codes

SMAPI 373
enrollment

querying user IDs 119
enrollment IDs, retrieving 203
enrollment status, retrieving 251
error messages

speech engine 441
error-correction

data, discarding 70, 72

IBM SMAPI Reference


playing back spoken words 97

utterance playback 94
errors, correcting speech recognition 37
establishing connection to speech engine 52
event ID, retrieving 210

F

firm words, retrieving 212
flags, retrieving 213
focus state, retrieving 216
format

function call descriptions 19
FSG file, retrieving path 217
function

call descriptions, format 19
calls to speech engine 39
calls, SMAPI 22
data access 22
requesting list of alternative words 112

function calls
DmClose 313
DmFlushEx 314
DmFreeMacro 315
DmFreeMacroEx 316
DmFreeNames 317
DmGetGroupsOnPage 318
DmGetKey 319
DmGetKeyGroup 320
DmGetKeyGroupOption 321
DmGetKeyGroupOptionSelection 322
DmGetLastError 323
DmGetMacro 325
DmGetMacroEx 327
DmGetNumberOfGroups 329
DmGetNumberOfOptions 330
DmGetNumberOfSelections 331
DmGetTemplate 332
DmIsNumberFlagged 334
DmKeywordFromType 335
DmOpen 337
DmQueryDelimiters 339
DmQueryMacroNames 340
DmQuerySetAndStoreKey 342
DmQueryTemplateNames 341
DmSetKey 343

DmStartMacroEditor 344
DmStoreKey 345
DmTypeFromKeyword 346
DmUpdate 348


functions
administrative 27
attribute handling 22
audio 28
callback and dispatching 22
callbacks executed by Windows

applications 76
connection 25
database 26
querying engine parameters 101
querying value of engine parameters 114
session 26
speech engine state 27
vocabulary 27

G

grammar compiler function calls
VtAddArg 355
VtCompileGrammar 356
VtGetMessage 357
VtGetTranslation 358
VtLoadFSG 360
VtSethArg 361
VtUnloadFSG 362

H

halt recognition temporarily 81

I

improving future recognition 55
increment values, retrieving 218
initializing

speech engine, available languages 121, 123
values in a connection 89

L

languages

querying available 121, 123
languages, retrieving 220
list of alternative words, requesting 112

IBM ViaVoice SDK for Windows


M

message
cancelling request for playback 49
receiving and dispatching callbacks 76
receiving from speech engine 149
message explanations
DMAPI 425
SMAPI 379
message type, retrieving 223
message types
SMAPI 375
message word count, retrieving 225
messages
DMAPI 423
SMAPI 369
microphone
turning off 83, 161
turning on 85, 162
microphone state, retrieving 221
misrecognized word, correcting 188

N

name values, retrieving 224
naming conventions 21
next word to decode, searching 150
notification
requesting when speech engine completes
decoding 79

O

opening
SMAPI 89
options field, retrieving 226
options flags, retrieving 244

P

parallel session API calls 29
parameters
querying value of engine 114
percent complete, retrieving 227
phrase score, retrieving 228
phrase state flags, retrieving 229
playback request, cancelling 49
playing
prerecorded audio file 91

playing back

spoken utterance 94

spoken words 97
predefined vocabularies, adding words to 43
preferred topics count, retrieving 231
prerecorded audio file, playing 91
processing

recognized commands 33

recognized text 36

speech, directing engine 33, 36
pronunciation

adding new 40

querying added 127, 129

querying existence 125

removing from personal pool 157
pronunciations, retrieving 232

Q

querying

added words 107, 109

available languages 121, 123

currently enabled vocabularies 117

default values for user, enrollment, task ID 115

enroll ID 141

existence of pronunciation 125

listing of added pronunciations 127, 129

sessions 133

speech data 134

speech engine functions 27

user enrollment IDs 119

user ID 141

users allowed to use speech engine 143

vocabularies, all defined 145
querying engine parameters 101
querying parameters 101

R

reason code, retrieving 215
receiving
messages
dispatching callbacks 76
messages from speech engine 149
recognition
improving future 55

IBM SMAPI Reference


recognition session

enabling defined vocabulary 77

establishing 32, 35

querying 133

temporary halt 81
recognized

commands, processing 33

text, processing 36
releasing speech focus 152
removing

callback routine 153

pronunciation from personal pool 157

words from dynamic vocabulary 154
reply message structures 281

speech engine 281
reply structure domain, retrieving 255
reply structure functions

unsolicited callbacks 295
reply structure multiple domains, retrieving 257
reply structure tags, retrieving 254
requesting

completions of specified string 47

microphone turnoff 161

speech focus 159
resetting utterance number 163
retrieving

alphabets 193

alternative words 195

annotations 196

archive size 245

archived file name 243

array of increment values 218

audio message name 222

audio signal 200

engine state 205

enroll IDs 207, 208

enrollment IDs 203

enrollment status 251

event ID 210

firm words 212

focus state 216

languages 220

message type 223

message word count 225

microphone state 221

name of application 199

name values 224
options field 226
options flags 244
options for event 211
path name of FSG file 217
percent complete 227
phrase score 228
phrase state flags 229
preferred topics count 231
pronunciations 232
reason code for focus change 215
reply structure domain 255
reply structure multiple domains 257
reply structure tags 254
return code 233
return code description 234
return code name 235
sample rates 236
script flags 237
scripts 238
service description 239
session ID 240
severity 241
single flags 213
size values 242
spelling 247
spellings 249
start/end times 275
status 252
task information 256
time values 258
topics array 260
trained values array 261
user ID 262
user IDs 264
users 266
utterance number 267
value of item 201
values 219
version identifier 246
vocabulary list 268
vocabulary name 269
vocabulary path 271
vocabulary words 272
words 274

IBM ViaVoice SDK for Windows


return code description, retrieving 234
return code name, retrieving 235
return code, retrieving 233
return codes

DMAPI 423
SMAPI 369


returning
ASCII string 278
SM_MSG return code 277
symbolic name 279
Windows codepage 202

router
callbacks 292
router.msg log 420

S

sample rates, retrieving 236
saving current speech data 165
script flags, retrieving 237
scripts, retrieving 238
searching next word to decode 150
service description, retrieving 239
session

detaching 67
disabling a defined vocabulary 68
functions 26
querying 133
recognition


establishing 32
starting a speech engine connection 52
session ID, retrieving 240
set speech engine functions 27

setting
default values 179
files used by engine 181
user information 184
value of speech engine parameter 177

setting up

vocabularies 32, 35
severity, retrieving 241
single callback routine, adding 39
size values, retrieving 242
SM_ANNOTATION 301
SM_MSG return code, returning 277
SM_VOCWORD 302
SM_WORD 303

SmAddCallback function call 39
SmAddPronunciation function call 40
SmAddToVocab function call 43
SMAPI

administrative functions 27

attributes 305

audio functions 28

callback and dispatching functions 22

checking version 46

closing connection 51

connecting 89

connection functions 25

database functions 26

engine messages 373

engine return codes 373

establishing connection 89

function calls by group 22

message explanations 379

message types 375

messages 369

opening 89

parallel session API calls 29

return codes 369

router.msg log 420

session functions 26

status codes 374

status messages 374

vocabulary functions 27
SmApiVersionCheck function call 46
SmArg 299
SmArgVal 300
SmAutoComplete function call 47
SmCancelPlayback function call 49
SmClose function calls 51
SMCOMM.H, defined reply message

structures 281
SmConnect function calls 52
SmCorrectText function call 55
SmDefineGrammar function call 57
SmDefineVocab function call 60
SmDefineVocabEx function call 63
SmDetachSessions function call 67
SmDisableVocab function call 68
SmDiscardData function call 70
SmDiscardSpeechData function call 72
SmDisconnect function call 74
SmDispatch function call 76

IBM SMAPI Reference


SmEnableVocab function call 77
SmEventNotify function call 79
SmGetAlphabets data access function 193
SmGetAlternates data access function 195
SmGetAnnotations data access function 196
SmGetApplication data access function 198
SmGetApplications data access function 199
SmGetAudioLevel data access function 200
SmGetBinaryItemValue data access

function 201
SmGetCodePage data access function 202
SmGetDescriptions function call 203
SmGetEngineState data access function 205
SmGetEnrollId data access function 207
SmGetEnrollIds data access function 208
SmGetEventId data access function 210
SmGetEventOptions data access function 211
SmGetFirmWords data access function 212
SmGetFlags data access function 213
SmGetFocusChangeReason data access

function 215
SmGetFocusState data access function 216
SmGetGrammarPath data access function 217
SmGetIncrements data access function 218
SmGetItemValue data access function 219
SmGetLanguages data access function 220
SmGetMicState data access function 221
SmGetMsgName data access function 222
SmGetMsgType data access function 223
SmGetNameValue data access function 224
SmGetNumberWordMsgs data access

function 225
SmGetOptions data access function 226
SmGetPercentages data access function 227
SmGetPhraseScore data access function 228
SmGetPhraseState data access function 229
SmGetPreferred data access function 231
SmGetPronunciations data access

function 232
SmGetRc data access function 233
SmGetRcDescription data access function 234
SmGetRcName data access function 235
SmGetSampleRates data access function 236
SmGetScriptFlags data access function 237
SmGetScripts data access function 238
SmGetService data access function 239
SmGetSessionId data access function 240
SmGetSeverity data access function 241
SmGetSizes data access function 242

SmGetSpeechDataArchive data access

function 243
SmGetSpeechDataOptions data access

function 244
SmGetSpeechDataSize data access

function 245
SmGetSpeechDataVersion data access

function 246
SmGetSpelling data access function 247
SmGetSpellings data access function 249
SmGetStates data access function 251
SmGetStatus data access function 252
SmGetTags data access function 254
SmGetTask data access function 255
SmGetTaskFlags data access function 256
SmGetTasks data access function 257
SmGetTimes data access function 258
SmGetTopics data access function 260
SmGetTrained data access function 261
SmGetUserId data access function 262
SmGetUserIds data access function 264
SmGetUsers data access function 266
SmGetUtteranceNumber data access

function 267
SmGetVocabList data access function 268
SmGetVocabName data access function 269
SmGetVocabPath data access function 271
SmGetVocWords data access function 272
SmGetWords data access function 274
SmGetWordTimes data access function 275
SmHaltRecognizer function call 81
SmHandler 300
SmMicOff function call 83
SmMicOn function call 85
SmMsg 302
SmMsgReceive function call 149
SmNewContext function call 87
SmPlayMessage function call 91
SmPlayUtterance function call 94
SmPlayWords function calls 97
SmQuery function call 101
SmQueryAddedWord function call 107
SmQueryAddedWordsEx function call 109
SmQueryAlternates function call 112
SmQueryBinary function call 114
SmQueryDefault function call 115
SmQueryEnabledVocabs function call 117
SmQueryEnrollIds 119
SmQueryLanguages function call 121

IBM ViaVoice SDK for Windows


SmQueryPhraseAlternatives function call 123
SmQueryPronunciation function call 125
SmQueryPronunciationEx function call 129
SmQueryPronunciations function call 127
SmQueryScripts function call 131
SmQuerySessions function call 133
SmQuerySpeechData function call 134
SmQueryTasks function call 135
SmQueryTopics function call 137
SmQueryUserDefault function call 139
SmQueryUserInfo funciton call 141
SmQueryUsers function call 143
SmQueryVocabs function call 145
SmQueryWord function call 147
SmRecognizeNextWord function call 150
SmReleaseFocus function call 152
SmRemoveCallback function call 153
SmRemoveFromVocab function call 154
SmRemovePronunciation function call 157
SmRequestFocus function call 159
SmRequestMicOff function call 161
SmRequestMicOn function call 162
SmRestoreSpeechData function call 163
SmReturn data access function 277
SmReturnRcDescription data access
function 278
SmReturnRcName data access function 279
SmSaveSpeechData function call 165
SmSet function call 167
SmSetArg function call 176
SmSetBinary function call 177
SmSetDefault function call 179
SmSetDirectory function call 181
SmSetUserDefault function calls 182
SmSetUserInfo function call 184
SmUndefineVocab function call 186
SmWordCorrection function call 188
specified word, checking active vocabularies 147
speech attributes
querying default 115
speech data
querying 134
speech data, saving current 165
speech engine 101
adding new pronunciation 40
adding words to vocabulary 43
callbacks 292
changing text context sent to 87

closing connection 51
connecting to 52
disabling a defined vocabulary 68
discarding audio and error-correction data 70,
72
disconnecting 67, 74
enabling vocabulary 77
error messages 441
function calls
SmAddPronunciation 40
SmAddToVocab 43
SmApiVersionCheck 46
SmAutoComplete 47
SmCallback 39
SmCancelPlayback 49
SmClose 51
SmConnect 52
SmCorrectText 55
SmDefineGrammar 57
SmDefineVocab 60
SmDefineVocabEx 63
SmDetachSessions 67
SmDisableVocab 68
SmDiscardData 70
SmDiscardSpeechData 72
SmDisconnect 74
SmDispatch 76
SmEnableVocab 77
SmEventNotify 79
SmHaltRecognizer 81
SmMicOff 83
SmMicOn 85
SmNewContext 87
SmPlayMessage 91
SmPlayUtterance 94
SmPlayWords 97
SmQuery 101
SmQueryAddedWords 107
SmQueryAddedWordsEx 109
SmQueryAlternates 112
SmQueryBinary 114
SmQueryDefault 115

IBM SMAPI Reference


SmQueryEnabledVocabs 117
SmQueryEnrollIds 119
SmQueryLanguages 121
SmQueryPhraseAlternatives 123
SmQueryPronunciation 125
SmQueryPronunciations 127
SmQueryPronunciationsEx 129
SmQueryScripts 131
SmQuerySessions 133
SmQuerySpeechData 134
SmQueryTasks 135
SmQueryTopics 137
SmQueryUserDefault 139
SmQueryUserInfo 141
SmQueryUsers 143
SmQueryVocabs 145
SmQueryWord 147
SmReceiveMsg 149
SmRecognizeNextWord 150
SmReleaseFocus 152
SmRemoveCallback 153
SmRemoveFromVocab 154
SmRemovePronunciation 157
SmRequestFocus 159
SmRequestMicOff 161
SmRequestMicOn 162
SmRestoreSpeechData 163
SmSaveSpeechData 165
SmSet 167
SmSetArg 176
SmSetBinary 177
SmSetDefault 179
SmSetDirectory 181
SmSetUserDefault 182
SmSetUserInfo 184
SmUndefineVocab 186
SmWordCorrection 188

function calls to 39

halt recognition temporarily 81

naming conventions for IDs 21

notification when decoding complete 79

querying
default attributes 115
domain list 135, 137


querying parameters 114
receiving messages from 76
reply message structures 281
request for string completion 47
setting


files to use 181

value of parameter 177
single callback routine,adding 39
state


functions 27

retrieving 205
terminating connection 51
turning off microphone 83
turning on microphone 85
updating user’s voice model 55


speech focus
releasing 152
requesting 159

speech recognition errors
correcting 37

spelling, associating pronunciation with 40

spelling, retrieving 247

spellings, retrieving 249

spoken words, playing back 97

start/end times, retrieving 275

starter set APIs
command and control 31
dictation 34

status codes
SMAPI 374

status messages
SMAPI 374

status, retrieving 252

string functions
SmAutoComplete 47

symbolic name, returning 279

T

task information, retrieving 256
temporary halt of recognition session 81
terminating SMAPI connection 51

IBM ViaVoice SDK for Windows


text

processing recognized 36
time values, retrieving 258
topics array, retrieving 260
trained values array, retrieving 261
turning off microphone 83
turning on microphone 85

U

unlimited vocabulary dll
VtGeneratePronunciations 367
unsolicited callbacks

reply structure functions 295
updating user’s voice model 55
user

information, setting 184

querying enrollment IDs 119
user ID, retrieving 262
user IDs, retrieving 264
users, retrieving 266
utterance

cancelling request for playback 49
playing back 94
resetting number 163

utterance number, retrieving 267

V

values, retrieving 219
version identifier, retrieving 246
version, checking SMAPI and API 46
vocabularies

checking for specified word 147
querying added words 107, 109
querying currently enabled 117
setting up and enabling 32, 35

vocabulary
adding words to 43
deleting dynamic 186
disabling defined 68
dynamically creating new 60, 63
enabling defined 77
functions 27
removing words from 154

vocabulary list, retrieving 268
vocabulary name, retrieving 269
vocabulary path, retrieving 271

vocabulary words, retrieving 272
voice model, updating user’s 55
VtAddArg 355
VtArg 363
VtCompileGrammar 356
VtGeneratePronunciations 367
VtGetMessage 357
VtGetTranslation 358
VtLoadFSG 360
VtSethArg 361
VtUnloadFSG 362

W

Windows applications
executing callbacks 76

words
alternative, requesting list of 112
cancelling request for playback 49

words, retrieving 274

IBM SMAPI Reference



原文链接: http://blog.csdn.net/yincheng01/article/details/3511777

你可能感兴趣的:(IBM语音技术API说明,比较锻炼英文能力)