The present invention relates generally to communication systems and methods, and specifically to efficient methods for collecting data via a telephone network.
Interactive voice response (IVR) is a well-known model for automated communication with telephone users over a telephone network. Typically, when a user dials in to a certain number that is configured for IVR, the telephone network switch opens a voice call between the user and the IVR device. The IVR device answers the call and then enunciates one or more voice prompts, to which the user responds by pressing appropriate keys on the telephone keypad. The IVR device receives the keystrokes, typically in the form of Dual-Tone Multi-Frequency (DTMF) audio signals conveyed over the telephone network, and thus records and responds to the user inputs.
Although IVR is an effective model for handling individual calls, each call to the IVR still consumes substantial machine and network resources. For each call in progress, the IVR itself must set aside sufficient computing and audio resources to handle the call for as long as the call is connected. The telephone network must also allocate communication resources to keep both legs of the call open (to the telephone and to the IVR device) at the switch or switches handling the call. As a result, in large-scale applications involving interactive response by multiple users via telephone, IVR may be impractical and excessively costly. Therefore, operators of these applications sometimes use other, less convenient alternatives for receiving inputs from telephone users, such as text-based short message service (SMS).
Embodiments of the present invention provide improved methods and systems for collecting keypad inputs from telephone users. These methods and system enable users to provide inputs to an application via a telephone network with the convenience and simplicity of voice calling, but without requiring that an IVR device be connected continuously to the call.
In some embodiments of the present invention, a novel call handling technique is initiated when a user places a call to a telephone number that is associated with an application requiring keypad inputs from the user. The telephone network switch that receives the call notifies a service control point (SCP) that is associated with the application (and hence with the telephone number that the user has called). Under instructions from the SCP, the switch opens the first leg of a connection from the switch to the telephone, and a second leg of the connection from the switch to a network peripheral, such as an audio response device. The audio response device makes an initial response to the call, thus establishing the connection with the telephone in accordance with telephone signaling conventions.
Once the connection has been established in this manner, the SCP instructs the switch to disconnect the second leg of the connection, while leaving the first leg open. The resources of the audio response device are now freed to initiate another call, and the portion of the telephone network resources associated with the second leg of the connection is freed, as well. From the point of view of the telephone user, however, the call is still connected. The resulting one-legged call is a novel use of the standard facilities of SS-7 telephone networks, which is made possible by the unique capabilities of the SCP.
Subsequently, the user may key in numeric entries via the keypad of the telephone, typically in response to some prompt unconnected with the telephone. For example, the user may be prompted by a television program that he or she is watching to press keys in order to make choices in an on-line poll. The switch receives signals in response to the user keystrokes and informs the SCP of the signals it has received. For example, the switch may convey to the SCP mid-call events corresponding to the keystrokes, as specified by Capabilities Set 1 (CS-1) or Capabilities Set 2 (CS-2) of the Intelligent Network Application Protocol (INAP) standards. The SCP processes these events, typically by reporting them to a server running the application in question. The user may press multiple keys in succession, for as long as the first leg of the call remains connected between the telephone and the switch, thus providing multiple inputs to the application.
There is therefore provided, in accordance with an embodiment of the present invention, a method for collecting information from a user of a telephone having a keypad, the method including:
Typically, the peripheral device includes an audio response device, and initiating the voice call includes receiving an audio reply from the audio response device in response to opening the second leg of the connection. In a disclosed embodiment, the telephone network includes a circuit-switched telephone network, operating in accordance with a Signaling System 7 (SS7) protocol.
In an aspect of the invention, receiving the signals includes reporting the keystrokes to a service control point (SCP). In a disclosed embodiment, reporting the keystrokes to the SCP includes generating mid-call events at the switch in response to the keystrokes, and conveying the mid-call events over the telephone network to the SCP. Additionally or alternatively, receiving the request includes, responsively to the specified telephone number, reporting the request to the SCP, and initiating the voice call and disconnecting the second leg include controlling functions of the switch responsively to instructions from the SCP.
There is also provided, in accordance with an embodiment of the present invention, a method for collecting information from a user of a telephone having a keypad, the method including:
In an aspect of the invention, opening the connection includes opening a second leg of the connection from the switch to a peripheral device, and disconnecting the second leg after initiating the voice call, while leaving the first leg of the connection open for receiving the signals responsively to the one or more keystrokes. Typically, the peripheral device includes an audio response device, and initiating the voice call includes receiving an audio reply from the audio response device in response to opening the second leg of the connection.
In some embodiments, receiving the signals includes reporting the keystrokes to a service control point (SCP). In one embodiment, the method includes conveying data from the SCP to a server indicative of the keystrokes made by the user, and tabulating the data at the server. Tabulating the data may include computing an output value based on the data, and including displaying the output value on the medium.
In a disclosed embodiment, receiving the request includes receiving multiple, respective requests from multiple users to open simultaneous voice calls to the specified telephone number, and opening the connection includes opening multiple simultaneous connections responsively to the requests, and receiving the signals includes receiving keystroke inputs from the multiple users over the simultaneous connections, and computing the output value includes tabulating selections made by the multiple users in response to the prompt, as indicated by the keystroke inputs. In this embodiment, the medium includes a television medium, and presenting the user with the prompt includes providing the prompt in a television program, and displaying the output value includes presenting the output value on the television program following the prompt.
There is additionally provided, in accordance with an embodiment of the present invention, apparatus for collecting information from a user of a telephone having a keypad, the apparatus including a service control point (SCP), which is adapted to receive a first message from a switch in a telephone network, indicative of a request received by the switch to open a voice call from the telephone to a specified telephone number, and responsively to the first message, to initiate a voice call by causing the switch to open a first leg of a connection from the switch to the telephone and to open a second leg of the connection from the switch to a peripheral device,
There is further provided, in accordance with an embodiment of the present invention, apparatus for collecting information from a user of a telephone having a keypad, the apparatus including:
The present invention will be more fully understood from the following detailed description of the embodiments thereof, taken together with the drawings in which:
Signals from telephone 30 are conveyed via a base station 32 to a circuit-switched telephone network 34. Although in this example, telephone 30 is shown to be a cellular telephone, the principles of the present invention are equally applicable to wireline telephones and networks. User 22 first dials the telephone number indicated by the announcer on the television program, and a voice call is accordingly opened between telephone 30 and network 34. The voice call is established and maintained in a novel manner that minimizes the use of network-side resources in handling the call, as described in detail with reference to the figures that follow.
Once the call is established, each keystroke by the user on the telephone keypad causes an event to be generated in network 34 and conveyed to a server 36. The server records the events, i.e., it records the keystroke choices made by user 22 and by other users who call in to the specified number. Multiple keystrokes may be input and recorded in this manner by each user, and by many different users simultaneously, for as long as the user voice calls remain connected. In this manner, for example, the television program may present a sequence of questions, and the users may respond to each one. The user voice call may remain open in this manner for an extended period of time, during which it is necessary for the user to press only a single key or sequence of keys to provide each successive input to server 36. This user-friendly model contrasts with methods known in the art for response using utilities such as SMS, wherein the user must send each successive response as a separate SMS message. Server 36 is thus able to collect many inputs from many users simultaneously. Typically, in the exemplary embodiment shown in the figure, the results are tabulated in real time and are then shown on the television program immediately after each question or a group of questions is presented to the viewers.
Although in the example shown in
When the user of telephone 30 places a call to a given telephone number, a corresponding call request signal is received by a switch 40 in network 34. In accordance with the IN model, switch 40 is programmed with a call control function (CCF) and a service switching function (SSF). When the CCF detects signaling passing through the switch that is directed to a telephone number belonging to an IN service, it suspends the call temporarily and passes a trigger to the SSF. Based on the trigger, the SSF of switch 40 passes control of the call to a smart service control point (SCP) 42. The SCP typically comprises hardware interfaces for communicating with switch 40 and server 36, and a processor that is programmed in software to carry out the functions described hereinbelow. SCP 42 processes the call, and then sends instructions back via INAP to switch 40 as to how the call should be handled by the CCF. Although SCP 42 has novel capabilities that are required for carrying out this embodiment of the present invention, switch 40 and other elements of network 34 may be standard, off-shelf components, operating in accordance with the SS7 and INAP standards without modification.
In the example illustrated in
Switch 40 notifies SCP 42 that the call has been connected. In response, the SCP immediately instructs the switch to disconnect the second leg of the call, between the switch and IVR device 44. Subsequently, only one half of the call remains connected, i.e., the first leg between telephone 30 and switch 40. In conventional network implementations, this remaining leg would immediately be disconnected, as well. In the present embodiment, however, the “half call” between telephone 30 and switch 40 remains open. From the point of view of user 22, telephone 30 is still connected by an ordinary voice call to the number that he has dialed.
While the half call remains open, user 22 presses keys on the telephone keypad in order to indicate his selections or other inputs in response to prompts provided on television 24. Each keystroke generates a corresponding signal to switch 40. In response to each such signal, the SSF of switch 40 generates a mid-call event, which it conveys to SCP 42 in the manner specified by INAP. Each of these mid-call events indicates to SCP 42 the key that user 22 has pressed.
SCP 42 notifies server 36 of each call that is established and each keystroke event that it receives in the context of this half-call keypad entry service. (SCP 42 may be configured to perform other IN services, as well, but only the keypad entry service is relevant to the present embodiment.) SCP 42 may communicate with server 36 using any suitable data communications protocol known in the art. For example, the SCP and server may be connected to communicate via a packet network (not shown) by means of TCP/IP packets. Server 36 is programmed to tabulate the keystroke data and to perform appropriate actions with respect to the data, such as reporting the data to television station 26 in the example of
To complete the call, SCP 42 instructs switch 40 to open the second leg of the call to IVR device 44. INAP provides a number of different message types that can be used for this purpose. For example, the SCP may send the switch an ETC (Establish Temporary Connection) or ICA (Initiate Call Attempt) message. In response to this message, switch 40 initiates a connection with the IVR device. Typically, the switch uses conventional ISUP (ISDN User Part) signaling for this purpose, such as an IAM (Initial Address Message) signal, which reserves a circuit to carry the call. The IVR device responds by accepting the call and playing an audio message or other signal, as described above. The second leg of the call is thus connected.
Upon connection of the call, switch 40 sends an event message to SCP 42 to indicate that the call has been answered. SCP 42 notifies server 36 that a new call has been opened, and the server instructs the SCP to begin monitoring keystrokes made on telephone 30. The SCP immediately instructs switch 40 to disconnect the second leg of the call, between the switch and IVR device 44. The form of the message that is used for this purpose depends on the type of message that the SCP sent to open the call. For example, if the SCP sent an ETC message to open the call, it may now send a DFC (Disconnect Forward Communication) message with respect to leg 2. Alternatively, if the SCP previously sent an ICA message, it may now send a RCP (Release Call Party) message. In response to the message from the SCP, switch 40 disconnects the IVR device from the call and releases the telephone network circuit that was reserved for the second leg. Upon disconnection of the second leg of the call, IVR device 44 also releases the resources that it allocated for handling the call, and these resources are now available to take a call from another telephone user.
After disconnection of the IVR device, user 22 enters keystrokes using the keypad of telephone 30. In response to each keystroke (up to the maximum specified by the previous RRB message), switch 40 reports a mid-call event to SCP 42. The SCP then reports each keystroke detected to server 36. This reporting procedure continues for the duration of the call, or until the server instructs the SCP to stop monitoring the call (as shown in
Although the embodiments described above make use of the features of certain communication protocols and signaling provided by these protocols, the principles of the present invention may similarly be applied over telephone networks of other types, using other suitable protocols and message types. It will thus be appreciated that the embodiments described above are cited by way of example, and that the present invention is not limited to what has been particularly shown and described hereinabove. Rather, the scope of the present invention includes both combinations and subcombinations of the various features described hereinabove, as well as variations and modifications thereof which would occur to persons skilled in the art upon reading the foregoing description and which are not disclosed in the prior art.