Browse
 
Tools
Rss Categories

LVSpeechPort::StreamStartListening

Reference Number: AA-01680 Views: 8130 0 Rating/ Voters

Sets the port in a listening mode, allowing for data to be streamed via StreamSendData, but will not begin processing the audio until all registered grammars have started loading and have had their meta tags processed. Recommended over StreamStart; see Remarks, below, for more details.

Function

  • int StreamStartListening(void)

Parameters

None.

Return Values

LV_SUCCESS

No errors; stream set up correctly.

LV_INVALID_HPORT

The port is not valid (either CreateClient has not been called or DestroyClient has been called prior to this call).

LV_FAILURE

The operation failed because the port was shutting down.

LV_EXCEPTION

An exception occurred while processing the request.

Remarks

StreamStartListening, introduced in LumenVox version 10.5, is an improved version of StreamStart, and should be used instead of StreamStart. It functions similarly to StreamStart, except it works in conjunction with RegisterGrammarForPendingStream to delay the processing of audio until all registered grammars have started loaded and have had their meta tags processed. 

Any audio received by the streamer after StreamStartListening has been called but before all registered grammars have had their meta tags processed will be saved. This means that StreamStartListening can be safely called even before grammars have been loaded without fear of losing audio data (you should still wait until all grammars have finished loading before performing a decode). With StreamStart, all grammars must have already been loaded and activated before calling StreamStart.

The general pattern we recommend you follow when using StreamStartListening is:

  1. Register all grammars you intend to use for a given recognition.
  2. Call StreamStartListening
  3. On separate threads, load and activate each grammar (if a grammar was already loaded from a previous recognition, you may skip loading and just activate it, but be careful of relying on this if you are using dynamic grammars that may have changed)
  4. Once STREAM_STATUS_END_SPEECH has been returned and all grammars have finished loading/activating, call Decode.
  5. Call DeactivateGrammars to deactivate all grammars in preparation for the next stream.

You can deviate from the above pattern, but it may cause unexpected behavior. For instance, when calling StreamStartListening, you must register grammars either before or after calling StreamStartListening (if no grammars are registered the stream will not be processed). Also, if you do not load or activate any grammars after calling StreamStartListening the stream will not be processed, because the check to begin processing audio occurs on the call to LoadGrammar and ActivateGrammar.

StreamStartListening is optional for speech applications, but must be used by any applications that use the LumenVox Call Progress Analysis functionality to change the voice activity detection mode (e.g. to turn on tone detection or CPA modes).

See Also