Embodiments of the present invention relate to the field of software for operating contact centers, in particular, software and services for enabling customers to handle relationship with vendors with which they are having or considering having a business relationship.
Vendor relationship management (VRM) is generally directed to providing customers with independence from vendors and a better mechanism for engaging with vendors. Unlike customer relationship management (CRM) where an enterprise manages relationship and data with multiple customers, with VRM, a customer manages relationship and data with multiple vendors/enterprises.
When applying VRM in the context of contact centers where the vendors are the different contact centers, there is a need for an efficient mechanism for customers to manage different aspects of their relationship with the contact centers.
According to one embodiment of the present invention, a method includes: receiving, on a processor, data associated with an interaction between a user and a first enterprise; applying, by the processor, a rule of a template based on the data; identifying, by the processor and using the rule of the template, a second enterprise; and transmitting, by the processor, the data to the second enterprise in accordance with the rule.
The template may include a script.
The method may further include receiving, by the processor, data sharing preferences, wherein the transmitting the data to the second enterprise includes transmitting data in accordance with data sharing preferences.
The data may include a plurality of fields, and the data sharing preferences may include a plurality of sharing preferences, each of the sharing preferences corresponding to one of the plurality of fields.
The method may further include receiving, on the processor, a selection of a third enterprise to connect to, the selection including authentication information associated with the user and with the third enterprise.
The data may include a plurality of fields, and the method may further include: identifying a subset of fields of the plurality of fields of the data in accordance with the template; and transmitting the subset of fields to the second enterprise.
The method may further include: storing, by the processor, user profile information; and transmitting, by the processor, the user profile information to the first enterprise.
The may further include: storing, by the processor, first user authentication information associated with the first enterprise and second user authentication information associated with the second enterprise; transmitting, by the processor, the first user authentication information to the first enterprise; and transmitting, by the processor, the second user authentication information to the second enterprise.
The may further include: receiving, by the processor, a call reason; identifying, by the processor, routing information in accordance with the call reason; and connecting the user with an agent in accordance with the identified routing information.
The may further include transmitting, by the processor, first agent availability information of the first enterprise and second agent availability information of the second enterprise.
The data associated with the interaction may include at least one of: an order receipt, an error log, a test result, an order history, tracking information, and notes.
The data may include a change in status.
The method may further include: receiving, by the processor, first device data from a first device of the user; and transmitting, by the processor, the first device data to the first enterprise and to the second enterprise.
The method may further include: receiving, by the processor, second device data from a second device of the user; and transmitting, by the processor, the second device data to the first enterprise and to the second enterprise.
The method may further include transmitting the data to an individual.
The method may further include: receiving an instruction to modify the rule of the template; and modifying the rule of the template in accordance with the instruction to generate a modified template.
The method may further include transmitting the template.
The processor may be a component of a mobile device.
The processor may be a component of a server connected to a computer network.
According to one embodiment of the present invention an apparatus includes: a processor; and a memory, wherein the memory stores instructions that, when executed by the processor, cause the processor to: receive data associated with an interaction between a user and a first enterprise; apply a rule of a template based on the data; identify, using the rule of the template, a second enterprise; and transmit the data to the second enterprise in accordance with the rule.
In general terms, embodiments of the present invention are directed to an application for assisting customers to communicate with one or more customer contact centers before, during, and/or after a communication session with a particular contact center. Embodiments of the present invention are also directed to an application that, in addition or in lieu of assisting customers in communicating with the customer contact centers, also allows customers to manage data associated with interactions with the various contact centers or other vendors by allowing customers to share data with other.
According to one exemplary embodiment, the contact center includes resources (e.g. personnel, computers, and telecommunication equipment) to enable delivery of services via telephone or other communication mechanisms. Such services may vary depending on the type of contact center, and may range from customer service to help desk, emergency response, telemarketing, order taking, and the like.
Customers, potential customers, or other end users (collectively referred to as customers) desiring to receive services from the contact center may initiate inbound calls to the contact center via their end user devices 10a-10c (collectively referenced as 10). Each of the end user devices 10 may be a communication device conventional in the art, such as, for example, a telephone, wireless phone, smart phone, personal computer, electronic tablet, and/or the like. Users operating the end user devices 10 may initiate, manage, and respond to telephone calls, emails, chats, text messaging, web-browsing sessions, and other multi-media transactions. Such communication may be, for example, via an application 11a-11c (referenced generally via reference 11) hosted by the end user device 10. The application 11 may, in addition or in lieu of the communication, allow the customer to manage relationships and data with various contact centers.
Inbound and outbound calls from and to the end users devices 10 may traverse a telephone, cellular, and/or data communication network 14 depending on the type of device that is being used. For example, the communications network 14 may include a private or public switched telephone network (PSTN), local area network (LAN), private wide area network (WAN), and/or public wide area network such as, for example, the Internet. The communications network 14 may also include a wireless carrier network including a code division multiple access (CDMA) network, global system for mobile communications (GSM) network, and/or any 3G or 4G network conventional in the art.
According to one exemplary embodiment, the contact center 80 includes a switch/media gateway 12 coupled to the communications network 14 for receiving and transmitting calls between end users and the contact center 80. The switch/media gateway 12 may include a telephony switch configured to function as a central switch for agent level routing within the center. In this regard, the switch 12 may include an automatic call distributor, a private branch exchange (PBX), an IP-based software switch, and/or any other switch configured to receive Internet-sourced calls and/or telephone network-sourced calls. According to one exemplary embodiment of the invention, the switch is coupled to a call server 18 which may, for example, serve as an adapter or interface between the switch and the remainder of the routing, monitoring, and other call-handling components of the contact center 80.
The contact center 80 may also include a multimedia/social media server for engaging in media interactions other than voice interactions with the end user devices 10 and/or web servers 32. The media interactions may be related, for example, to email, vmail (voice mail through email), chat, video, text-messaging, web, social media, screen-sharing, and the like. The web servers 32 may include, for example, social interaction site hosts for a variety of known social interaction sites to which an end user may subscribe, such as, for example, Facebook, Twitter, and the like. The web servers may also provide web pages for the enterprise that is being supported by the contact center 80. End users may browse the web pages and get information about the enterprise's products and services. The web pages may also provide a mechanism for contacting the contact center 80, via, for example, web chat, voice call, email, web real time communication (WebRTC), or the like.
According to one exemplary embodiment of the invention, the switch is coupled to an interactive media response (IMR) server 34, which may also be referred to as a self-help system, virtual assistant, or the like. The IMR server 34 may be similar to an interactive voice response (IVR) server, except that the IMR server is not restricted to voice, but may cover a variety of media channels including voice. Taking voice as an example, however, the IMR server may be configured with an IMR script for querying calling customers on their needs. For example, a contact center 80 for a bank may tell callers, via the IMR script, to “press 1” if they wish to get an account balance. If this is the case, through continued interaction with the IMR, customers may complete service without needing to speak with an agent. The IMR server 34 may also ask an open ended question such as, for example, “How can I help you′?” and the customer may speak or otherwise enter a reason for contacting the contact center 80. The customer's response may then be used by the routing server 20 to route the call to an appropriate contact center 80 resource.
If the call is to be routed to an agent, the call is forwarded to the call server 18 which interacts with a routing server 20 for finding an appropriate agent for processing the call. The call server 18 may be configured to process PSTN calls, VoIP calls, and the like. For example, the call server 18 may include a session initiation protocol (SIP) server for processing SIP calls. According to some exemplary embodiments, the call server 18 may, for example, extract data about the customer interaction such as the caller's telephone number, often known as the automatic number identification (ANI) number, or the customer's internet protocol (IP) address, or email address.
In some embodiments, the routing server 20 may query a customer database, which stores information about existing clients, such as contact information, service level agreement (SLA) requirements, nature of previous customer contacts and actions taken by contact center 80 to resolve any customer issues, and the like. The database may be managed by any database management system conventional in the art, such as Oracle, IBM DB2, Microsoft SQL server, Microsoft Access, PostgreSQL, MySQL, FoxPro, and SQLite, and may be stored in a mass storage device 30. The routing server 20 may query the customer information from the customer database via an ANI or any other information collected by the IMR 34 and forwarded to the routing server by the call server 18.
Once an appropriate agent is available to handle a call, a connection is made between the caller and the agent device 38a-38c (collectively referenced as 38) of the identified agent. Collected information about the caller and/or the caller's historical information may also be provided to the agent device for aiding the agent in better servicing the call. In this regard, each agent device 38 may include a telephone adapted for regular telephone calls, VoIP calls, and the like. The agent device 38 may also include a computer for communicating with one or more servers of the contact center 80 and performing data processing associated with contact center 80 operations, and for interfacing with customers via voice and other multimedia communication mechanisms.
The selection of an appropriate agent for routing an inbound call may be based, for example, on a routing strategy employed by the routing server 20, and further based on information about agent availability, skills, and other routing parameters provided, for example, by a statistics server 22.
The contact center 80 may also include a reporting server 28 configured to generate reports from data aggregated by the statistics server 22. Such reports may include near real-time reports or historical reports concerning the state of resources, such as, for example, average waiting time, abandonment rate, agent occupancy, and the like. The reports may be generated automatically or in response to specific requests from a requestor (e.g. agent/administrator, contact center application, and/or the like).
According to one exemplary embodiment of the invention, the routing server 20 is enhanced with functionality for managing back-office/offline activities that are assigned to the agents. Such activities may include, for example, responding to emails, responding to letters, attending training seminars, or any other activity that does not entail real time communication with a customer. Once assigned to an agent, an activity an activity may be pushed to the agent, or may appear in the agent's workbin 26a-26c (collectively referenced as 26) as a task to be completed by the agent. The agent's workbin may be implemented via any data structure conventional in the art, such as, for example, a linked list, array, and/or the like. The workbin may be maintained, for example, in buffer memory of each agent device 38.
According to one exemplary embodiment of the invention, the mass storage device(s) 30 may store one or more databases relating to agent data (e.g. agent profiles, schedules, etc.), customer data (e.g. customer profiles), interaction data (e.g. details of each interaction with a customer, including reason for the interaction, disposition data, time on hold, handle time, etc.), and the like. According to one embodiment, some of the data (e.g. customer profile data) may be provided by a third party database such as, for example, a third party customer relations management (CRM) database. The mass storage device may take form of a hard disk or disk array as is conventional in the art.
According to one embodiment, the contact center may also include an analytics server 13 for analyzing real time/recorded speech/text exchanged in interactions between customers and the contact center. The analyzed data may be used, for example, to perform searches, run statistics, categorize the interactions, and/or gain understanding of the communications to better serve the customer during a current interaction and/or future interactions.
A person of skill in the art should recognize that other servers in lieu or in addition to the servers depicted in
The various servers of
In the various embodiments, the term interaction is used generally to refer to any real-time and non-real time interaction that uses any communication channel including, without limitation telephony calls (PSTN or VoIP calls), emails, vmails (voice mail through email), video, chat, screen-sharing, text messages, social media messages, web real-time communication (e.g. WebRTC calls), and the like.
Embodiments of the present invention are directed to systems and methods for providing assistance to customers before, during, after, and between communications with agents at a contact center 80.
According to one embodiment, the system of
According to one embodiment, a customer accesses the conversation assistance server 110 via the client application 11 installed in his or her end user device 10 to manage conversations and/or data with the contact centers 80. In this regard, the client application 11 provides a front-end user interface to the user. In the embodiment where the client application 11a is a mobile application, the application may be implemented in any of a variety of languages (e.g., C, Objective C, Java, HTML and JavaScript, etc.) and may operate on any of a variety of operating systems and software platforms (e.g., Apple® iOS, Android®, Microsoft® Windows Mobile®, Microsoft Windows®, Apple® OS X®, etc.). In the embodiment where the client application 11b is a web application, it may be configured to in a web browser of, for example, a laptop computer, a desktop computer, or a tablet computer.
In some embodiments of the present invention, the conversation assistance servers 110 may include one or more servers typically found in customer contact centers such as, for example, a web server 111, a SIP server 113, a mobile services server 115, a speech and text analytics server 117, and a conversation assistance database 119. The various servers are invoked for providing data and services to the client applications 11, and communicating with the contact centers 80 on behalf of the customer or user.
According to one embodiment, the client applications 11 communicate directly only with conversation assistance servers 110, and the conversation assistance servers communicate with the servers of the contact centers 80, such as, for example, the servers depicted in
According to one embodiment of the present invention, the conversation assistance servers 110 communicate with various servers associated with the contact center. For example, the conversation assistance servers 110 may communicate with speech and text analytics servers 13 of the contact center to retrieve transcriptions of prior calls and may communicate with a multimedia/social media server 24 of the contact center to initiate chat conversations between the user and an agent in the contact center. Other types of information such as availability of specific agents, estimated wait time, and call back services can be provided to the conversation assistance servers 110 using, for example, APIs such as the Genesys® Platform SDK.
Although the embodiment shown in
In other embodiments, in addition to routing, the conversation assistance servers 110 transform the requests and responses between the client applications 11 and the contact centers 80. For example, the conversation assistance servers 110 may be configured to modify or otherwise reformat data pushed from the contact centers 80 to a format more appropriate for the particular devices that the client applications 11 are running on (e.g., smartphones versus larger screened devices such as tablets and laptop computers or the speed of the Internet connection between the device and the conversation assistance servers 110).
In some cases where quick responsiveness is desired (e.g., during a call with a contact center), communications occur directly between the client application 11 and the contact center 80 over connection 136, e.g., when communicating using SIP and RTP.
According to one embodiment of the present invention, the conversation assistance servers 110 provide a number of functions to a user via the client applications 11 before a call (e.g., during a “pre-call” period). These functions include, without limitations, customer authentication, call reason, identification, agent selection, and call back management.
In one embodiment, conversation assistance servers 110 assist in customer authentication by receiving (and possibly storing) credentials from a user and transmitting the credentials to the contact center 80. For example, a user may input name, address, and account number information into a client application 11 which forwards the credentials to the contact center 80, thereby reducing errors from inaccuracy in conveying the authentication information and streamlining the initial customer authentication portion of the call (e.g., supplying a “mother's maiden name” or other password).
According to one embodiment of the present invention, the conversation assistance servers 110 or the client application 11 store the user's credentials. These credentials may include authentication tokens issued by the various organizations, passwords, addresses and other contact information, etc. These stored credentials may be automatically transmitted to various contact centers 80 by the client application or the conversation assistance servers 110. In addition, the client application 11 allows a user to control which portions of the stored credentials can be sent to various enterprises.
For example, the stored credentials may include a user's address, bank account number, frequent flier number, credit card number, and phone number. As such, the user may be willing to share his or her frequent flier number and credit card number with an airline company, but would not be willing to share his or her bank account number with the airline company. As such, embodiments of the present invention allow a user to granularly select which portions of the stored credentials or information can be accessed by each enterprise that is compatible with the conversation assistance system 100.
In a traditional interactive voice response (IVR) menu system, a user (or a customer) navigates through menus to select a broad call reason (e.g., “For sales inquiries, press 1. For customer support, press 2 . . . ”) in addition to selecting a language. In one embodiment, the client application 11 stores customer preferences such as language and preferred (or “favorite”) agents and transmits these preferences to the contact center 80, thereby allowing the user to be routed to an appropriate agent more quickly.
In one embodiment, the reason for the current call can be inferred using a variety of information including the user's previous call (if any), prior interactions with the enterprise, information collected from the user's interactions with the enterprise's website, and prior communications using other modalities (e.g., chat, email, prior purchases, etc.).
For example, if the previous call included the phrase “How do I program my DVR from my mobile phone?” and the agent answers “I can't help you with this, you might want to visit the website,” a speech analytics system 13 can analyze the conversation, determine that the call was not resolved, and categorize the call accordingly. Based on this category (or “topic”) information, a conversation assistance server 110 can access the speech analytics system 13 in operation 504 to retrieve information that the prior call was categorized as unresolved, receive information in operation 506 regarding other categories associated with the call (e.g., “DVR support”), and include “DVR customer support” as a potential inferred call reason. As such, embodiments of the present invention can use the categories that were automatically assigned by the speech analytics system 13 to the previous call in order to automatically determine whether the current call is likely to relate to a prior unresolved issue and to add these suggestions as to inferred potential call reasons in operation 508.
In some embodiments of the present invention, a user can use the client application 11 to mark a call as being unresolved. If the user calls again within a particular time period (e.g., 30 minutes), the system can infer that the user is likely calling again on the same issue.
According to one embodiment of the present invention, the user can flag or mark a conversation as being “resolved” or “unresolved” (or, equivalent terms such as “complete” or “incomplete”) based on his or her understanding of the circumstances. In addition, the speech analytics systems according to embodiments of the present invention can automatically detect whether an issue has been resolved or not based on the detection of phrases within the recognized speech (e.g., “Thank you, my phone is working again.”). However, there may be instances in which the user's perception of the resolution status may differ from that of the contact center (e.g., due to an error in the automatic speech recognition determination, due to a changing of the user's mood, due to changing conditions with the product, etc.).
As such, in some embodiments of the present invention, the resolution status of the call is synchronized between the contact center 80, the conversation assistance server 110, and the client application 11. For example, the synchronization process may include, for example: synchronizing based on newest timestamp; deferring to manually entered status settings (e.g., allowing the user or an agent's entries to automatically override the determinations of automatic speech recognition systems); or other synchronization techniques as would be known by a person of ordinary skill in the art.
According to another embodiment of the present invention, a call reason can be inferred from a self-help system operating, for example, on a website of the enterprise.
Generally, self-help attempts are “escalated” to a live agent. However, before routing takes place, information about the user is inferred from the interaction with the self-help system. For example, in response to the question “Am I eligible for an upgrade on my mobile phone?” the agent may reply “To answer this question, you need to speak with an agent, would you like me to connect you now?” The interaction may also be tagged with the “upgrade eligibility” category or topic. If the user answers “yes,” then the interaction may be tagged with the “unresolved” category because the self-help virtual agent was unable to resolve the user's issue. In operation 512, the conversation assistance server 110 retrieves information about the interaction with the self-help system (e.g., either during or after the interaction). In operation 514, the conversation assistance server 110 determines whether or not the interaction has been resolved and, in operation 516, identifies categories associated with the interaction. In the above example, the pending call should be routed with the call reason “upgrade eligibility” and, in operation 518, the conversation assistance server 110 adds the identified call reason to the inferred call reasons.
In some embodiments of the present invention, every mode of self-help (e.g., website, Speech Enabled IVR, Virtual Agent App, etc.) involves user authentication. Therefore, a CUSTOMER ID, or any other indicia for identifying the customer, is associated with each of these interactions. In these embodiments, when the user invokes a pre-call option in his conversation assistance client application 11, the client application communicates with the conversation assistance servers 110, which analyze the user's last interactions as identified by CUSTOMER ID. If those interactions include interactions with the self-help system and if the issue was unresolved, the conversation assistance servers 110 communicate with the client application 11 to display as a potential call reason, the customer question/problem that was unresolved in the user's recent self-help session.
In still other embodiments of the present invention, interactions with enterprises over a variety of other channels (e.g., web, email, chat, phone, customer service mobile applications, retail shops, and social media channels) are also analyzed to identify the issue that may need to be resolved. One example, of such a product for analyzing data from a wide range of different channels is Genesys® Text Analytics.
For example, if a customer extensively visits web pages that relate to “flying with pets policy” and then used the client application 11 to engage in a call with a contact center 80, the conversation assistance server 110 may infer that the user is interested in speaking with an agent regarding airline policies on traveling with animals and identify that topic as a possible call reason.
In addition, in some embodiments, if a user would like to initiate a call from a specific web page by activating a “click to call” button and the user has a conversation assistance client application 11 installed, then the conversation assistance client application may open in the same window or a new browser window, the current web page (e.g., its URL) may be suggested as a call reason or shared with the agent, and the user may mark portions of the currently open web page to be shared with the agent (e.g., highlighting particular paragraphs) or they can initiate a co-browsing session with WebRTC or similar communication technologies, see for instance Genesys® WebRTC system. For example, in one embodiment in which the end user device 10 runs the Android® operating system, the Android “share intent” can be used to share particular web pages with a conversation assistance client application 11 running on end user device 10, thereby automatically sharing the current link with the client application 11.
According to one embodiment, the client application 11 also provides an option for the case where none of the inferred call reasons corresponds to the user's actual reason for calling. Upon selecting this option, the client application 11 displays a list of all available call reasons as either a flat list or in a hierarchical fashion. According to one embodiment, the user indicates his selection of a call reason, either by the user interacting with the client application 11 by pointing and clicking, or by speaking in natural voice to the client application 11.
As shown in the embodiment of
According to one embodiment of the present invention, the conversation assistance servers 110 provide a number of functions to a user via the client applications 11 during a call, allowing the end user to be in control of the conversation as the call is taking place. These functions may include, without limitation, contextual help through the sharing of content from agents at the contact center, the upload of data from the user to the agent at the contact center, requests to be transferred to other agents, requests for assistance from a supervisor, and reporting complaints.
Embodiments of the present invention allow a user to receive, via the client application 11, relevant contextual content during a conversation with an agent of the contact center.
Systems and methods for sharing content between agents and users are described in, for example, U.S. patent application Ser. No. 13/669,288, “Out-of-band communication system for contact centers,” filed in the U.S. Patent and Trademark Office on Nov. 5, 2012, the entire disclosure of which is incorporated herein by reference.
For example, when discussing a malfunctioning router, the transcription output of the real-time speech analytics system 13 may detect when the user says the model number of the router and categorize the conversation as being related to a particular model. The conversation assistance server 110 may then detect the categorization of the conversation as being related to that router and automatically push product information to the client application 11, where the product information may include, for example, specifications about the router, troubleshooting guides, and software/firmware updates related to that particular router. In some embodiments, the pushed data may include a uniform resource locator (URL) identifying a web page or other resource (e.g., a file on an FTP site), text (such as web page including HTML), or may be binary data (such as images, audio, and video).
In addition, users may use the client application 11 to upload data to the contact center 80 via the conversation assistance server 110. For example, rather than asking a user to read a long serial number from a malfunctioning device to the agent, an agent may ask a user to take a photo of the relevant sticker using the camera attached or integrated into the end user device on which the client application 11 is running. Other data that can be sent to the agent may include sending error logs, credit card information, photographs of receipts as proof of purchase. In some embodiments, WebRTC data communication technology is utilized for this functionality.
According to some embodiments of the present invention, the client application 11 includes a feature to request that the call be transferred from the current agent to another agent, to a supervisor, or to request a supervisor to join the call without requiring interaction from the current agent. In some embodiments of the present invention, the request is provided from the client application 11 to the conversation assistance servers 110, which sends an appropriate request to the call center (e.g., to a call routing server or other component of the call center for performing a call transfer or conferencing operation).
According to one embodiment, the current agent with whom the customer is communicating may be alerted of the fact that the customer has opted to transfer the call to another agent. For example, the conversation assistance server 110 may transmit a message to the agent device for display thereon.
According to one embodiment, the customer may also initiate a complaint, via the client application 11, during a current call.
In operation 1102, the complaint is received by the conversation assistance server 110 and forwarded to appropriate components of the contact center 80 in operation 1104. For example, the complaint may be forwarded to a database of call problems, an email inbox of a responsible person at the enterprise, or an agent workbin 26. According to one embodiment, the server 110 may be configured to receive the complaint, and process the complaint to generate an outbound communication based on rules associated with handling complaints. For example, the rules may prompt the server 110 to generate a task for an agent to review the complaint and take action in response to the complaint.
According to one embodiment of the present invention, the conversation assistance servers 110 provide a number of functions to a user via the client applications 11 after a call or between calls (e.g., not immediately before or after a given call). These features include requesting a call back, marking an issue or call as being unresolved, rating calls, adding and removing agents from the favorite agents list, listening to and commenting on recordings of calls, and searching recorded calls.
The call back request feature of the client application 11 provides an option that the user may select to request a supervisor, specialist, or other agent of the contact center to call back at a particular time or as soon as possible. According to one embodiment, the conversation assistance server 110 receives the request and generates a task that is delivered, for example, to the workbin 26 of an appropriate agent at the contact center 80.
According to one embodiment, the client application 11 provides an option that the user may select to mark previous calls (including the most recent call) as having unresolved issues. The marking of a call as unresolved may also include text, images, and other data supplied by the user that can be used, for example, to explain why the issue is still unresolved. In one embodiment, the received data and the flagging of the call as being unresolved are stored in a database connected to the conversation assistance server 110.
According to one embodiment, the client application 11 provides an option that the user may select to rate previous calls (including the most recent call). In some embodiments, the rating is a simple thumbs up/thumbs down or positive/negative rating. In other embodiments, the rating is a numerical rating (e.g., from 1 to 10). In still other embodiments the rating may be accompanied by a text description. The client application 11 may also provide a feature to share call ratings over social media (e.g., Facebook®, LinkedIn®, and Twitter®). In some embodiments of the present invention, the ratings of the agents are stored in the conversation assistance backend servers 110 and are made public to other users of the client application 11 on other end user devices 10, thereby allowing users to collaborate in identifying more helpful agents and for sharing tips on ways to obtain better service from the enterprises.
According to one embodiment, the client application 11 provides an option that the user may select to add and remove agents from a favorite agents list. For example, if a user had a positive experience with a particular agent and wanted to speak with that agent in the future, the user can utilize the client application 11 to add the agent who handled a previous interaction to the user's favorite agent list. As described above, when the client application 11 is invoked to initiate a conversation with the enterprise, the favorite agent list can be accessed and the user may be provided with the option to speak with one of their favorite agents. In addition, embodiments of the present invention also allow a user to remove agents from their favorite agent list. The favorite agent list may be stored either on the end user device 10 by the client application 11 or may be stored at the conversation assistance server 110.
According to one embodiment, the client application 11 provides an option that the user may select to play back recordings of prior calls with contact centers 80.
According to one embodiment, the client application 11 also provides records of prior calls and other interactions (including text chat transcriptions, emails, annotations and other notes regarding prior conversations) between the user and each of the connected contact centers 80. These interactions may be stored at the contact centers 80 and made available to the conversation assistance servers 110 using an application programming interface (API) or may be stored by the conversation assistance servers 110.
According to one embodiment, the client application 11 provides an option that the user may select to annotate the recordings of the prior calls at particular times (e.g., to note that an agent provided helpful instructions beginning at a particular time). In some embodiments, the playback material includes content that was pushed by the agent or by the user.
According to one embodiment, the client application 11 provides a function to view a “receipt” including the name of the agent, the time of the call, and other information (e.g., a transaction number, a ticket number, a price quote, etc.) The receipt may include clickable links for additional information such as package tracking information, support ticket status information, or may link to various portions of the website of the enterprise.
Embodiments of the present invention may also provide the ability to search previously recorded calls. These searches may be performed between calls (e.g., not immediately before or after a given call) and may involve operations that are not specific to any particular call. Various call centers may include speech analytics technology (e.g., the ability to perform automatic speech recognition (ASR) on the call between the user and the agent and to analyze the resulting data) to provide further insight into the activities of the contact center. The transcriptions of the calls may be indexed by a search engine.
In some embodiments, the search can also be performed to search all accessible interactions with various enterprises, including text chat transcriptions, emails, annotations and other notes regarding prior conversations. These interactions may be stored at the contact centers 80 and made available to the conversation assistance servers 110 using an application programming interface (API) or may be stored by the conversation assistance servers 110.
In still other embodiments the conversation assistance servers 110 include memory (e.g., dynamic memory or a persistent memory such as flash media and spinning hard disks) to store (e.g., cache) data for faster retrieval. For example, when searching for a keyword in all the previous calls the conversation assistance servers 110 may store an inverted index database mapping keywords to particular calls and call center names to avoid searching every call.
According to one embodiment, in addition or in lieu of organizations being in control of conversations and other interactions with organizations, enterprises, and vendors, the customers are also in control of data exchanged between the customer and different vendors, such as, for example, the same customer interacting with different companies. A customer management of the data associated with various organizations (or “vendors”) will be referred to herein as “vendor relationship management” or “VRM.”
According to one embodiment, the VRM module 1804 is configured to perform various functions in receiving and storing data supplied from client applications 1806 and from contact centers 80, and supplying the data to client applications 1806 and contact centers 80. During various interactions between the user and the contact centers 80, additional data may be generated and associated with the interactions. This additional data may include, for example, conversation transcripts, notes made by the user and/or an agent, test results, error reports, order histories, order tracking information, etc. and the additional data may be stored by the VRM module 1804. The additional data may also be shared between contact centers (e.g., of organizations, enterprises, and vendors) 80.
The data may be supplied to contact centers 80 and to client applications 1806 according to various rules as defined in “templates” that may be stored by the VRM module. As such, embodiments of the present invention can be used to “orchestrate” interactions and the flow of information between different vendors or enterprises providing services to a particular customer. This can be especially beneficial in situations where the services provided by the various enterprises complement one another or depend on one another.
In one embodiment of the present invention, a user may set up a client device 10 for use with the VRM system by installing an application 1806a (e.g., a mobile application) on a mobile device 10a accessing a web page (or web application) 1806b using a computer 10b. The client application 1806 may then request the user to enter some profile information, such as a name, address, phone number, and other identifying information.
According to one embodiment, the client applications 1806 may be similar to the client applications 11 of the above embodiments, except that the client applications 1806 of the present embodiment are enhanced with functionality to allow customers to manage relationships and data shared to and from the different contact centers. In this regard, the client applications 1806 provide a unified user interface for controlling the data that is shared with various vendors or enterprises.
According to one embodiment, when a user initiates a call or other interaction with a contact center using the client application 1806 by selecting an accessible enterprise from a list of connected enterprises, profile information that has been marked as accessible by that enterprise is be automatically shared with the enterprise when the call is initiated, thereby simplifying the process of user authentication and reducing difficulties in communicating information between the user and an agent.
Furthermore, according to one embodiment of the present invention, storing profile information using the VRM system allows a user to update his or her information once (using the VRM system) and to have the updated information automatically propagated to all enterprises that are accessible by the VRM system. For example, after a user moves to a new home, the user may wish to update his or her mailing address with each enterprise that he or she deals with. In the past, updating the address generally would require contacting each enterprise to supply the enterprise with the new address. In contrast, according to one embodiment of the present invention, updating the address from within the client application 1806 causes the new address to be pushed to connected vendors that have access to the address fields of the user's profile.
According to one embodiment of the present invention, during initiation of the call, the client application 1806 may further provide an intelligent customer front door system that provides suggestions on how to route the call based on call reasons suggested by the user via the client application 1806. For example, the client application 1806 may provide a virtual assistant (implemented either locally on the end user device 10 or on a server 1802). The user may supply a call reason such as “I want to change my PIN” to the virtual assistant and the virtual assistant may then suggest a particular customer service department to handle such a request and assist in routing the call appropriately, thereby allowing the user to bypass at least some aspects of an IVR system. According to embodiment, this may be implemented in a manner substantially similar to that described above with respect to
According to one embodiment of the present invention, the VRM module 1804 assists in orchestrating complex tasks across multiple parties and vendors. For example, embodiments of the present invention may provide predefined templates for assisting a user in making travel arrangements, troubleshooting consumer products, and planning complex events (e.g., Valentine's Day celebrations).
For example, when making travel arrangements, a user may need to contact an airline company to book flight, a hotel to reserve a room, and a car rental company for transportation. The user may also want to make reservations at a local restaurant and purchase tickets to visit local attractions. This process generally requires contacting several different entities and manually communicating information to them. For example, after booking a flight, a user will generally also need to supply the flight information to the car rental company in order to identify which location the user would like to rent a car from and to provide vehicle pick-up and return times. In contrast, according to one embodiment of the present invention, information generated during the flight booking process (e.g., information about an issued ticket) can be automatically supplied to other enterprises (if the user chose to allow the other enterprises to have access to this information). For example, if the rental car company received the updated flight information through a VRM system according to embodiments of the present invention, it could automatically populate start and end times for the rental period. As another example, searches for restaurant reservations and tickets for events can be restricted to times between arrival and departure times of the flights.
Embodiments of the present invention may further perform sub-tasks to be plugged into the analysis of the scenarios. For example, the VRM system may automatically check to see if the user has friends who will be at the destination and try to arrange meetings, check to see if there are local franchises of a favorite restaurant chain in order to make reservations at these restaurants, and may check for sports events, concerts, or stage performances that will occur during the user's stay.
In some embodiments of the present invention, the users may use the client application 11 to upload data associated with prior calls with first agents of a first contact center to second agents of a second contact center of another enterprise. For example, a user having a problem with his smartphone first contacts the manufacturer of the phone to report a problem. The user may upload photographs, error logs, and other information stored on the phone to the contact center of the manufacturer. The interactions between the agent of the manufacturer and the user can be recorded and transcribed, and the transcripts may also be stored along with analysis by the agent. The package of information associated with the call may be stored at the conversation assistance servers 110 and/or at the end user device 10. During the call, the agent of the manufacturer may determine that the problem is not with the phone itself, but rather a configuration problem with the cellular carrier and, as such, may recommend contacting the carrier instead. As such, according to embodiments of the present invention, the user can upload the package of data associated with the first call (between the user and the manufacturer) to the agent of the cellular carrier, thereby simplifying the process of communicating the problem to the second agent (e.g., the carrier).
As another example, embodiments of the present invention may provide orchestration for tasks such as planning a complex event such as Valentine's Day celebrations, such as ordering flower delivery, booking transportation for the evening, making restaurant reservations, etc.
As described above, before, during, and after the interactions with the various enterprises, data is generated regarding the interactions and the plans that are made. According to one embodiment of the present invention, records regarding these interactions such as interaction history, personal notes, personal records, order history, etc. are stored and may be shared with other enterprises. The information may be shared using a standardized or uniform application programming interface (API) and protocol for cross-vendor transactions, such as the JSR 91 Trouble Ticket API.
According to one embodiment of the present invention, status changes at one enterprise can automatically generate notifications to other enterprises in related cases. Returning to the above example regarding travel arrangements, if, for example, a flight is delayed, then notifications may be automatically sent to the other enterprises that are involved in the related travel arrangements. As such, the car rental company may receive the notification of the delay and automatically adjust the car pick-up time, and the restaurant may receive the notification and automatically reserve a table at a later time, if available.
Embodiments of the present invention may be implemented either as a cloud based service or may be implemented on an end user device 10. For example, the various operations described above can be performed by a server 1802 that includes a VRM module 1804, or they can be performed by an application 1806 running on an end user device 10.
According to one embodiment of the present invention, the rules for conveying information from the user to vendors and between different vendors (including the propagation of information due to changes in conditions) can be defined by templates available to the user. The templates can be implemented using any of a variety of computer languages, such as State Chart eXtensible Markup Language (SCXML), JavaScript, Lisp, Python, Ruby, etc.
In some embodiments of the present invention, a user can create and customize templates using a template editor. In addition, in some embodiments, users can share templates with other users.
According to one embodiment of the present invention, a process for using a VRM system takes place on both an end user device and a server 1802. Initially, a user may trigger a new operation using the client application 1806 on the end user device 10. The triggering of the new operation triggers a new task in the server's orchestration service (e.g., the VRM module 1804). Based on the task triggered, a particular template is loaded, where the template includes operating rules (e.g., an SCXML script). The end user device 10 stores personal data and makes the data available to the server 1802 as needed. The VRM module 1804 may also consult the data collected from prior interactions, and supply relevant portions of the data from the prior interactions to various connected enterprises, in accordance with the operating rules. The VRM module 1804 may also load related sub-tasks (as described above) as specified by the operating rules.
However, embodiments of the present invention are not limited thereto. The various operations described above may be executed either entirely by the end user device 10, entirely by the server 1802, or various combinations thereof. For example, in some embodiments, the template is stored on and can be executed by the end user device 10 and the data generated during the interactions is stored on the end user device 10. As such, the end user device 10 can directly manage and supply data to various enterprises without assistance from a server 1802. As another example, in other embodiments of the present invention, the end user device 10 stores the generated data locally, but sends the data to various contact centers 80 via server 1802.
According to one embodiment of the present invention, a process for executing a template proceeds as follows: data associated with an interaction is received; a template associated with the data is identified; the various rules of the template are tested against the received data; matching rules of the template are executed, where the execution of a rule includes identifying at least one other enterprise that at least a portion of the received data is to be sent to; and sending the portion of the received data to the other enterprise.
In various embodiments of the present invention, a hybrid “automated” and “manual” sharing of data may be implemented. For example, instead of automatically sharing data between the user and enterprises and from one enterprise to another, the client application 1806 may show the user all of the data that will be shared prior to sharing the data, and the client application 1806 may allow the user to further refine which data is seen by the enterprise.
In some embodiments of the present invention, the client application 1806 also aggregates and provides access to data generated by devices owned or operated by the user. For example, an Internet-connected smoke detector may automatically generate notifications when smoke is detected. As another example, an Internet-connected washing machine may automatically generate notifications if it is running low on detergent and an Internet-connected refrigerator may generate notifications when its compressor is malfunctioning or when internal temperatures exceed a threshold level. According to some embodiments of the present invention, the data generated by the various devices can be aggregated by, for example, the client application 1806 running on the end user device 10 or by the VRM module 1804 on the server 1802, thereby providing a user with an aggregated view of the data generated by his or her appliances. Furthermore, data generated by the various devices and collected by a VRM system according to embodiments of the present invention can also be provided to agents at contact centers 80. For example, smoke detector information can be automatically provided to emergency services (e.g., 9-1-1 services), and appliance malfunction data can be automatically provided to agents when placing calls to request service.
In some embodiments of the present invention, access to the data generated by the devices can be controlled by the user in a manner similar to the control of individual fields of data of a user profile. In addition, in some embodiments of the present invention, the user is provided with notifications when data is to be communicated between a device and a vendor, where the notification provides the user with the ability to control whether or not the data is transmitted to the vendor and may include information about the way in which the information will be used by the vendor.
In some embodiments of the present invention, some or all of the functionality described above as being provided by the VRM module 1804 is provided by the client applications 1806 and performed by the end user devices 10.
According to some embodiments of the present invention, the conversation assistance servers 110 can also participate in orchestrating and/or federating information among various enterprises in order to allow communication of alerts and other data between different enterprises. For example, in one embodiment of the present invention, information from one enterprise (e.g., an airline) can automatically be transmitted to another enterprise (e.g., a car rental company) to assist in performing tasks (e.g., the car rental company can be provided with a flight number and arrival time, thereby simplifying the process of determining when the car will be rented and later returned).
Furthermore, information can automatically be generated to update other enterprises when conditions change at a first enterprise. For example, in one embodiment of the present invention, if a flight is delayed, then an alert can be automatically sent to the car rental company indicate that the reservation time should be moved back to a later time.
Although embodiments of the present invention are described above with respect to communications with contact centers, other aspects of communications with enterprises that may be conducted through or using VRM systems may also benefit from information exchange. For example, data can be generated during self-serve interactions (e.g., purchasing products or services via a website or interactions with a virtual agent) and this data can be supplied to self-serve interactions with other vendors.
Although embodiments of the present invention are described above with respect to interactions between individuals (or “users”) and one or more organizations (e.g., “vendors” or “enterprises”), embodiments of the present invention are not limited thereto. According to one embodiment of the present invention, data related to interactions with the “sharing economy” or “collaborative economy” or “peer-to-peer economy” in which individuals conduct transactions with one another using shared platforms are also captured by a VRM system. For example, when a user books a room in an individual's home through a collaborative economy room rental service (e.g., Craigslist® or Airbnb®), information is exchanged with the individual rather than with an agent at a contact center. As another example, when renting cars or receiving rides from individuals rather than organizations (e.g., using Getaround® and Lyft®), data is exchanged with the owners of the cars rather than agents at a contact center. However, the data exchanged with these individuals may similarly be captured and exchanged via a VRM system, e.g., a server 1802 and a VRM module 1806 or an end user device 10.
Each of the various servers in the contact center 80, the conversation assistance server 110, and the server 1802 may be a process or thread, running on one or more processors, in one or more computing devices 500 (e.g.,
Each of the various servers, controllers, switches, and/or gateways in the afore-described figures may be a process or thread, running on one or more processors, in one or more computing devices 1500 (e.g.,
The central processing unit 1521 is any logic circuitry that responds to and processes instructions fetched from the main memory unit 1522. It may be implemented, for example, in an integrated circuit, in the form of a microprocessor, microcontroller, or graphics processing unit (GPU), or in a field-programmable gate array (FPGA) or application-specific integrated circuit (ASIC). The main memory unit 1522 may be one or more memory chips capable of storing data and allowing any storage location to be directly accessed by the central processing unit 1521. As shown in
A wide variety of I/O devices 1530 may be present in the computing device 1500. Input devices include one or more keyboards 1530a, mice, trackpads, trackballs, microphones, and drawing tablets. Output devices include video display devices 1530c, speakers, and printers. An I/O controller 1523, as shown in
Referring again to
The removable media interface 1516 may for example be used for installing software and programs. The computing device 1500 may further comprise a storage device 1528, such as one or more hard disk drives or hard disk drive arrays, for storing an operating system and other related software, and for storing application software programs. Optionally, a removable media interface 1516 may also be used as the storage device. For example, the operating system and the software may be run from a bootable medium, for example, a bootable CD.
In some embodiments, the computing device 1500 may comprise or be connected to multiple display devices 1530c, which each may be of the same or different type and/or form. As such, any of the I/O devices 1530 and/or the I/O controller 1523 may comprise any type and/or form of suitable hardware, software, or combination of hardware and software to support, enable or provide for the connection to, and use of, multiple display devices 1530c by the computing device 1500. For example, the computing device 1500 may include any type and/or form of video adapter, video card, driver, and/or library to interface, communicate, connect or otherwise use the display devices 1530c. In one embodiment, a video adapter may comprise multiple connectors to interface to multiple display devices 1530c. In other embodiments, the computing device 1500 may include multiple video adapters, with each video adapter connected to one or more of the display devices 1530c. In some embodiments, any portion of the operating system of the computing device 1500 may be configured for using multiple display devices 1530c. In other embodiments, one or more of the display devices 1530c may be provided by one or more other computing devices, connected, for example, to the computing device 1500 via a network. These embodiments may include any type of software designed and constructed to use the display device of another computing device as a second display device 1530c for the computing device 1500. One of ordinary skill in the art will recognize and appreciate the various ways and embodiments that a computing device 1500 may be configured to have multiple display devices 1530c.
A computing device 1500 of the sort depicted in
The computing device 1500 may be any workstation, desktop computer, laptop or notebook computer, server machine, handheld computer, mobile telephone or other portable telecommunication device, media playing device, gaming system, mobile computing device, or any other type and/or form of computing, telecommunications or media device that is capable of communication and that has sufficient processor power and memory capacity to perform the operations described herein. In some embodiments, the computing device 1500 may have different processors, operating systems, and input devices consistent with the device.
In other embodiments the computing device 1500 is a mobile device, such as a Java-enabled cellular telephone or personal digital assistant (PDA), a smart phone, a digital audio player, or a portable media player. In some embodiments, the computing device 1500 comprises a combination of devices, such as a mobile phone combined with a digital audio player or portable media player.
As shown in
In some embodiments, a central processing unit 1521 provides single instruction, multiple data (SIMD) functionality, e.g., execution of a single instruction simultaneously on multiple pieces of data. In other embodiments, several processors in the central processing unit 1521 may provide functionality for execution of multiple instructions simultaneously on multiple pieces of data (MIMD). In still other embodiments, the central processing unit 1521 may use any combination of SIMD and MIMD cores in a single device.
A computing device may be one of a plurality of machines connected by a network, or it may comprise a plurality of machines so connected.
The computing device 1500 may include a network interface 1518 to interface to the network 1504 through a variety of connections including, but not limited to, standard telephone lines, local-area network (LAN), or wide area network (WAN) links, broadband connections, wireless connections, or a combination of any or all of the above. Connections may be established using a variety of communication protocols. In one embodiment, the computing device 1500 communicates with other computing devices 1500 via any type and/or form of gateway or tunneling protocol such as Secure Socket Layer (SSL) or Transport Layer Security (TLS). The network interface 1518 may comprise a built-in network adapter, such as a network interface card, suitable for interfacing the computing device 1500 to any type of network capable of communication and performing the operations described herein. An I/O device 1530 may be a bridge between the system bus 1550 and an external communication bus.
While the present invention has been described in connection with certain exemplary embodiments, it is to be understood that the invention is not limited to the disclosed embodiments, but, on the contrary, is intended to cover various modifications and equivalent arrangements included within the spirit and scope of the appended claims, and equivalents thereof.