The advent of Voice Over Internet Protocol (“VoIP”) has added another layer of complexity to the modern world of telephony. VoIP allows users to make telephone calls using a broadband Internet connection instead of conventional wired or wireless telephone lines. Some VoIP services may only allow users to call other people using VoIP devices. However, many services also allow users to call anyone who has a telephone number, including local, long distance, mobile, and international numbers. While some services only work over a computer or a special VoIP phone, other services allow use of a traditional telephone through an adaptor.
Cellular telephone service has also become popular, and most cell phone services permit connections to any other type of telephone service, including cellular, landline, and VoIP services. Protocols for handing off calls from one type of service to another type of service continue to emerge. For example, it is common for a telephone call initiated by a cell phone user to a VoIP device user to be connected as a pure VoIP call. However, the data transport mechanism of the cell phone typically does not have enough bandwidth to sustain high voice quality for a pure VoIP call.
The present disclosure describes methods for establishing a hybrid voice session between a telephone device and a VoIP device.
In one embodiment, a caller on a mobile device initiates a request for a voice session with a callee on a VoIP device by clicking on callee's contact information listed in the mobile device's address book. Because the caller and callee both run an instant messaging application on their devices, the contact information includes a unique virtual identifier for the callee, such as an email address. The virtual identifier includes a presence feature which indicates whether or not the callee is online. If the virtual identifier indicates that the callee is online, then the request will be enabled, and a hybrid voice session will be established using a mobile voice channel and a VoIP voice channel.
In one embodiment, the request is enabled by creating a call registration record using a mobile data network. The record is sent by the mobile device to a call registration server in the VoIP network, and includes attributes of the voice session, including a device identification of the mobile device (the telephone number of the caller's cell phone), the virtual identifier of the callee, and the virtual identifier of the caller. In addition, the record may include the expiration time of the call, and a subject of the call. The caller then dials the VoIP service provider, which retrieves the registration record based on the mobile device identifier. The callee is then identified from the registration record, and a request to notify the callee is generated. The notification request is send to the VoIP device where the callee is signed in, and if the callee accepts the proposed voice session, a mobile voice session is established between the mobile device and a gateway device, and a VoIP voice session is established between the gateway device and the VoIP device.
In one embodiment, the request is enabled by interacting with an interactive voice response (“IVR”) system. The caller dials the VoIP service provider, which accepts the call because the telephone number dialed is a VoIP number. A mobile voice session is then established between the mobile device and a gateway device, and a VoIP voice session also is established between the gateway device and the IVR system. The IVR system sends a ready signal back to the mobile device, and the mobile device then sends the virtual identifier of the callee to the IVR system. Preferably, the mobile device converts the virtual identifier to a series of digits and dials those digits to the IVR system. The VoIP network identifies and locates the callee based on the digits sent to the IVR system, and sends a notification to the VoIP device where callee is signed in regarding the proposed voice session. If the callee accepts the proposed voice session, the VoIP voice session is modified to establish a VoIP voice channel between the gateway device and the VoIP device.
In one embodiment, the request is enabled by interacting with an IVR system. The caller dials the VoIP service provider, which accepts the call because the telephone number dialed is a VoIP number. A first voice session is then established between the telephone device and a gateway device, and a VoIP voice session also is established between the gateway device and the IVR system. The IVR system sends a voice prompt back to the telephone device, and the caller on the telephone device then speaks a command that identifies the intended callee. The VoIP network identifies and locates the callee based on the command sent to the IVR system, then sends a notification to the VoIP device where callee is signed in regarding the proposed voice session. If the callee accepts the proposed voice session, the VoIP voice session is modified to establish a VoIP voice channel between the gateway device and the VoIP device.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
The present disclosure describes systems and methods whereby the user of a mobile device (the “caller”) establishes a hybrid voice session with the user of a VoIP device (the “callee”) by clicking on a contact in the contact list of the mobile device. The voice session is considered a hybrid session because it is not a pure VoIP call, i.e., where the voice goes through the IP network to and from both the mobile device and the VoIP device. Instead, the hybrid voice session utilizes multiple media channels, such as the voice channel in the mobile network, and the VoIP channel in the VoIP network, thereby taking advantage of the presence, signaling, and notification infrastructure of the VoIP network. In one embodiment, the data channel of the mobile network is utilized to create a call registration record prior to enabling the hybrid communication channel.
It is now common for many device users, including mobile and VoIP users, to load an instant messaging client application onto their devices in order to have real time chat sessions with others. Popular instant messaging services include: Windows Live Messenger; AOL Instant Messenger, Excite/Pal, Gadu-Gadu, Google Talk, iChat, ICQ, Jabber, Qnext, QQ, Skype, Trillian and Yahoo! Messenger. Such systems require that each user be assigned a unique virtual identifier, such as an email address, that includes a “presence” feature. When a user is logged onto the messaging system, the presence feature will indicate that the user is online. Advantageously, the presence feature may be utilized to facilitate establishing a voice session with a VoIP user that is online.
The technologies described herein are operational with numerous general purpose or special purpose computing system environments or configurations. Examples of well known computing systems, environments, and/or configurations that may be suitable for use include, but are not limited to, personal computers, server computers, hand-held or laptop computing devices, personal digital assistants, telephones (wired, wireless, or cellular), multiprocessor systems, microprocessor-based systems, set-top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
The system may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, etc., that perform particular tasks or implement particular abstract data types. The system may also be implemented in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
With reference to
Computer 110 typically includes a variety of computer readable media. Computer readable media can be any available media that can be accessed by computer 110 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes both volatile and nonvolatile media, and removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (“DVD”) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can accessed by computer 110. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above should also be included within the scope of computer readable media.
The system memory 130 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 131 and random access memory (RAM) 132. A basic input/output system 133 (BIOS), containing the basic routines that help to transfer information between elements within computer 110, such as during start-up, is typically stored in ROM 131. RAM 132 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 120. By way of example, and not limitation,
The computer 110 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
Computer 110 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 180. Remote computer 180 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 110, although only a memory storage device 181 has been illustrated in
When used in a LAN networking environment, computer 110 is connected to LAN 171 through a network interface or adapter 170. When used in a WAN networking environment, computer 110 typically includes a modem 172, network interface or other means for establishing communications over the WAN 173, such as the Internet. The modem 172, which may be internal or external, may be connected to the system bus 121 via the user input interface 160, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 110, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
One or more application programs 266 are loaded into memory and run on the operating system 64. Examples of applications includes email programs, scheduling programs, personal information management (“PIM”) programs, word processing programs, spreadsheet programs, browser program, and so forth. The mobile device 220 includes a notification manager 268 loaded into memory 262, which executes on processor 260. The notification manager handles notification requests from the applications 266.
The mobile device includes a power supply 270, which is preferably implemented as one or more batteries. The power supply might further include an external power source that overrides and/or re-charges the built-in batteries, such as an AC adaptor, or a powered docking cradle.
The mobile device 220 is shown with three types of notification mechanisms: an LED 240, a vibration device 272, and an audio generator 274. These devices are directly coupled to the power supply 270 such that when activated, they remain on for a duration dictated by the notification mechanism even though the processor and other components might be shut down to conserve battery power. For example, the LED 240 is often configured to remain on indefinitely until a user takes action on the notification since the LED is a low power user. The vibration generator and audio generator, however, typically consume more power, and may therefore be configured to turn off after some limited duration, or when other system components are turned off.
The cellular telephone 302 is a conventional mobile device, as generally described in
The personal computer (“PC”) 304 is a conventional computing device, as generally described in
The mobile voice network 310 is coupled to a VoIP network 330 by a gateway device 312. The mobile voice network 310 is a conventional cellular voice network conforming to applicable telecommunications standards, for example, a second-generation cellular voice network, such as a GSM or CDMA network, or a third-generation cellular voice network, such as a CDMA2000 or UMTS network. Typically, a service provider hosts the network on one or more conventional computing devices, such as device 110, configured to provide relevant server functionality. The gateway device 312 is a conventional computing device, like device 110, that is configured to provide a communication interface between a mobile voice network, such as network 310, and an IP network, such as network 330. The gateway device 312 typically includes all routines necessary for the managing the interface, including compression/decompression, packetization, call routing, and control signaling, for example. The gateway device 312 is operatively coupled to a first server or softswitch 332 in the VoIP network 330. In this embodiment, the softswitch 332 is also coupled to a notification server 334 and a call registration server 336. However, it should be recognized that all three servers could be implemented in a single server device providing all three functions.
The mobile data network 320 is coupled to the VoIP network 330 by second gateway device 322. The mobile data network 320 is a conventional wireless data network conforming to applicable telecommunications standards. Typically, a service provider hosts the network on one or more conventional computing devices configured to provide relevant server functionality. The gateway device 322 is a conventional computing device that is configured to provide a communication interface between a mobile data network, such as network 320, and an IP network, such as network 330. The gateway device 322 typically includes all routines necessary for the managing the interface. The gateway device 322 is operatively coupled to the call registration server 336 of the VoIP network 330.
The VoIP network 330 is a conventional IP network that is hosted by a service provider on one or more conventional computing devices configured to provide relevant server functionality.
Referring now to
In step 402, the online status of the callee is polled by the IM client. This step is transparent to the user, and is done periodically by the IM client. Alternatively, the status of the caller's contacts are pushed from the IM presence server and updated whenever the caller is online. Online presence may be indicated in a number of different ways, for example, with a presence indicator, such as a small icon, located next to the virtual identifier. In one embodiment, the icon is green if the user is online, and grey if the user if offline.
If the presence indicator indicates that the contact is online, then in one embodiment, the user is given a means to distinguish among the service features available to IM users. For example, the IM client may cause a pop-up screen to be displayed on cell phone 302 that lists several choices for the IM service: (i) chat with contact; (ii) email contact; and (iii) call contact. If in step 405, the user selects the choice “call contact,” then in step 406, the IM client sends a request to establish a call registration record through the mobile data network 320. This request is indicated by signal path 10 in
If the user does not select “call contact” in step 405, then other processing may occur which is outside the scope of this disclosure.
If the contact is determined to be offline in step 404, then the IM client will cause the cell phone 302 to call the telephone number associated with the contact directly in step 404 using the mobile voice network.
In step 408, the mobile data network 320 routes the request from the mobile data network 320 to the gateway 322, as shown by signal path 12 in
In step 414, the IM client on cell phone 302 dials the telephone number for the VoIP service provider, such as Windows Live, through the mobile voice network 310. This is shown by signal path 20 in
In step 420, the softswitch 332 sends a query to the call registration server 356 to look up the call registration record indexed by the caller ID of the cell phone 302 (signal path 26). In step 422, the call registration server 336 retrieves the record and sends it back to the softswitch server 332 (signal path 28). In step 424, the softswitch server 332 retrieves the callee's virtual identifier from the record, then in step 426, the softswitch sends a request to to the notification server 334 to notify callee (signal path 30). In step 428, the notification server 334 locates the IP address where the callee's virtual identifier is logged in, namely PC 304, and in step 430, the notification server sends a notification to PC 304 (signal path 32). The notification is displayed on PC 304 in step 432 and indicates at least that a voice session is being requested by a caller, for example, by displaying the virtual identifier of the caller or the caller ID of the cell phone 302.
If the callee accepts the call in step 434, then the softphone in PC 304 sends notice of acceptance to the softswitch server 336 in step 436 (signal path 34). In step 438, the softswitch server 336 forwards the call acceptance back to gateway 312 (signal path 36). The gateway 312 in turn forwards the call acceptance to the mobile voice network 310 in step 440 (signal path 38). The cellular telephone 302 receives the call acceptance in step 442 (signal path 40), and a mobile voice session is established (signal path 50) in step 444 with the gateway 312 through the mobile voice network 310. Finally, in step 446, the gateway 312 establishes a VoIP voice session (signal path 52) between the gateway 312 and the PC 304 through the VoIP network 350. Thus, a hybrid voice session is established between cell phone 302 and PC 304 using the mobile voice session and the VoIP voice session. If the callee rejects the call in step 434, the PC 304 sends a notification back to the cell phone 302 indicating that the call was rejected in step 448.
Referring now to
In step 402, the online status of the callee is polled by the IM client on cell phone 302, or pushed from the IM presence server. If the contact is offline, the IM client causes cell phone 302 to call the contact directly in step 404 using the mobile voice network. If the presence indicator indicates that the callee is online, then in one embodiment, the IM client displays a pop-up screen on cell phone 302 that lists choices for IM services for the caller to select from, namely: (i) chat with contact; (ii) email contact; and (iii) call contact. If the caller selects the choice “call contact” in step 405, then in step 414, the IM client dials the telephone number for the VoIP service provider through the mobile voice network 310. This is shown by signal path 60 in
In step 500, the softswitch 332 accepts the call and sends notice of acceptance to the gateway 312 and to the IVR server 338 (signal path 66). The gateway 312 then forwards the acceptance to the mobile voice network 330 (signal path 68) in step 502. In step 504, cell phone 302 receives the acceptance (signal path 70), and a mobile voice session (voice media path 72) is established with the gateway 312 through the mobile voice network 330 in step 506. In step 508, a VoIP voice session is established (voice media path 74) between the gateway 312 and the IVR server 338. Thus, a hybrid voice session (voice media path 78) is established between the cell phone 302 and the IVR system 338 using the mobile voice session and the VoIP voice session.
IVR is a well known technique that uses a computerized system, such as IVR server 338, to present a telephone caller with one or more options from a list of options. Generally, when a user calls an IVR system, a voice recording is played, and the caller responds by either pressing one or more numbers on the telephone keypad to select the desired option, or speaking a simple statement. The system may be configured to recognize a variety of commands in response to the voice prompts, including simple statements such as “yes” or “no,” as well as more complex statements, for example, a command plus an argument, such “call John Doe.”.
In one embodiment, softswitch 332 initiates an IVR session (signal path 76) in step 510 and sends a “ready” signal back to cell phone 302. The ready signal is preferably a voice prompt from the IVR server 338, such as “THE CALL MANAGEMENT SYSTEM IS READY. PLEASE ENTER THE PERSONAL IDENTIFICATION NUMBER FOR THE PARTY YOU ARE CALLING, THEN PRESS POUND.”
Upon receiving the ready signal in step 512, the IM client on cell phone 302 converts the callee's virtual identifier to a series of digits, then displays a pop-up screen in step 514 allowing the caller to confirm or edit the digits before sending them to the IVR system. The caller then accepts the digits, and the IM client causes the cell phone 302 to dial those digits to the IVR server 338 (voice media path 78) in step 516.
The softswitch 332 locates the callee by looking up the callee's virtual identifier in the softswitch database in step 518. The softswitch 332 then begins to transfer the mobile call through the notification server 334 (signal path 80) in step 520. The notification server locates the PC where the callee has logged in with his virtual identifier in step 522, then sends a call transfer notification to the VoIP softphone on PC 304 in step 524 (signal path 82). The notification is displayed on PC 304 in step 526 and indicates at least that a voice session is being requested by a caller, by displaying the virtual identifier of the caller or the caller ID of the cell phone 302.
If the callee accepts the call in step 528, then the softphone in PC 304 sends notice of acceptance to the softswitch server 336 in step 530 (signal path 84). In step 532, the gateway 312 establishes a VoIP voice session (voice media path 86) between the gateway 312 and the PC 304 through the VoIP network 350. Thus, a hybrid voice session is established between cell phone 302 and PC 304 using the mobile voice session (voice media path 78) and the VoIP voice session (voice media path 86). If the callee rejects the call in step 528, then a “call rejected” notification is sent back to the mobile phone 302 in step 534.
Referring now to
In step 706, the softswitch 332 accepts the call and sends notice of acceptance to the gateway 612 and to the IVR server 338 (signal path 166). In step 708, the gateway 612 forwards the acceptance to the voice network 610 (signal path 168). In step 710, telephone 602 receives the acceptance (signal path 170), and a voice channel (voice media path 172) is then established with the gateway 612 through the voice network 630 in step 712. In step 714, a VoIP channel is established (voice media path 174) between the gateway 612 and the IVR server 338. Thus, a hybrid voice session (voice media path 178) is established between the telephone 602 and the IVR system 338 using the voice channel and the VoIP channel.
Softswitch 332 then initiates an IVR session (signal path 176) in step 716 and causes the IVR server 338 to send a first voice prompt back to telephone 602 in step 718. The voice prompt is preferably a simple message, such as “THE CALL MANAGEMENT SYSTEM IS READY. PLEASE STATE YOUR REQUEST.” The caller responds with a voice command including an argument in step 720, for example: “CALL JOHN DOE AT HOTMAIL DOT COM,” or simply: “CALL JOHN DOE.” If the IVR system 338 does not recognizes the callee or understand the command in step 722, then it increments a counter in step 724.
In step 726, if the counter does not exceed a present maximum for number of tries, such as three, then the IVR system issues a voice prompt in step 728 such as: “I DO NOT UNDERSTAND YOUR COMMAND. PLEASE TRY AGAIN.” In step 730, the caller tries again to speak a proper response.
If the counter does exceed the present maximum in step 726, then the IVR system issues a voice prompt in step 732 such as: “I'M SORRY THAT YOU'RE HAVING DIFFICULTY. PLEASE TRY AGAIN LATER” and the softswitch cancels the VoIP voice session and ends the routine in step 734.
If the IVR system does understand the command and recognizes the callee in step 722, then the softswitch 332 locates the callee on the VoIP network by looking up the identifier provided by the caller in the softswitch database in step 736.
The softswitch 332 then begins to transfer the voice session through the notification server 334 (signal path 180) in step 742. The notification server locates the PC where the callee has logged in with his virtual identifier in step 744, then sends a call transfer notification to the VoIP softphone on PC 304 in step 746 (signal path 182). The notification is displayed on PC 304 in step 748 and indicates at least that a voice session is being requested by a caller, by displaying the virtual identifier of the caller or the caller ID of the cell phone 302.
If the callee accepts the call in step 750, then the softphone in PC 304 sends notice of acceptance to the softswitch server 336 in step 752 (signal path 184). In step 754, the gateway 612 establishes a VoIP channel (voice media path 186) between the gateway 612 and the PC 304 through the VoIP network 330. Thus, a hybrid voice session is established between telephone 602 and PC 304 using the voice channel (voice media path 178) and the VoIP channel (voice media path 186). If the callee rejects the call in step 750, then the IVR system sends a voice notification statement to telephone 602 in step 756, such as: “THE PERSON YOU ARE CALLING CANNOT ANSWER THE CALL AT THIS MOMENT” and the routine ends.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims. It is intended that the scope of the invention be defined by the claims appended hereto.