This relates to internet protocol voice transmission methods, clients and servers.
Unexpected call drops and not hearing each other are frequent sources of frustration and poor user experience in voice over internet protocol (VoIP) calling. Poor coverage network areas, transition from one network to another (Wifi to cellular or vice versa) all have implications for dropped calls and/or a user experience of not hearing each other for more than many would tolerate. This innovation accepts the fact that it is unavoidable to have poor network coverage areas, network transitions etc. and provides a method by which the call continuity can be maintained to keep users engaged in the call while methods for reconnecting are being applied.
This innovation comprises a server apparatus comprising a processor coupled to the storage device, internet protocol connectivity and processor executable program code that immediately attempts to reconnects voice over IP calls that have been temporarily disconnected. This innovation also includes client devices comprising a processor coupled to the storage device, a video output, an audio output, internal protocol connectivity, and processor executable program code that receive commands to reconnect calls that may be temporarily interrupted. The innovation includes support at the client devices and server device for Multi-Device scenarios where an end user may reconnect to the voice call using a second client device. Unlike some of the prior art, such as U.S. Pat. No. 9,125,141 (Sanjeev), this innovation immediately notifies both parties that there is a connectivity problem. In contrast, the prior art waits until connectivity is restored and starts to begin calling the other person. The prior art's ability to cancel the reconnection attempt occurs later when connectivity is restored, but at that point, sufficient time may have elapsed to not want to call again and the user may not be next to the device to cancel the call, which will result in an unexpected call attempt and a poor user experience. The preferred embodiment server architecture of this solution also allows for quicker re-connection of the call (instead of reconnection to voicemail in many dropped call cases currently) and the user will be able to control the experience by canceling while the user is still engaged with the device. Also unlike the known prior art, this solution is adapted to multi-device scenarios where a user may be subscribed to multiple client devices and can be reconnected on a different client device to the same call session as may happen when a client device has a depleted battery and the user may want to reconnect to the same call using another of the same user's client devices to reconnect.
In 105, each client monitors the health of its signaling and media paths. The server also monitors the health of signaling and media to each client. In 106, B1 experiences a network connectivity problem that results in disruption to both the signaling and media paths. This causes both Clients 101 and 103 to not hear each other. Client B starts to automatically reconnect the call, but while this reconnection occurs, both Clients A and B are informed to provide the feedback to wait while the reconnection attempt is in progress. Failure to provide this feedback may result in users hanging up the call in user frustration. In some implementations, dropping the call due to temporary network connectivity problems or users hanging up due to lack of proper feedback can worsen the experience by ending up with each user calling the other at the same time and each going to voicemail of the other.
In the innovation, each user, not just one side, is presented with both a visual and audible alert. In 107, Client A is alerted that Client B is reconnecting while in 108, Client B is alerted that he/she is experiencing a problem and that a reconnection attempt is in progress. The visual indicator may be an animated circle around the avatar of the other person as shown in
In 109, Client B's network connectivity is restored and the call is re-established. This results in the server informing both clients to cancel the alerts in 110 and 111 and resume the conversation.
In 409, client B uses another device, B2, to call A. Since A is already waiting for B with a reconnection indicator, the server uses the call attempt from B to A to join the two calls together in 410. Even though the original call started with A calling B, on the reconnection attempt, B calls A with a second device and joins the same call. This scenario uses an example of the battery depleting on the device B1, but it may have been for any other reasons, including network disruptions to device B1. This allows a multi-device scenario where a user can reconnect from another device to the same call and resume the conversation.
Once the media and signaling paths are restored for Client B, in 411, Client A is sent a message to cancel the alert and the two clients can resume the conversation.
For this bridging to occur, if multiple servers are involved, the call attempts need to be centrally shared in a repository, such as via a database, so that it can recognize that A is calling B and B is calling A at the same time.
VoIP calling typically involves a signaling and a media (bearer) path. Signaling can be in-band with media or out-of-band. A protocol such as WebRTC is optimized for media and the signaling path is out-of-band. Furthermore, VoIP calling can be implemented as peer-to-peer between clients or with a server in the middle between the clients. We assume a client-server architecture, but the same applies for peer-to-peer architectures. Regardless of the method used for signaling and media or the architecture of peer to peer or via a server, there are multiple problems that need to be solved to provide call continuity and a better user experience compared to existing methods: I. Detection of poor network conditions and network transitions II. Alerting users of automatic reconnect attempts to keep users engaged III. Automatic reconnection when connectivity is lost IV. Call “bridging”
Detection:
The server performs periodic application heartbeats to a client. This heartbeat is best done with a lightweight protocol on top of the transport, such as websocket pings (RFC 6455). The server and client each monitor the media path. If network problems are experienced and media is not received on client A, it would mean the client B on the other end is not hearing what A is saying or vice versa. This would require an automatic reconnection to provide the best user experience. At this point, if no indication is provided to both A and B that a reconnection is attempted, after some time period (e.g. 5 seconds), the odds are either A or B would hang up the call due to lack of feedback or progress. Providing feedback to users that an automatic reconnection attempt is in progress is important to keep the users engaged and informed.
Alerting:
This application proposes a method with both visual and audible indications to keep the users engaged while the clients and server attempt to automatically reestablish the call. a. The method proposed has a visual indicator, such as an animation or a status bar indicating the party experiencing the problem and that a reconnect attempt is in progress. Since the server is able to conclusively know that for example A is the one experiencing the problem, it can notify the B client that it is waiting for A to reconnect. This also informs B that the problem is not on his/her side. Client A can also alert the user that it is trying to reconnect while it starts to automatically reconnect B. In addition to a visual indicator, it's important to have an audible tone or message. The audible tone or recorded message to notify the user becomes most important in several cases: someone is driving or using a Bluetooth device with the client screen not directly in front of them; or answering a call over a locked screen on some mobile devices, such as iOS with the use of CallKit where you can't see the visual indicator unless you unlock the screen with a password, passcode, fingerprint etc.
Automatic Reconnection:
All automatic reconnect attempts are bounded to some reasonable amount of time, such as, for example, 30-60 seconds. During this time period, both the visual and periodic audible alerts are provided to keep the users engaged. At the end of the reconnect attempt period, the call is terminated and users are alerted that the reconnect attempt was unsuccessful. There are times when signaling is lost for some time, but media recovers, possibly so quick that makes it unnoticeable to users in conversation. This can be due to media paths optimized for temporary network disruptions, such as with use of the WebRTC protocol, but signaling may depend on protocols on top of TCP/IP. In such cases, no visual or audible tone is alerted to users because they can hear each other, however, the server can use heuristics based on data from the past and the presence of media that it is a temporary network disruption There are times when network transitions can occur, such as WiFi to cellular or vice versa, and signaling, media or both may be in an unrecoverable state (e.g. due to a change in IP address or network dependency changes). During these cases, it may require the call to drop and for the client to call again. This innovation proposes a better user experience. This sequence is used to explain this method:
Call “bridging” While B is provided with a visual and audible reconnecting status of A, the A user may decide to hang up and call B. Since B is already waiting for A to reconnect, A's new call attempt should be seamlessly “bridged” to B and the conversation would resume. B would not know that A made another call attempt to B. Furthermore, to A, it would look like B answered the call as any other call is answered with user interaction, but when in fact, the bridging method makes it a seamless experience.
This application is a continuation application of and claims benefit to U.S. application Ser. No. 16/450,674 filed on Jun. 24, 2019, which claims benefit to U.S. Provisional Application 62/754,617 filed on Nov. 2, 2018, which are incorporated by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
6801604 | Maes et al. | Oct 2004 | B2 |
7072641 | Satapathy | Jul 2006 | B2 |
8274970 | Bennett et al. | Sep 2012 | B2 |
8798605 | Heit et al. | Aug 2014 | B2 |
8976940 | Maxwell et al. | Mar 2015 | B2 |
9125141 | Sanjeev | Sep 2015 | B1 |
9380265 | Hanson et al. | Jun 2016 | B2 |
9386622 | Yoon et al. | Jul 2016 | B2 |
9826090 | Spiessbach et al. | Nov 2017 | B2 |
10033847 | Osman et al. | Jul 2018 | B2 |
20030185160 | Tegethoff | Oct 2003 | A1 |
20030223570 | Partanen | Dec 2003 | A1 |
20040073658 | Oran et al. | Apr 2004 | A1 |
20050069116 | Murray, II | Mar 2005 | A1 |
20070274488 | Callaghan | Nov 2007 | A1 |
20080037746 | Dufrene et al. | Feb 2008 | A1 |
20080101247 | Bouchard | May 2008 | A1 |
20100322388 | Ger | Dec 2010 | A1 |
20110280386 | Fotta et al. | Nov 2011 | A1 |
20120233327 | Smith et al. | Sep 2012 | A1 |
20120263287 | Gisby | Oct 2012 | A1 |
20130070755 | Trabeisi et al. | Mar 2013 | A1 |
20130242775 | Taylor | Sep 2013 | A1 |
20130268598 | Tipirneni | Oct 2013 | A1 |
20130293665 | Pang | Nov 2013 | A1 |
20140029732 | Liik | Jan 2014 | A1 |
20140222930 | Gangadharan | Aug 2014 | A1 |
20140297878 | Minami | Oct 2014 | A1 |
20150078543 | Gisby et al. | Mar 2015 | A1 |
20150230147 | Brownworth et al. | Aug 2015 | A1 |
20150304603 | Yoon et al. | Oct 2015 | A1 |
20150312281 | Martinez et al. | Oct 2015 | A1 |
20160027134 | Alvarado et al. | Jan 2016 | A1 |
20160094589 | Gunnalan et al. | Mar 2016 | A1 |
20160094716 | Caulfield et al. | Mar 2016 | A1 |
20160105545 | Filonov et al. | Apr 2016 | A1 |
20160191573 | Zehavi et al. | Jun 2016 | A1 |
20160277272 | Peach et al. | Sep 2016 | A1 |
20160316414 | Yeoum et al. | Oct 2016 | A1 |
20160366559 | King | Dec 2016 | A1 |
20170034223 | Arscott et al. | Feb 2017 | A1 |
20170041808 | Skeba et al. | Feb 2017 | A1 |
20170149846 | Mufti et al. | May 2017 | A1 |
20180198911 | Tamblyn et al. | Jul 2018 | A1 |
20180270346 | Donnenwirth et al. | Sep 2018 | A1 |
20190158783 | Dove | May 2019 | A1 |
20190306252 | Lebedev et al. | Oct 2019 | A1 |
Number | Date | Country | |
---|---|---|---|
20210218791 A1 | Jul 2021 | US |
Number | Date | Country | |
---|---|---|---|
62754617 | Nov 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16450674 | Jun 2019 | US |
Child | 17178699 | US |