The invention relates to a communications system and method, and more particularly to an information assistance system and method for distributing communication calls among information/call centers.
It is common that an information assistance service provider sets up information/call centers (conveniently referred to hereinafter as “call centers”) in different geographic areas to handle information assistance calls from users. One such information assistance call typically is routed by a telephone carrier to a call center based on call origination, e.g., all calls from Minneapolis are routed to a nearby Chicago call center in the first instance. The information assistance service provider oftentimes needs to meet certain quality of service (QOS) requirements, e.g., the maximum wait time before a call is answered, to gain customer satisfaction. For example, to meet the maximum wait time requirement, if a call center, for whatever reasons, is unable to answer a call within a predetermined period, the call is rerouted to another call center in accordance with a call routing algorithm.
To take advantage of the virtually free transport of the Internet, an increasing number of voice calls, including information assistance calls, are realized based on a Voice over Internet Protocol (VoIP). Specifically, the voice content of a call is digitized and reformatted into VoIP packets, which are then routed through the Internet to a destination server. Such packets are reassembled at the destination server and the voice content is reconstructed, which process is transparent to both the caller and the called party. A session initiation protocol (SIP) is particularly useful for establishing and terminating a VoIP call session. For details on the SIP, one may refer, e.g., to: “SIP: Protocol Overview,” http://www.radvision.com, Radvison Ltd., 2001.
The invention is directed to dynamically routing calls, e.g., VoIP calls, to information assistance providers, e.g., call centers, operators, etc. for handling the calls. In accordance with the invention, before a call session is established, a device for routing the call, e.g., a telephone carrier switch, identifies the call center to which the call is routed. To that end, the carrier switch sends to a server, e.g., redirect server, in an information assistance system a first message, e.g., a SIP Invite message, which requests acceptance of the call thereby. In response, a list of selected information assistance providers available to accept the call is compiled, based on measures of current conditions of the plurality of information assistance providers. The server responds to the SIP Invite message with a second message, e.g., a SIP Multiple Choices message, which includes a subset of the selected information assistance providers. In response to such a second message, the carrier switch sends the SIP Invite message to at least one of the selected information assistance providers in the subset, again requesting acceptance of the call thereby.
In an illustrative embodiment, the carrier switch sends the SIP Invite message to the information assistance providers in the subset sequentially. Only after one of the information assistance providers responds with a SIP OK message, does the carrier switch forward the call to the information assistance provider. If none of the information assistance providers are available, the caller is so informed and may be asked to try again later.
In another illustrative embodiment, based on a recognition of the dynamic nature of the availability of information assistance providers, after exhausting an initial list of information assistance providers, the carrier switch may be “tricked” into sending a second SIP Invite message to the redirect server. This may be achieved by including the redirect server's IP address as an entry in the initial list of information assistance providers. In response to this second Invite message, the redirect server fetches a new list of available information assistance providers with which the carrier switch attempts to establish the call session.
In yet another illustrative embodiment, a condition may be set in the initial list of information assistance providers, which requires the carrier switch to send a second Invite message to the redirect server when the condition is met, thereby obtaining a new list of available information assistance providers.
Advantageously, with the invention, an information assistance call is only routed to an information assistance provider after the provider confirms its availability to answer the call. The limited network bandwidth is effectively utilized as only relatively short messages are exchanged before a call is connected to an information assistance provider, as opposed to dedicating a channel to communicating the call even before availability of a provider is determined as in prior art.
Further objects, features and advantages of the invention will become apparent from the following detailed description taken in conjunction with the accompanying drawings showing an illustrative embodiment of the invention, in which:
The invention is directed to dynamically routing information assistance calls, e.g., VoIP calls, to call centers to effectively provide an information assistance service. In accordance with the invention, an information assistance call is routed according to instructions by a redirect server in an information assistance system. To that end, for example, before a telephone carrier switch forwards an information assistance call to a call center, it conducts handshaking with the redirect server in accordance with the well known session initiation protocol (SIP), including sending a message inviting the redirect server to accept the call, with no knowledge that the redirect server in the present invention does not accept any call. Rather, the redirect server replies with a SIP Multiple Choices message (also known as a “SIP 300 message”) containing a list of call centers which may be able to accept the call, in accordance with the invention. Based on the received list, the carrier switch then sends a similar invite message to request the call centers on the list to accept the call. The list of call centers provided by the redirect server may be compiled by a call routing server based on the current load or other conditions of various call centers, in accordance with a dynamic call routing algorithm. One such dynamic call routing algorithm is described, e.g., in copending, commonly assigned U.S. application Ser. No. 09/861,777, filed on May 21, 2001, which is incorporated herein by reference.
In an illustrative embodiment, the telephone carrier switch sends a SIP Invite message to the call centers on the received list sequentially. Only after one of the call centers responds with a SIP OK message, does the carrier switch forward the information assistance call to the call center. In other words, if a call center responds with a SIP Unavailable message indicating unavailability of the call center, the carrier switch queries the next call center on the list, and so on and so forth until one of them confirms its availability to answer the call. Otherwise, if none of the call centers on the list are available, the caller is so informed and may be asked to try again later. However, in another illustrative embodiment, based on a recognition of the dynamic nature of the availability of call centers, after exhausting at least part of an initial list of call centers, the carrier switch may be “tricked” into sending a second SIP Invite message to the redirect server. This may be achieved by including the redirect server's IP address as an entry in the initial list of call centers. In response to this second Invite message, the redirect server fetches a new list of available call centers with which the carrier switch attempts to establish an information assistance call session. In yet another illustrative embodiment, a condition may be set in the initial list of call centers, which requires the carrier switch to send a second Invite message to the redirect server when the condition is met, thereby obtaining a new list of available call centers.
Advantageously, with the invention, an information assistance call is only routed to a call center after the call center confirms its availability to answer the call. The limited network bandwidth is effectively utilized as only relatively short messages are exchanged before a call is connected to a call center, as opposed to dedicating a channel to communicating the call even before availability of a call center is determined as in prior art.
An information assistance call, e.g., initiated from telecommunication device 105, is routed in a conventional manner through carrier network 100, e.g., a public switched telephone network (PSTN), to a carrier switch therein, denoted 101. In this instance, to effectively utilize the limited bandwidth of the carrier network 100, switch 101 is programmed to packetize the voice content of the call, in accordance with the VoIP, and the resulting packets are transmitted through packet-switched network 104, e.g., the Internet. In a well known manner, the transmitted packets are reassembled at a destination switch to recover the voice content. The voice content is then conveyed to an operator at a call center, thereby realizing the information assistance call. However, before the VoIP call session is established, switch 101 in this instance needs to identify the call center to which the call is connected. To that end, a call routing algorithm is implemented in call routing server 108. Each of call centers 102-1 through 102-K is connected to call routing server 108, e.g., via a wide area network. Server 108 receives from the call centers measures of their conditions, necessary for the call routing algorithm to identify available call centers. Examples of such measures or metrics concerning the call centers, e.g., call center 102-1, are enumerated as follows:
(1) Call Abandonment (CA) metric—this metric indicates the percentage of callers that have hung up after experiencing a set answer delay, e.g., 24 seconds in this instance. A relatively high CA metric value indicates that a relatively high percentage of calls received by call center 102-1 were abandoned by the callers because of a long answer delay. Thus, one may want to set a maximum limit on the CA metric value, say, 20%, to meet a certain QOS requirement. When the CA metric value of call center 102-1 exceeds the maximum limit, call center 102-1 is likely not to be able to answer a current call within the maximum wait time.
(2) Calls in Queue (CIQ) metric—this metric measures the number of incoming calls waiting in the queue to be answered by call center 102-1. The higher the CIQ metric value, the higher the likelihood that a current call, if it were connected to call center 102-1, would become an overflow call and would have to be rerouted to a different call center. The CIQ metric value may be weighted against the number of logged in or active operators in call center 102-1, indicated by metric value (5) below. This stems from the fact that the more (fewer) active operators in the call center, the more (fewer) calls in the queue they can answer within the maximum wait time. Thus, the CIQ metric value relative to the number of active operators may be more effective in determining a call center where a current call should be routed.
(3) Direct Call Processing Time (DCPT) metric—this metric indicates the average duration of a call after the call is picked up by an operator in call center 102-1, thereby measuring the efficiency of the operators answering the incoming calls. The higher the DCPT metric value, the more likely that a current call would not be answered within the maximum wait time. For example, a high DCPT value may be a minute or more.
(4) H metric—this metric measures the number of calls processed per hour by the operators in call center 102-1. The higher the H metric value, i.e., the larger the number of calls answered by the operators per hour, the less likely that a current call would not be answered within the maximum wait time. Like the CIQ metric, the H metric may be weighed against the number of active operators, indicated by metric value (5) below, as what constitutes a high H metric value depends on the number of active operators in call center 102-1.
(5) Logged in Operators (LIO) metric—this metric measures the number of operators who have logged in the system to answer calls in call center 102-1. As mentioned before, this metric may be considered in combination with other metrics such as the CIQ and H metrics.
(6) Longest Queue Time (LQT) metric—this metric measures the longest queue time for any incoming call waiting in the queue to be answered. Additional incoming calls would likely be designated overflow calls and would have to be rerouted to a different call center if the LQT metric value exceeds a predetermined threshold.
(7) Rerouted Inbound Calls in Progress (RICIP) metric—this metric measures the number of calls being rerouted to call center 102-1 from other call centers 102-2, . . . 102-K (“overflow calls”). A high RICIP metric value indicates a high rate of acceptance of overflow calls in call center 102-1, and the call center is likely to not designate any incoming call an overflow call since the call volume is manageable.
(8) Rerouted Outbound Calls in Progress (RICIP) metric—this metric measures the number of overflow calls being rerouted from call center 102-1 to an alternate call center. If call center 102-1 is already rerouting many of its incoming calls, it is likely that call center 102-1 would need to continue to designate an incoming call an overflow call and reroute same.
(9) Time Service Factor (TSF) metric—this metric measures the percentage of calls answered in call center 102-1 within a predetermined time limit, e.g., 24 seconds, to meet a QOS requirement. The higher the TSF metric value, the more likely that a current call would not be designated an overflow call and would not have to be rerouted to an alternate call center.
Based upon an analysis and weighing of such metrics concerning each of call centers 102-1, 102-2, . . . 102-K, call routing server 108 selects one or more call centers which are most likely available to answer the current call.
Call routing server 108 communicates to redirect server 120 the list of most likely available call centers for handling the current information assistance call. Redirect server 120 also communicates with switch 101 in accordance with the SIP to establish a VoIP call session. Carrier switch 101 initiates the call session by sending a SIP Invite message destined to the IP address of server 120. Treating server 120 as an intended recipient of the call (i.e., a call center), carrier switch 101 expects a response from server 120 whether it can accept the call. However, redirect server 120 in accordance with the invention does not reply with a simple “OK” or “Unavailable” message. Rather, after redirect server 120 receives the SIP Invite message from carrier switch 101, as indicated in step 205 in
Otherwise, if it is determined that the response message indicating unavailability of the call center, e.g., a SIP Unavailable message, carrier switch 101 in step 440 determines whether there is an additional IP address(es) on the list to which carrier switch 101 has not sent an Invite message. If not, the subject routine comes to an end, where a recorded message may be played to the user, e.g., “No information assistance service is available,” “All circuits are busy,” “Please call again later,” etc., and the call is then disconnected. Otherwise, carrier switch 101 in step 445 selects the next IP address on the list, and the routine returns to step 415 described before.
In a second embodiment, to take advantage of a well known SIP “parallel search” feature afforded to switch 101, the aforementioned list of available call centers sent by redirect server 120 may contain two or more call centers which are equally ranked, i.e., equally likely to answer the current information assistance call. One such list is illustrated in
In a third embodiment, redirect server 120 may revise the list of available call centers provided by call routing server 108 and include the revised list in the Multiple Choices response message to carrier switch 101. For example, redirect server 120 may truncate the list from server 108 (e.g.,
In addition, the imposition of such an upper limit is sensible in that it not only limits the wait time before a caller knows whether the information assistance call can be connected, but may also serve as a condition for obtaining a new list of available call centers from call routing server 108, in accordance with an aspect of the invention. Such a new list is warranted because if the predetermined number of top ranked call centers on the current list which were most likely available to answer the call a short while ago have become unavailable now, the load or other conditions of call centers 102-1 through 102-K may have drastically changed. Such a drastic change may be due to a sudden power outage at a call center, or an abnormal increase in call volume in a geographic region, e.g., caused by a sudden disaster in that region.
In implementation, to ensure that a request for a new list of available call centers is made after attempts to connect the call to the predetermined number of top ranked call centers have failed, redirect server 120 inserts its own IP address immediately after the IP addresses of such top ranked call centers on the list.
It should be noted that the number of lists in which redirect server 120 can insert its IP address to request a new list should be limited. Otherwise, the wait time for connecting the call may become indefinitely long, which is undesirable. In this example, because of a maximum wait time requirement, at most one new list can be requested. That is, redirect server 120 can only insert its IP address in the very first list received from server 108 for the current information assistance call. To that end, server 120 checks the header of an Invite message which in this instance includes an identifier associated with the current information assistance call, e.g., an automatic number identification (ANI). As is well known, the ANI represents the telephone number from which the call originates, which is provided to switch 101 in establishing the call. In this instance, if server 120 encounters a new ANI in the header of an Invite message, server 120 registers the new ANI and the time of receipt of the Invite message in a registry, and inserts its IP address in the list of available call centers from server 108, resulting in the revised list of
In a fourth embodiment, redirect server 120 may be programmed to set a condition for obtaining a new list of available call centers from server 108. That is, instead of inserting its IP address in a list of available call centers as demonstrated in
Time condition 703 is established by redirect server 120 to ensure that not too much time has been elapsed before it is determined that the current list has become “stale,” and there is sufficient time for obtaining a new list upon which switch 101 can act. The actual time limit is selected based on the system time at which redirect server 120 receives an Invite message from switch 101. In this instance, when redirect server 120 receives one such Invite message, it registers the time of its receipt, say, 9:30:00 a.m. In response to the Invite message, server 120 elicits from call routing server 108 a list of available call centers. Server 120 then refers to the list and the Invite message receipt time, and determines the appropriate time limit, 9:30:05 a.m., by which switch 101 should have sent an Invite message to Call_Center_D to meet a maximum wait time (e.g., 10 seconds) requirement. After formulating time condition 703, server 120 inserts the condition in the list alongside the IP address of Call_Center_D, as shown in
Continuing with the above example, after receiving the revised list of
The foregoing merely illustrates the principles of the invention. It will thus be appreciated that those skilled in the art will be able to devise numerous other arrangements which embody the principles of the invention and are thus within its spirit and scope.
For example, it will be appreciated by those skills in the art that protocols other than the VoIP and SIP may be used to implement the present invention.
Finally, information assistance system 106 is disclosed herein in a form in which various functions are performed by discrete functional blocks. However, any one or more of these functions could equally well be embodied in an arrangement in which the functions of any one or more of those blocks or indeed, all of the functions thereof, are realized, for example, by one or more appropriately programmed processors.