This invention relates to a method and apparatus for multimodal voice ad web services.
As devices become smaller, modes of interaction other than keyboard and stylus are a necessity. In particular, small handheld devices like cell phones and PDAs serve many functions and contain sufficient processing power to handle a variety of tasks. Present and future devices will greatly benefit from the use of multimodal access methods.
Multichannel access is the ability to access enterprise data and applications from multiple methods or channels such as a phone, laptop or PDA. For example, a user may access his or her bank account balances on the Web using an Internet browser when in the office or at home and may access the same information over a dumb phone using voice recognition and text-to-speech when on the road.
By contrast, multimodal access is the ability to combine multiple modes or channels in the same interaction or session. The methods of input include speech recognition, keyboard, touch screen, and stylus. Depending on the situation and the device, a combination of input modes will make using a small device easier. For example, in a Web browser on a PDA, you can select items by tapping or by providing spoken input. Similarly, you can use voice or stylus to enter information into a field. With multimodal technology, information on the device can be both displayed and spoken.
Multimodal applications using XHTML+Voice offer a natural migration path from today's VoiceXML-based voice applications and XHTML-based visual applications to a single application that can serve both of these environments as well as multimodal ones. A multimodal application integrates voice interface and graphical user interface interaction by setting up two channels, one for the graphical user interface and another for the voice. At the time of writing the XHTML+Voice (X+V) Profile 1.2 was published at www.voicexml.org on 16 Mar. 2004.
In a known implementation of a multimodal browser with remote voice processing a voice channel is set up between the client and the voice server and allocated to carry the voice data for the duration of the voice interaction within a X+V session. The voice channel is disconnected after the voice interaction and the X+V session continues. For each separate interaction within the X+V session a new voice channel must be set up since this avoids consuming costly voice resources on the server when the X+V session is idle.
Setting up and closing down a voice channel for each voice interaction has the disadvantage of increasing the response time of each and every voice interaction due to the time taken to open and close voice channels using present protocols (SIP and RTP). The added latency is a direct function of the network bandwidth available between the device and the server. This causes problems on low bandwidth networks such as slow internet connections and on a slow wireless network. For instance, the network bandwidth on pre-3G wireless networks is limited.
According to a first aspect of the present invention there is provided a method or controlling an audio connection from an audio interface to an audio processor comprising setting up a processor link for audio data with the audio processor; setting up an interface link for audio data with the audio interface in an interface session in response to the setting up of the audio interface session; connecting the processor the start of an audio interaction within the interface session whereby audio data can flow between the audio interface session and the audio processor; disconnecting the processor link and the interface link in response to a signal indicating the end of the audio interaction; and taking down the interface link in response to the end of the interface session.
Virtualizing the IVR ports for use on a per turn basis whilst retaining a constant connection between the virtualizing unit and the device is certainly novel. Setting up a RTP channel using the SIP Protocol over a low bandwidth network takes undue capacity because one needs to identify the session number and IVR port number in the hand shaking. Furthermore a SIP call is used for new calls and resources (VoiceXML browser, speech engines, etc) need to be allocated before the RTP channel is setup. The new connection protocol uses a single signal trigger to achieve the same connection—no session number is needed because the signal is sent in an existing session channel. No port number, session, or voice engine resource allocation is needed because the ports are already allocated. The only allocation required is an available and configured RTP channel. Furthermore the new connection protocol uses an existing signal to trigger the virtual circuit so there is no setup overhead at all.
The advantages of the creating a connectable and disconnectable audio channel (virtual circuit) are that: 1) the system adds virtually no latency to the response time of the interaction when the number of simultaneous virtual circuits is less than or equal to the physical IVR ports available; 2) No code change is needed on the client and on the IVR; 3) when the number of virtual circuits exceeds the number of physical IVR ports available, the system performance degrades gracefully and 4) due to the permanent voice circuit between the device and the switch, any user audio input is captured in the switch and can be later played back to the IVR once a virtual circuit becomes available.
Giving control of virtual voice channel connect and disconnect to an intermediate controller allows both the client and server to trigger connects and disconnects.
The audio processor may be an interactive voice response system with an optional voice server for speech recognition and/or text-to-speech.
The audio interface can be a VoiceXML browser or a XML browser with voice functionality for multimodal operation.
The method further comprises buffering the audio data if there is a delay connecting the interface link with the processor link.
The setting up a processor link with the audio processor step comprises negotiating a RTP connection using SIP protocol.
The signal triggering the start of an audio interaction is a pre-existing signal indicating the start of a multimodal dialogue.
The signal triggering the end of an audio interaction is a pre-existing signal indicating the synchronisation of fields in a multimodal dialogue.
Embodiments of the invention will now be described, by means of example only, with reference to the accompanying drawings in which:
The system of the preferred embodiment comprises a plurality of clients 10.1 to 10.n connected through a network 11 to a multimodal server 12. Each client 10 comprises: an XHTML browser 14; an interaction manager 16; and audio hardware 18. The server 12 comprises: an X+V document database 20, an XHTML+Voice(X+V) filter 22; a VoiceXML (VXML) browser 24; an interactive voice response system (IVR) 26; a voice engine 28; and a switch 30.
The network 11 carries: an XHTML (X) channel 32; a CTRL (control) channel 34; a SIP (Session Initialisation Protocol) channel 36; and an RTP (Real-Time Protocol) channel 38. The X channel 32 carries the XHTML application for the X+V interaction. In the preferred embodiment the CTRL channel 34 carries a sync signal for synchronising corresponding XHTML and VXML fields. X+V defines the concept of corresponding fields in XHTML forms and VXML forms. A sync data event signal is sent when a multimodal interaction to synchronise one XML field with the corresponding XML fields. The RTP channel 38 carries the data for the audio. The SIP channel 36 is used to setup the RTP channel. The CTRL, RTP and SIP channels do not connect the client 10 directly to the VXML browser 24/IVR 26 but via the switch 30. The switch 30 consumes very little resource and can therefore support a large number of concurrent clients 10, larger than the IVR capacity available.
The preferred embodiment is described with respect to one client 10 and one RTP channel 38 but the advantages of the invention become apparent when there are many more clients than there are voice channels.
The client XHTML browser 14 interprets an XHTML document received via the X channel 32. The XHTML browser 14 is a known XHTML browser with added functionality to interact with a VXML browser and interact with audio hardware.
The interaction manager 16 controls the interactions between the XHTML browser 14 and the VXML browser 24 by sending and receiving control information on the CTRL (control) channel 34 and SIP (Session Initialisation Protocol) channel 36. The important aspect of the interaction between the XHTML browser 14 and the VXML browser 24 is the sync event signal which is sent from interaction manager 16 just before the voice interaction and the sync data signal which is sent after the voice interaction. The sync event signal triggers a voice dialogue in the VXML browser 24, The sync data signal was synchronizes the corresponding field data after the voice interaction.
The audio content is sent and received on the RTP (Real-Time Protocol) channel 38 by the audio hardware under the control of the interaction manager 16.
The X+V document database 20 stores X+V documents and sends them on request to the X+V filter 22.
The X+V filter 22 acquires X+V documents from the X+V document database 20 on request from an XHTML browser 14. The X+V documents are filtered into the XHTML component parts and VXML component parts. The XHTML component parts are sent to the XHTML browser 14 and the VXML component parts are sent to the VXML browser 24. The XHTML component part contains voice handlers to show corresponding X and V fields and mark the parts of the XHTML where interaction with the VXML browser is required.
The VXML browser 24 is a conventional VXML browser. The VXML browser receives requests to perform voice interactions using VXML component parts of an X+V document for an X+V session. The VXML browser manages voice interactions within that X+V session. Processing of individual voice functions is passed to the IVR.
Although in the preferred embodiment the VXML browser 24 and X+V filters are shown in the server 12 they could also be implemented on the client 10.
The IVR 26 processes voice interactions. Pre-recorded prompts can be played in response to requests from a browsed VXML document parts and dual tone multi-frequency signals (DTMF) received as inputs to browsed VXML document parts. The IVR 26 also interfaces the voice engine 28. The IVR 26 connects to the SIP channel 36 and RTF channel 38 through the switch 30.
The voice engine 28 performs speech recognition input and text to speech output for the IVR 26.
The switch 30 comprises a multiplexer 40 and a buffer 42. The multiplexer 40 connects one of a large number of client voice links (between itself and potentially thousands of mobile device clients) with one of a smaller number of IVR voice links (between itself and the IVR). When the switch 30 intercepts a sync event signal on a control channel (CTRL) it connects the corresponding client voice link with an IVR voice link to create a virtual voice circuit between the client and an IVR port.
Once created the sync event signal is passed through to the VXML browser 24 for processing of the voice interaction. The VXML browser 24 may update the VXML field and then instruct the IVR 26 to play a prompt and take voice input over the virtual circuit. The virtual circuit lasts only for the duration of a single voice interaction (a ‘conversational turn’) and the end of the interaction is signalled by a sync data signal. On trigger of the sync data signal the switch 30 disconnects the virtual circuit. Voice resources for the virtual link can then be reused by another client device immediately upon disconnection. For scalability, the switch could be connected by a high speed network to the IVR.
In the preferred embodiment RTP channels 38 are opened at the first voice interaction during a X+V session. Alternatively the switch can be configured to open an RTP sessions before the first voice interaction at the start of the X+V session. For the pre-opened RTP channels, the voice channel between the switch 30 and the IVR 26 remains connected. This means that when a new virtual circuit needs to be set up, it becomes simply a case of setting up the routing within the switch and no additional physical call set up with the IVR needs to take place. In practice this means adding negligible latency to the responsiveness of the system.
In the event that all physical IVR ports are in use (i.e. too many devices are attempting to perform voice interaction at the same time), the switch 30 can store the audio in the buffer 42. When later an IVR port becomes available a virtual circuit is set up and the buffered audio is played back to the IVR thus completing the interaction (e.g. leaving a voice message). Of course, if this happens too often, then it means that the system is at 100% utilisation and additional IVR ports are required.
To illustrate the method of the present embodiment the events of two typical voice interactions are now described with reference to the event diagram of
Using a handheld PDA a user surfs to a flight information website to find out the estimated time of arrival of a flight. The GUI displays the enquiry form with two fields: the flight number and date of flight. The user focuses on the first field and an audio prompt is played “please enter the flight number”. The user enters the flight number using the keyboard on his PDA (this interaction is described with reference to the ‘web sync’ below). The user then focuses on the next field and an audio prompt is heard ‘please enter the date’. This time the user uses the audio hardware says ‘today’ into a microphone. The voice data is processed and that day's date is automatically inserted into the date field. This interaction is described in the ‘voice sync’ event sequence below. In this example the two fields are filled in and the flight information site returns the estimated time of arrival—in text form or voice or both.
Initially the client 10 requests 50 that a voice channel 38 is set up and a one time SIP request is sent on the SIP channel 36 to the IVR 26 to set up a voice channel 38. However, instead of a client 20 to server voice channel 38, one client link between the switch 30 and the client is set up 52 and at least one serve link between the switch and the server is set up 54. The client link and the server link form a connectable voice circuit which may be connected and then disconnected by the switch. The number of server links is limited by the number of ports on the IVR and the number of client links is limited by the implementation of the switch 30.
In
A voice sync interaction 76 in
Only when the client device is about to be switched off is a voice take down signal sent 97. In response to this signal, the switch takes down 98 the client link and the server takes down 99 the IVR link.
In summary, the embodiment is based on being able to locate a voice server, temporarily allocate it, send it the audio of you saying “When is today's flight 683 due to arrive?”, getting the results of what you said back in the browser, and deallocating the voice server for use by the next person talking into their browser. Voice channels and IVR ports are initially set up by a switch and the IVR using conventional audio protocols. The Voice channels are not initially connected to the client. The switch handles the allocation and deallocation of IVR voice channels without having to continuous communication with the IVR. A user indicates (usually by pressing a PTT button) to the client device that he wishes to initiate a voice interaction during an X+V session. This translates to a request on the CTRL channel to synchronise the XHTML and VXML forms which the embodiment uses as a trigger for the VXML browser to execute a conversational turn. The multiplexer intercepts this control command and connects the virtual voice circuit between the device and an existing open but unattached voice port. The virtual circuit is connected without having to set up an RTP channel. The CTRL signal is then forwarded to the interaction manager so that the conversation can take place. At the end of the conversation the virtual circuit is disconnected.
Number | Date | Country | Kind |
---|---|---|---|
0507148.5 | Apr 2005 | EP | regional |
PCT/EP2006/061380 | Apr 2006 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP2006/061380 | 4/6/2006 | WO | 00 | 10/1/2007 |