System and method for mapping a customer journey to a category
10847136 ยท 2020-11-24
Assignee
Inventors
Cpc classification
H04M3/493
ELECTRICITY
H04M2203/555
ELECTRICITY
International classification
G10L15/06
PHYSICS
H04M3/493
ELECTRICITY
Abstract
Systems and methods for mapping a customer journey in an interactive voice response (IVR) system to a category from a categories list, build a directed graph based on one or more sample IVR customer journeys; generate a black list based on the directed graph; for a given customer journey: filter one or more non-informative menus from the plurality of available menus based on the black list; concatenate the respective associated menu prompt of each menu that was not filtered, and one or more user responses to one or more menu prompts from the series of interactions in the given customer journey, into a concatenated word string; calculate a similarity score between the concatenated word string and a category name of each category from the categories list; and map the given customer journey to the category whose category name produces the highest similarity score.
Claims
1. A method for mapping a customer journey in an interactive voice response (IVR) system to a category from a categories list, the IVR system comprising a plurality of available menus, each menu having an associated menu prompt, and the customer journey reflecting a series of interactions with one or more of the plurality of menus, the method performed on a computer having a processor, a memory, and one or more code sets stored in the memory and executed by the processor, comprising: building, by the processor, a directed graph based on one or more sample IVR customer journeys; wherein the directed graph comprises one or more nodes and one or more directed arcs, each node of the directed graph representing a menu of the plurality of available menus, and each directed arc representing a menu path in an IVR sequence within a given sample IVR customer journey; generating, by the processor, a black list based on the directed graph; for a given customer journey: filtering, by the processor, one or more non-informative menus from the plurality of available menus based on the black list; concatenating, by the processor, the respective associated menu prompt of each menu that was not filtered, and one or more user responses to one or more menu prompts from the series of interactions in the given customer journey, into a concatenated word string; calculating, by the processor, a similarity score between the concatenated word string and a category name of each category from the categories list; and mapping, by the processor, the given customer journey to the category whose category name produces the highest similarity score.
2. The method as in claim 1, wherein a non-informative menu is identified for filtering based on at least one of a threshold degree of frequency of its representative node in the directed graph, a threshold in-degree of its representative node in the directed graph, and a threshold out-degree of its representative node in the directed graph.
3. The method as in claim 1, further comprising: adding, by the processor, text of IVR menu prompts to a predefined text corpus of combined text; and training one or more word embeddings based on the combined text.
4. The method as in claim 1, wherein generating the black list comprises extracting, by the processor, one or more menus from the set of IVR menus and adding the one or more menus to an IVR menus black list.
5. The method as in claim 4, wherein the filtering further comprises filtering, by the processor, the one or more non-informative menus by splitting the IVR sequence into one or more IVR menus; for each menu, if the menu is in the black list, removing the menu from the IVR journey; and outputting a filtered IVR journey.
6. The method as in claim 1, wherein the similarity score is calculated based on a cosine similarity.
7. The method as in claim 1, wherein a similarity map is generated for each comparison of a given IVR journey text to each category in the category list.
8. The method as in claim 7, wherein a highest similarity score is determined based on the similarity map reflecting the highest similarity.
9. The method as in claim 1, wherein the category is a contract reason and the list of categories is a list of contact reasons.
10. A system for mapping a customer journey in an interactive voice response (IVR) system to a category from a categories list, the IVR system comprising a plurality of available menus, each menu having an associated menu prompt, and the customer journey reflecting a series of interactions with one or more of the plurality of menus, comprising: a computer having a processor and memory; and one or more code sets stored in the memory and executed by the processor, which configure the processor to: build a directed graph based on one or more sample IVR customer journeys; wherein the directed graph comprises one or more nodes and one or more directed arcs, each node of the directed graph representing a menu of the plurality of available menus, and each directed arc representing a menu path in an IVR sequence within a given sample IVR customer journey; generate a black list based on the directed graph; for a given customer journey: filter one or more non-informative menus from the plurality of available menus based on the black list; concatenate the respective associated menu prompt of each menu that was not filtered, and one or more user responses to one or more menu prompts from the series of interactions in the given customer journey, into a concatenated word string; calculate a similarity score between the concatenated word string and a category name of each category from the categories list; and map the given customer journey to the category whose category name produces the highest similarity score.
11. The system as in claim 10, wherein a non-informative menu is identified for filtering based on at least one of a threshold degree of frequency of its representative node in the directed graph, a threshold in-degree of its representative node in the directed graph, and a threshold out-degree of its representative node in the directed graph.
12. The system as in claim 10, further configured to: add text of IVR menu prompts to a predefined text corpus of combined text; and train one or more word embeddings based on the combined text.
13. The system as in claim 10, wherein when the black list is generated, one or more menus are extracted from the set of IVR menus and the one or more menus are added to an IVR menus black list.
14. The system of claim 13, wherein, when filtering, the system is further configured to filter the one or more non-informative menus by splitting the IVR sequence into one or more IVR menus; for each menu, if the menu is in the black list, remove the menu from the IVR journey; and output a filtered IVR journey.
15. The system as in claim 10, wherein the similarity score is calculated based on a cosine similarity.
16. The system as in claim 10, wherein a similarity map is generated for each comparison of a given IVR journey text to each of category in the category list.
17. The system as in claim 16, wherein a highest similarity score is determined based on the similarity map reflecting the highest similarity.
18. The system as in claim 10, wherein the category is a contract reason and the list of categories is a list of contact reasons.
19. A method for mapping a customer journey in an interactive voice response (IVR) system to a category from a categories list, the IVR system comprising a plurality of available menus, each menu having an associated menu prompt, and the customer journey reflecting a series of interactions with one or more of the plurality of menus, the method performed on a computer having a processor, a memory, and one or more code sets stored in the memory and executed by the processor, comprising: building, by the processor, a directed graph based on one or more sample IVR customer journeys; wherein the directed graph comprises one or more nodes and one or more edges, each node of the directed graph representing a menu of the plurality of available menus, and each edge representing a menu path in a portion of a given sample IVR customer journey; generating, by the processor, a black list based on the directed graph; for a given customer journey: filtering, by the processor, one or more menus from the plurality of available menus based on the black list; concatenating, by the processor, the respective associated menu prompt of each menu that was not filtered, and one or more user responses to one or more menu prompts from the series of interactions in the given customer journey, into a concatenated word string; calculating, by the processor, a similarity score between the concatenated word string and a category name of each category from the categories list; and assigning, by the processor, the given customer journey to the category whose category name produces the highest similarity score.
20. The method as in claim 19, wherein a similarity map is generated for each comparison of a given IVR journey text to each of category in the category list; and wherein a highest similarity score is determined based on the similarity map reflecting the highest similarity.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
(1) The subject matter regarded as the invention is particularly pointed out and distinctly claimed in the concluding portion of the specification. The invention, however, both as to organization and method of operation, together with objects, features and advantages thereof, may best be understood by reference to the following detailed description when read with the accompanied drawings. Embodiments of the invention are illustrated by way of example and not limitation in the figures of the accompanying drawings, in which like reference numerals indicate corresponding, analogous or similar elements, and in which:
(2)
(3)
(4)
(5)
(6)
(7)
(8)
(9)
(10) It will be appreciated that for simplicity and clarity of illustration, elements shown in the figures have not necessarily been drawn accurately or to scale. For example, the dimensions of some of the elements may be exaggerated relative to other elements for clarity, or several physical components may be included in one functional block or element. Further, where considered appropriate, reference numerals may be repeated among the figures to indicate corresponding or analogous elements.
DETAILED DESCRIPTION OF EMBODIMENTS OF THE INVENTION
(11) In the following description, various aspects of the present invention will be described. For purposes of explanation, specific configurations and details are set forth in order to provide a thorough understanding of the present invention. However, it will also be apparent to one skilled in the art that the present invention may be practiced without the specific details presented herein. Furthermore, well known features may be omitted or simplified in order not to obscure the present invention.
(12) Although embodiments of the invention are not limited in this regard, discussions utilizing terms such as, for example, processing, computing, calculating, determining, establishing, analyzing, checking, or the like, may refer to operation(s) and/or process(es) of a computer, a computing platform, a computing system, or other electronic computing device, that manipulates and/or transforms data represented as physical (e.g., electronic) quantities within the computer's registers and/or memories into other data similarly represented as physical quantities within the computer's registers and/or memories or other information non-transitory processor-readable storage medium that may store instructions, which when executed by the processor, cause the processor to perform operations and/or processes. Although embodiments of the invention are not limited in this regard, the terms plurality and a plurality as used herein may include, for example, multiple or two or more. The terms plurality or a plurality may be used throughout the specification to describe two or more components, devices, elements, units, parameters, or the like. The term set when used herein may include one or more items. Unless explicitly stated, the method embodiments described herein are not constrained to a particular order or sequence. Additionally, some of the described method embodiments or elements thereof may occur or be performed simultaneously, at the same point in time, or concurrently.
(13) Embodiments of the invention can provide systems and methods which perform categorization of IVR journeys automatically, without any previous knowledge. Furthermore, embodiments of the systems and methods described herein are capable of categorizing millions of IVR journeys on a daily basis (which is impossible to do manually). These and other benefits are accomplished, according to embodiments of the invention, by for example providing systems and methods which map a customer journey in an IVR system to a category from a categories list or set to identify a contact reason for IVR journeys in an unsupervised manner and without any prior knowledge about the logic of the specific IVR system.
(14) Embodiments of the invention may implement an unsupervised categorization algorithm which maps or assigns a given IVR journey to one category from a given categories list, e.g., based on the text of the prompts. Given a customer's IVR journey, embodiments of the invention may perform for example, as follows (as discussed in greater detail herein):
(15) 1. Filter out or remove non-informative menus from a list or group of menus in an IVR system. For example, a menus list may be generated with the following pre-process: i. Build or create a directed graph based on a sample of IVR journeys (each menu being reflected as a node or point in the directed graph, and each directed arc representing following menus in an IVR sequence). ii. Filter out or remove from the directed graph the most frequent menus (e.g., nodes) with the highest degree (e.g., filter out or remove non-informative menus from a list or group of menus in an IVR system by removing the nodes with the highest degree, as explained in detail herein).
(16) 2. Prompts concatenation: concatenate or combine prompts (e.g., the text played by the system) of the remaining menus (e.g., which have not been filtered out) and corresponding customer responses.
(17) 3. Calculate a text-based similarity score for each category (e.g., each contact reason): i. Calculate a distance-based score for every word in the concatenated prompt and every word in the category (e.g., each word being represented), for example, via a dense vector (e.g., a pre-trained, domain specific word-embedding representation). The vector space may capture semantic similarities between words in the sense that similar words will be geometrically close to each other in the vector space. ii. For each one of the category's words, take the maximum similarity score. iii. The category score equals an average of those maximum scores.
(18) 4. Max score: select the category with the highest score.
(19) Embodiments of the invention offer a completely automatic way to categorize IVR journeys. The complexity of the problem addressed by embodiments of the invention stems from the fact that an IVR system is inherently very dynamic and the text that it plays to the customer depends on the particular customer's state and history. In many cases the system may try to drive a customer towards a specific path (e.g., bill payment), while the customer may have a different intent (e.g., report faulty equipment). This results in a lengthy dialog that complicates the categorization process. This causes unnecessary processing power to be wasted on analyzing the additional dialog (e.g., text), as well as excess data storage to be wasted in storing the excess data in memory. Embodiments of the invention mitigate against both of these excesses by first filtering irrelevant prompts based on statistical network analysis and then computing the distance between the concatenated dialog via a novel alignment algorithm, as described herein.
(20) Furthermore, embodiments of the invention may be integrated as part of a data injection pipeline and may provide a contact reason for every IVR journey handled by an IVR system. These contact reasons may further improve IVR systems by being integrated into various system analyses, such as in reports showing the distribution of contact reasons in IVR calls, IVR-to-agent routing evaluation, correlation of IVR contact reason to IVR KPIs and others.
(21) These and other features of embodiments of the invention will be further understood with reference to
(22)
(23) System server 110 may be any suitable computing device and/or data processing apparatus capable of communicating with computing devices, other remote devices or computing networks, receiving, transmitting and storing electronic information and processing requests as further described herein. System server 110 is, therefore, intended to represent various forms of digital computers, such as laptops, desktops, workstations, personal digital assistants, servers, blade servers, mainframes, and other appropriate computers and/or networked or cloud-based computing systems capable of employing the systems and methods described herein.
(24) System server 110 may include a server processor 115 which is operatively connected to various hardware and software components that serve to enable operation of the system 100. Server processor 115 serves to execute instructions to perform various operations relating to advanced search, and other functions of embodiments of the invention as described in greater detail herein. Server processor 115 may be one or several processors, a central processing unit (CPU), a graphics processing unit (GPU), a multi-processor core, or any other type of processor, depending on the particular implementation.
(25) System server 110 may be configured to communicate via communication interface 120 with various other devices connected to network 105. For example, communication interface 120 may include but is not limited to, a modem, a Network Interface Card (NIC), an integrated network interface, a radio frequency transmitter/receiver (e.g., Bluetooth wireless connection, cellular, Near-Field Communication (NFC) protocol, a satellite communication transmitter/receiver, an infrared port, a USB connection, and/or any other such interfaces for connecting the system server 110 to other computing devices and/or communication networks such as private networks and the Internet.
(26) In certain implementations, a server memory 125 is accessible by server processor 115, thereby enabling server processor 115 to receive and execute instructions such as a code, stored in the memory and/or storage in the form of one or more software modules 130, each module representing one or more code sets. The software modules 130 may include one or more software programs or applications (collectively referred to as the server application) having computer program code or a set of instructions executed partially or entirely in server processor 115 for carrying out operations for aspects of the systems and methods disclosed herein, and may be written in any combination of one or more programming languages. Server processor 115 may be configured to carry out embodiments of the present invention by, for example, executing code or software, and may execute the functionality of the modules as described herein.
(27) In accordance with embodiments of
(28) Of course, in some embodiments, server modules 130 may include more or less actual modules which may be executed to enable these and other functionalities of the invention. The modules described herein are, therefore, intended to be representative of the various functionalities of system server 110 in accordance with some embodiments of the invention. It should be noted that, in accordance with various embodiments of the invention, server modules 130 may be executed entirely on system server 110 as a stand-alone software package, partly on system server 110 and partly on user device 140, or entirely on user device 140.
(29) Server memory 125 may be, for example, random access memory (RAM) or any other suitable volatile or non-volatile computer readable storage medium. Server memory 125 may also include storage which may take various forms, depending on the particular implementation. For example, the storage may contain one or more components or devices such as a hard drive, a flash memory, a rewritable optical disk, a rewritable magnetic tape, or some combination of the above. In addition, the memory and/or storage may be fixed or removable. In addition, memory and/or storage may be local to the system server 110 or located remotely.
(30) In accordance with further embodiments of the invention, system server 110 may be connected to one or more database(s) 135, for example, directly or remotely via network 105. Database 135 may include any of the memory configurations as described herein, and may be in direct or indirect communication with system server 110. In some embodiments, database 135 may store information relating to user documents. In some embodiments, database 135 may store information related to one or more aspects of the invention.
(31) As described herein, among the computing devices on or connected to the network 105 may be one or more user devices 140. User device 10 may be any standard computing device. As understood herein, in accordance with one or more embodiments, a computing device may be a stationary computing device, such as a desktop computer, kiosk and/or other machine, each of which generally has one or more processors, such as user processor 145, configured to execute code to implement a variety of functions, a computer-readable memory, such as user memory 155, a user communication interface 150, for connecting to the network 105, one or more user modules, such as user module 160, one or more input devices, such as input devices 165, and one or more output devices, such as output devices 170. Typical input devices, such as, for example, input devices 165, may include a keyboard, pointing device (e.g., mouse or digitized stylus), a web-camera, and/or a touch-sensitive display, etc. Typical output devices, such as, for example output device 170 may include one or more of a monitor, display, speaker, printer, etc.
(32) In some embodiments, user module 160 may be executed by user processor 145 to provide the various functionalities of user device 140. In particular, in some embodiments, user module 160 may provide a user interface with which a user of user device 140 may interact, to, among other things, communicate with system server 110.
(33) Additionally or alternatively, a computing device may be a mobile electronic device (MED), which is generally understood in the art as having hardware components as in the stationary device described above, and being capable of embodying the systems and/or methods described herein, but which may further include componentry such as wireless communications circuitry, gyroscopes, inertia detection circuits, geolocation circuitry, touch sensitivity, among other sensors. Non-limiting examples of typical MEDs are smartphones, personal digital assistants, tablet computers, and the like, which may communicate over cellular and/or Wi-Fi networks or using a Bluetooth or other communication protocol. Typical input devices associated with conventional MEDs include, keyboards, microphones, accelerometers, touch screens, light meters, digital cameras, and the input jacks that enable attachment of further devices, etc.
(34) In some embodiments, user device 140 may be a dummy terminal, by which processing and computing may be performed on system server 110, and information may then be provided to user device 140 via server communication interface 120 for display and/or basic data manipulation. In some embodiments, modules depicted as existing on and/or executing on one device may additionally or alternatively exist on and/or execute on another device. For example, in some embodiments, one or more modules of server module 130, which is depicted in
(35)
(36) In some embodiments, method workflow 200 may be performed on a computer (e.g., system server 110) having a processor (e.g., server processor 115), memory (e.g., server memory 125), and one or more code sets or software (e.g., server module(s) 130) stored in the memory and executing in or executed by the processor. Method workflow 200 begins with the first of the two pre-processes, building a menu black list (e.g., a list of IVR menus to be filtered), at step 205, when the processor is configured to build a directed graph, as described in detail with reference to
(37) Turning briefly to
Example 1
(38) [7865,7756,7333,6777,2343],
(39) [6777,4567,7345,3453,6633,9384],
(40) [7686,5568,3454,2343,2982]
(41) In some embodiments, at step 320, for each listed IVR journey, the processor may generate a distinct node in the direct graph for each IVR menu, and calculate or otherwise provide a count of the number of occurrences of each node (e.g., reflecting the number of times a given IVR menu is represented). In some embodiments, at step 330, the processor may be configured to generate an arc, edge, or link between the nodes of each bi-gram of IVR menus (e.g., pairs of consecutive IVR menus in an IVR sequence). As understood herein, an arc, edge, or link represents a functional connection between pairs of nodes. In some embodiments, one or more of such connections may be directional or bi-directional in nature, e.g., a directed arc or edge), and each directed arc may represent a menu path in an IVR sequence within a given sample IVR customer journey. In some embodiments, at step 340, the processor may be configured to analyze, for example, all the bi-grams of the IVR menus (e.g., pairs of consecutive IVR menus) within each IVR sequence. For example, the processor may calculate the degree-in (e.g., instances in which the node is a second in a pair), the degree-out (e.g., instances in which the node is the first one in a pair), the degree (e.g., the number of connections a given node has to other nodes, or degree-in +degree-out) of each node, and/or the number of occurrences of each pair.
(42) At step 350, in some embodiments the processor may generate (e.g., output or construct) a directed graph based on the nodes, edges (e.g., directed arcs), and degrees. In some embodiments, a directed graph representing an IVR system may include nodes representing IVR menus, an edge or link from a node representing a given menu A to a node representing a given menu B indicating that there is an IVR sequence in which the menu B directly follows the menu A, and the weight of the edge indicating the number of times the menu B directly follows the menu A in a given sample (e.g., a given sample IVR journey or sample set of IVR journeys).
(43) For example, using the inputs in Example 1 above would yield as an output a directed graph 400 as provided in
(44) Returning to
(45) Turning briefly to
(46) Returning again to
(47) After the pre-processing phase, in some embodiments the method may continue with the IVR journey categorization phase, as described herein. At step 220, in some embodiments, the processor may receive, as an input, an IVR journey. In some embodiments, an IVR Journey (e.g., an IVR sequence) may be represented as a list of menus. Furthermore, a menu may be represented as a tuple that includes 3 strings: a menu ID, a prompt, and response. An example IVR menu prompt and response are shown in Example 2 below.
Example 2
(48) Prompt: For Billing say billing or press 1, For Connections say connections or press 2, For Faults say faults or press 3, or for Products say products or press 4.
(49) Response: billing
(50) In some embodiments, an IVR menu may include voice recognition, dual-tone multi-frequency (DTMF) signaling, or both options. In some embodiments, e.g., when a user verbalizes a response to a prompt by the IVR system, the response may be analyzed by an IVR automatic speech recognition (ASR) system and recorded. In some embodiments, e.g., when a user presses a button corresponding to the desired option (e.g., pressing 2 for Connections), the response may be interpreted in the context of the prompt options and recorded. In the above example, if a user presses 1, the press may be interpreted as billing.
(51) At step 225, the processor may filter or remove one or more non-informative menus from the plurality of available menus (e.g., the menus that make up the IVR journey). In some embodiments, the processor may filter one or more non-informative menus from the plurality of available menus e.g., based on the black list. As understood herein, a non-informative menu is a menu within an IVR journey having a defined lack of informative value in determining the correct category for the IVR journey. In some embodiments, a non-informative menu may be a menu within an IVR journey that also appears on the black list, e.g., due to its lack of informative value in determining the correct category for the IVR journey. In some embodiments, a non-informative menu may be identified for filtering, for example, based on at least one of a threshold degree of frequency of its representative node in the directed graph, a threshold in-degree of its representative node in the directed graph, and/or a threshold out-degree of its representative node in the directed graph, as explained in detail herein. In some embodiments, the processor may filter or remove the one or more non-informative menus by splitting or dividing the IVR journeys or sequences into IVR menus, and, for each menu, if its corresponding menu ID is in the black list, then the processor may remove it from the IVR journey. The output of this is a filtered IVR journey.
(52) At step 230, in some embodiments the processor may interpret any DTMF responses in the filtered IVR journey (e.g., when a user presses 1, 2 or any other number option rather than articulating the response verbally) and replace the selected option with its meaning extracted from the prompt. In some embodiments, for each menu, the processor may first parse the prompt to produce a table of options, e.g. {1: billing, 2: connections, 3: faults, 4: products}. This may be implemented, for example, by the processor identifying recurrent patterns in the prompt, e.g., PRESS NUM FOR X or NUM FOR X, and then constructing a table from the patterns in which NUM=X. In some embodiments, if a user response is a key in a table of options, the processor may replace it with the corresponding value.
(53) At step 235, the processor may concatenate or combine the respective associated menu prompt of each menu that was not filtered, and one or more user responses (e.g., responses to the menu prompt) to one or more menu prompts from the series of interactions in the given customer IVR journey, into a concatenated word string. As understood herein, concatenation refers to the operation of joining character strings end-to-end. In some embodiments, the processor may concatenate the filtered IVR string by, for example, initializing an empty result string, splitting the filtered IVR journey to individual steps, and, for each step, appending prompt and response values to the result string. In some embodiments, the resulting output may be a text string that is a consecutive concatenation of prompts and responses in the given IVR journey.
(54) At step 240, in some embodiments, the processor may perform text preprocessing on the text comprising concatenated prompts and user responses. For example, in some embodiments all or specific uppercase letters may be converted to lowercase, function words may be removed, and/or stemming may be performed. Stemming, as understood herein, may refer to the process of reducing inflected (and/or sometimes derived) words to their word stem, base, or root form. Such preprocessing functions may be performed by implementation of existing NLP tools as known in the art, such as, e.g., spacy, openNLP, or Stanford NLP. An example output may be purchase new WiFi modem need help connect PC tablet press 2.
(55) At step 245, the processor may calculate a similarity score between the concatenated word string (e.g., the filtered and pre-processed IVR journey text) and a category name of each category from a categories list, as described in detail with reference to
(56) Turning briefly to
(57) At step 620, in some embodiments, using word embeddings, e.g., the trained word embeddings of step 215, for each contact reason from the list of contact reasons, the processor may compute a first similarity score (S), between each word (w.sub.j) in the IVR journey text and each word (v.sub.i) in the contact reason. It should be noted that in various embodiments, one or more similarity measures may be implemented in calculating the various similarity scores described herein. For example, in some embodiments, a cosine similarity may be used, using, for example, the following equation:
S(v.sub.i,w.sub.j)=cosine(embedding(w.sub.i),embedding(v.sub.j))
(58) Cosine similarity, as understood herein, is a measure of similarity between two non-zero vectors of an inner product space that measures the cosine of the angle between the two vectors. In text analysis, each term may be notionally assigned a different dimension and a text may be characterized by a vector where the value in each dimension corresponds to the number of times the term appears in the text. Cosine similarity then gives a useful measure of how similar two sets of text are likely to be in terms of their subject matter. Of course, in some embodiments other known similarity measures may also or alternatively be implemented.
(59) At step 620, in some embodiments the processor may compute, for each word v.sub.i in the contact reason text (V), a similarity score representing its similarity to the IVR journey text (W), as the maximum similarity to words in the text W, e.g., using the following equation:
S(v.sub.i,W)=max(S(v.sub.i,w.sub.j)) where w.sub.j is a word in W
(60) Next at step 630, in some embodiments, the processor may calculate a similarity between the IVR journey text (W) and the contact reason text (V) as the average of similarity scores between each word of the contact reason and the IVR Journey text as computed in the second similarity score, e.g., using the following equation:
S(V,W)=average(S(v.sub.i,W)) for all v.sub.i in V
(61) At step 640, in some embodiments the result of the similarity score S(V,W) (e.g., of step 630 above) may be inserted into the empty map, e.g., the processor may populate the map, generating a similarity map, based on the similarity score S(V,W). In some embodiments, method 600 may be executed by the processor for each contact reason (e.g., each category) in the list of contact reasons (e.g., in the list of categories), thereby generating maps reflecting the comparison of a given IVR journey text to each of the contact reasons in the contact reason list.
(62) By way of example, Table 1 below shows an example output map resulting from the execution of a comparison between one contact reason (payment extension) and one prompt fragment (extend payment press 1).
(63) TABLE-US-00001 TABLE 1 payment extension extend 0.4 0.8 payment 1.0 0.5 press 0.2 0.11 1 0.01 0.02 MAX 1.0 0.8 Average (0.9)
(64) Returning to
(65) An example algorithm according to an embodiment of method 600 is summarized below:
(66) In order to choose the correct contact reason for IVR journey J, the algorithm may: calculate a similarity score between the IVR journey words to each of the contact reason words:
(67)
CR(J)=argmax.sub.1ikS.sub.i Notations: CR.sub.i=The i contact reason (e.g., Billing, Technical Support) k=number of different contact reasons J=the IVR journey represented as concatenated prompts words v=word in the contact reason w=word in the concatenated prompts of the journey {right arrow over (v)},{right arrow over (w)}=the words embedded vectors
(68) The output is a table or tables with similarity score calculations between the input text and each contact reason, an example of which is shown in
(69) Embodiments of the invention provide significant improvements to IVR system technology in general and to IVR journey contact reason matching in particular, materially mitigating against unnecessary processing power being wasted on analyzing additional dialog (e.g., text), as well as excess data storage being wasted in storing excess data in memory. By way of example of the efficacy and improvement of implementing the systems and methods described herein, embodiments of the invention were tested on 200 manually labeled real IVR journeys achieving 88% accuracy (with no previous algorithms executed). The following table, Table 2, includes a few example results.
(70) TABLE-US-00002 TABLE 2 Contact Reason Prompts Sequence Technical Thanks for calling demoivr3.\Now, please 79940, 78367, 78377, 78379, support just say or enter a phone number that's 78380, 79017, 79124, linked to your internet account\Was 79750, 80469, 80469, that . . . \Please say yes or no.\Thanks. Just a 80469, 80468, 80467, second . . . \Is this call today about technical 79973, 80241, 80242, support?\Have you restarted your modem 79966 and computer or device to see if that will fix the issue your currently experiencing?\Please look at the text message we just sent to your mobile, and tap the link to start trouble shooting your ADSL connection, Wi-Fi or email setup problem. Please hang up now and tap the link to be guided through the trouble shooting steps. If you're not \We are currently experiencing long wait times. Would you like us to call you back in approximately . . . \Sorry, I appear to be having difficulty registering your call back. I'll just put you back in the queue for now.\When you've finished, please stay on the line to provide some feedback about your experience. Billing Thanks for calling demoivr Business.\ . . . and 79948, 78349, 78362, 78380, and is your enquiry about the phone you're on 78377, 78379, 78707, payment right now? Please say yes or no.\So please 78698, 79637, 79627, just say or enter the phone number\Thanks. 79973, 79966 Just a second . . . \Was that . . . \Please say yes or no.\So I can direct your call to the right place, in just a few words please tell me the reason for your call.\Okay, one second . . . \There are lots of ways to pay your demoivr account. You can set up a direct debit. Another popular way is online at our secure website. Go to demoivr dot com forward slash bill pay. You can bpay from your own bank if you have a biller code and reference n\Okay, to find out the balance of your billed and unbilled call charges, say Account Balance. If you'd like to get a copy of your bill say Bill Copy. Or for anything else about your account say Other Enquiry\When you've finished, please stay on the line to provide some feedback about your experience. Technical . . . and is your enquiry about the phone you're 78349, 78380, 78707, 78717, support on right now? Please say yes or 79369, 79011, 79530, no.\Thanks. Just a second . . . \So I can direct 79054, 79973, 80451, your call to the right place, in just a few 80452, 80454, 80456, words please tell me the reason for your 80457, 80458, 80459, call.\As demoivr offers lots of different 80460, 79966 services to Mobile callers I need you to tell me a little more about the reason for your call today. You can say something like check my account balance or find out about Messagebank. So, what's the reason?\That's to report a fault with a mobile . . . \ . . . is that right?\Okay, one second . . . \If your phone is asking for a PUK code, please say P.U.K. If you need to reset your PIN, please say, pin reset. You can also try turning your phone off and on again. This resets the phone on the network and may fix the issue. If you're currently calli\When you've finished, please stay on the line to provide some feedback about your experience.\Not tech savvy? Check out demoivr dot com forward slash mobile support for troubleshooting tips for some of the popular handsets./Need a little help to get the most out of your mobile? At demoivr dot com forward slash mobile support you will find step by step tips on everything from mobile support to setting up and customising some of the popular handsets
(71)
(72) In some embodiments, from the SFTP server the files may be integrated in a batch processing pipeline. For example, a pipeline that originally used a rule-based system to categorize each session according to the contact reason may instead be programmed to implement the IVR journey contact reason detector to provide an automatic categorization for IVR sessions. After preprocessing, the data may be stored in a data storage system, e.g., server database 135 or external database 175, in two tables, e.g., IVREVENTS and IVRSESSIONS, using the same or equivalent structure as the raw CSV files. In some embodiments, the field contact_reason (e.g., reflecting the mapped contact reason for each IVR journey) may be added to the IVRSESSIONS table during the pre-processing phase. This data may be used then by various other system applications.
(73) By way of a first example, some embodiments of the invention may correlate IVR contact reasons to IVR KPIs (for example, containment-rate, drop-rate, average time etc.) and sort different contact reasons with respect to given KPIs, e.g., in order to provide insights such as: 30% of customers calling for Payment Extension process via IVR, continues to agent. As such, in some embodiments, the processor may, for each contact reason: (1) extract from the database all IVR sequences that have been assigned with the given contact reason, (2) compute an average containment-rate (or any other given KPI) over the extracted sequences, (3) sort the contact reasons based on average containment rate in the descending order, and (4) present the results, e.g., on a display, to an analyst.
(74) By way of a second example, some embodiments of the invention may compare IVR contact reasons to company call drivers (e.g., the topics which drive customers to call and typically account for the highest volume of traffic to an IVR), e.g., in order to produce insights such as 20% of transferred to agent calls due to Technical issue with mobile, were actually about upgrading a mobile. As such, in some embodiments, the processor may, for each IVR sequence that reached an agent (e.g., due to the caller's issue not being properly resolved via the IVR): (1) if IVR contact reason does not match a company call driver, (2) store a pair (e.g., IVR_CR, NX_CALL_DRIVER) with count=1 (or if the pair already exists increase the count by 1), (3) sort (e.g., IVR_CR, NX_CALL_DRIVER) based on the count, e.g., in the descending order, and (4) present the results, e.g., on a display, to an analyst.
(75) Of course, in other example implementations, systems and methods according to embodiments of the invention may, for example, process a repeat calls analysis: correctly identify customers that are calling again because their issue was not resolved at the first time. If the contact reason is different then the call would not be a repeated call. Another example implementation is in Customer journey analytics: e.g., providing valuable insights regarding journeys that include IVR interactions (e.g., JES, patterns discovery, etc.).
(76) Unless explicitly stated, the method embodiments described herein are not constrained to a particular order or sequence. Furthermore, all formulas described herein are intended as examples only and other or different formulas may be used. Additionally, some of the described method embodiments or elements thereof may occur or be performed at the same point in time.
(77) While certain features of the invention have been illustrated and described herein, many modifications, substitutions, changes, and equivalents may occur to those skilled in the art. It is, therefore, to be understood that the appended claims are intended to cover all such modifications and changes as fall within the true spirit of the invention.
(78) Various embodiments have been presented. Each of these embodiments may of course include features from other embodiments presented, and embodiments not specifically described may include various features described herein.