In many applications, it may be needed for a person to review a previous conversation between two or more users. For example, a person could review a text transcript of a conversation to understand the subject matter of the conversation. Reviewing an entire conversation may take significant time since a conversation between users may be long in duration, may repeat information, and may include details that are not relevant to the main purpose of the conversation.
Accordingly, it may be desired to create a summary of a conversation between two or more users to allow a person to quickly understand the subject matter of the conversation without reviewing the entire conversation. An effective conversation summary may concisely represent the important topics and details of the conversation.
In some aspects, the techniques described herein relate to a computer-implemented method, including: receiving conversation information, wherein: the conversation information includes a sequence of conversation turns, the sequence of conversation turns includes a first conversation turn and a second conversation turn, the first conversation turn corresponds to first text, and the second conversation turn corresponds second text; computing label scores by processing the sequence of conversation turns with one or more neural networks, wherein computing the label scores includes: computing, for the first conversation turn, first label scores for a first label and second label scores for a second label, and computing, for the second conversation turn, third label scores for the first label and fourth label scores for the second label; computing tag scores for tags by processing the label scores, wherein computing the tag scores includes: computing, for the first conversation turn, a first tag score for a first tag using the first label scores and the second label scores, and computing, for the second conversation turn, a second tag score for a second tag using the third label scores and the fourth label scores; selecting a subset of the tags using the tag scores, wherein selecting the subset of the tags includes selecting the first tag using the first tag score and not selecting the second tag using the second tag score; obtaining a first text representation of the first tag; and generating a conversation summary using the first text representation of the first tag.
In some aspects, the techniques described herein relate to a computer-implemented method, wherein the first text of the first conversation turn was obtained by performing speech recognition of audio.
In some aspects, the techniques described herein relate to a computer-implemented method, wherein computing the first label scores includes processing the first text with a convolutional neural network.
In some aspects, the techniques described herein relate to a computer-implemented method, wherein computing the first tag score includes processing a first label score of the first label scores and a second label score of the second label scores.
In some aspects, the techniques described herein relate to a computer-implemented method, wherein computing the first tag scores includes multiplying a first label score of the first label scores and a second label score of the second label scores.
In some aspects, the techniques described herein relate to a computer-implemented method, wherein selecting the subset of the tags includes determining a similarity between the first tag and the second tag.
In some aspects, the techniques described herein relate to a computer-implemented method, wherein: selecting the subset of the tags includes selecting a third tag of a third conversation turn; the computer-implemented method includes obtaining a third text representation of the third tag; and generating the conversation summary includes concatenating the first text representation of the first tag with the third text representation of a third tag.
In some aspects, the techniques described herein relate to a computer-implemented method, wherein: the first conversation turn corresponds to a first timestamp; the third conversation turn corresponds to a third timestamp; and generating the conversation summary includes ordering the first text representation and the third text representation using the first timestamp and the third timestamp.
In some aspects, the techniques described herein relate to a system, including: at least one server computer including at least one processor and at least one memory, the at least one server computer configured to: receive conversation information, wherein: the conversation information includes a sequence of conversation turns, the sequence of conversation turns includes a first conversation turn and a second conversation turn, the first conversation turn corresponds to first text, and the second conversation turn corresponds second text; compute label scores by processing the sequence of conversation turns with one or more neural networks, wherein computing the label scores includes: computing, for the first conversation turn, first label scores for a first label and second label scores for a second label, and computing, for the second conversation turn, third label scores for the first label and fourth label scores for the second label; compute tag scores for tags by processing the label scores, wherein computing the tag scores includes: computing, for the first conversation turn, a first tag score for a first tag using the first label scores and the second label scores, and computing, for the second conversation turn, a second tag score for a second tag using the third label scores and the fourth label scores; select a subset of the tags using the tag scores, wherein selecting the subset of the tags includes selecting the first tag using the first tag score and not selecting the second tag using the second tag score; obtain a first text representation of the first tag; and generate a conversation summary using the first text representation of the first tag.
In some aspects, the techniques described herein relate to a system, wherein: the first conversation turn corresponds to a first user identifier; the second conversation turn corresponds to a second user identifier; and obtaining the first text representation of the first tag includes using the first user identifier.
In some aspects, the techniques described herein relate to a system, wherein the first user identifier corresponds to a customer and the second user identifier corresponds to an agent.
In some aspects, the techniques described herein relate to a system, wherein obtaining the first text representation of the first tag includes retrieving the first text representation of the first tag from a data store.
In some aspects, the techniques described herein relate to a system, including presenting the conversation summary to a user.
In some aspects, the techniques described herein relate to a system, including receiving an input from the user to modify the conversation summary.
In some aspects, the techniques described herein relate to a system, including storing the conversation summary in a data store, wherein the data store is indexed using the first label.
In some aspects, the techniques described herein relate to a system, wherein computing the first label scores includes processing the first text with a classifier.
In some aspects, the techniques described herein relate to one or more non-transitory, computer-readable media including computer-executable instructions that, when executed, cause at least one processor to perform actions including: receiving conversation information, wherein: the conversation information includes a sequence of conversation turns, the sequence of conversation turns includes a first conversation turn and a second conversation turn, the first conversation turn corresponds to first text, and the second conversation turn corresponds second text; computing label scores by processing the sequence of conversation turns with one or more neural networks, wherein computing the label scores includes: computing, for the first conversation turn, first label scores for a first label and second label scores for a second label, and computing, for the second conversation turn, third label scores for the first label and fourth label scores for the second label; computing tag scores for tags by processing the label scores, wherein computing the tag scores includes: computing, for the first conversation turn, a first tag score for a first tag using the first label scores and the second label scores, and computing, for the second conversation turn, a second tag score for a second tag using the third label scores and the fourth label scores; selecting a subset of the tags using the tag scores, wherein selecting the subset of the tags includes selecting the first tag using the first tag score and not selecting the second tag using the second tag score; obtaining a first text representation of the first tag; and generating a conversation summary using the first text representation of the first tag.
In some aspects, the techniques described herein relate to one or more non-transitory, computer-readable media, wherein the first label corresponds to dialog acts and the second label corresponds to topics.
In some aspects, the techniques described herein relate to one or more non-transitory, computer-readable media, wherein selecting the subset of the tags includes selecting tags above a threshold.
In some aspects, the techniques described herein relate to one or more non-transitory, computer-readable media, wherein selecting the subset of the tags includes determining a similarity between the first tag and the second tag.
The invention and the following detailed description of certain embodiments thereof may be understood by reference to the following figures:
Users may engage in conversations for a variety of purposes and through a variety of channels. For example, conversations may use text messages or may be conducted over audio and/or video. The techniques described herein may be used for any type of conversation and any channel or medium for conducting conversations (e.g., in person, phone, video, email, SMS, etc.).
In some instances, it may be desired to generate a text summary of a conversation. For example, a transcript of a conversation (e.g., obtained from text messages or via speech recognition of an audio conversation) may be processed to generate a text representation of the conversation that allows a person to easily understand the important topics or other aspects of the conversation.
To improve the quality of a conversation summary, the summary may include all important details of the conversation, avoid repetition, and omit details that are not relevant to the main purpose of the conversation. Existing tools for generating conversation summaries may not provide conversation summaries of sufficient quality for some applications.
In some implementations, a conversation summary may be generated using a label space and/or tags. Text of the conversation may be automatically processed to assign one more or labels to the text. Any appropriate labels may be used. For example, a label may correspond to selecting a dialog act of the text from a set of possible dialog acts. For another example, a label may correspond to selecting a topic of the text from a set of possible topics. The labels may be combined to generate tags that describe the text. The most relevant tags may be identified and processed to generate a text summary of the conversation.
The generation of high-quality conversation summaries may provide business value to companies. Considerable time and cost is required for an employee to review a conversation transcript. An employee may review a conversation summary much more quickly and thus save considerable time. An employee may also obtain a better understanding of a conversation since speed reading a conversation transcript may result in missing or misunderstanding important aspects of the conversation. A better understanding of the conversation may allow the employee to provide better services or make better business decisions based on the understanding of the conversation. Accordingly, a business may decrease costs and also improve the quality of their services through using high quality conversation summaries.
In some instances, it may be desired to facilitate the search and retrieval of conversations and/or conversation summaries according to various aspects of conversations. Conversations and/or summaries may be associated with one or more labels and/or tags corresponding to important aspects of the conversation (e.g., an act or topic of the conversation). For example, conversations and/or summaries may be stored in a database that is indexed according to various conversation labels and/or tags to allow retrieval of conversations and/or summaries according to specified labels and/or tags.
The indexing of conversations and/or conversation summaries may provide business value to companies. Indexing of conversations allows for a better understanding of the substance of conversations and how they relate to the business of the company. For example, the indexing of customer service conversations may help businesses better understand customer complaints and the products or services that are most valued by customers. Businesses may use this information to improve their products and services and increase their profitability.
According to one aspect, the techniques described herein provide improved performance for computing summaries and conversation transcripts within a computer environment. The techniques described herein include improved conversation labeling and processing techniques that preserve conversation structure and capture more aspects of conversation nuances than traditional summarization techniques. Elements of a conversation are labeled and tagged according to two or more configurable categories which provide for capturing aspects of a conversation from multiple dimensions. Categories, labels, and label scoring may be adjusted to allow fast and efficient configuration for different applications, locations, industries, languages, dialects, and the like.
In another aspect, the techniques described herein provide an improvement in adaptability to the performance characteristics of different computing environments. In some implementations, computation of labels and tags for different turns of conversations enables a configurable granularity and complexity of computations. In one configuration, computation of labels and/or tags may involve models that may be confined to the text of one conversation turn and may be suitable for a computing environment with lower memory or computations capabilities. In another configuration, computation of labels may involve models that process text of two or more conversation turns and may be suitable for computing environments with higher memory or computations capabilities.
In another aspect, the techniques described herein provide an improvement to the accuracy and performance of indexing of conversations. In some implementations, turns of a conversation may be indexed using assigned labels. The assigned labels provide for consistent identification of properties and characteristics of the conversations. The techniques provide for the use of consistent labels with a well-defined meaning even if the text of the associated conversations may be of different languages, dialects, types, and the like. Likewise, labels may be shorter than the conversations they are associated with therefore requiring less computer resources for indexing and search than the original conversation.
Company 130 may provide services relating to the conversation. For example, company 130 may provide a communications service 150 to facilitate the conversation between user 111 and user 121. For example, communications service 150 may relate to facilitating phone calls or text messaging between user 111 and user 121. Communications service 150 may store text of the communications in conversation data store 160. Any appropriate information may be stored in conversation data store 160, such as text of text messages or transcriptions of speech.
Company 130 may also provide a summarization service 170 to facilitate the summarization of conversations. Summarization service 170 may access the text of conversations in conversation data store 160 and process the text to generate a conversation summary. The conversation summary may be stored in summary data store 180. The conversation summary may be accessed by other users or may be indexed to facilitate search and retrieval.
At step 210, conversation information is obtained. Any appropriate conversation information may be obtained using any appropriate techniques. For example, the conversation information may correspond to text messages or may correspond to transcribed speech. The conversation information may be represented as a sequence of conversation turns, where each conversation turn corresponds to a communication of a user. The conversation turns may include other information, such as a type of user (e.g., customer or customer service representative), an identity of a user (e.g., a numerical ID or a name), or a timestamp of the communication.
As used herein, a conversation turn corresponds to any utterance of a user. A conversation turn may correspond to any quantity of text or speech, such as a word, phrase, part of a sentence, complete sentence, or multiple sentences. The conversation turns may generally alternate between users, but conversation turns of users may overlap in time, and a single user may provide more than one conversation turn before the other user provides a conversation turn.
At step 220, a conversation summary is generated using any of the techniques described herein. For example, conversation turns may be processed to determine labels and/or tags. The labels and/or tags may then be used to generate a text summary of the conversation. In some implementations, the summary may be stored and/or indexed for later use, or the conversation summary may be presented to a user for approval and/or possible modification.
At step 230, the conversation summary may be presented to a user. For example, the summary may be presented to one of the users in the conversation or to another user. This step is optional and may be omitted.
At step 240, approval may be received from the user or the user may modify the summary. For example, the user may edit the text of the conversation summary or modify labels and/or tags corresponding to the conversation summary. This step is optional and may be omitted.
At step 250, the conversation summary may be stored in a data store. The conversation summary may be stored in the same data store used to store the text of the conversation or in a different data store. In some implementations, the summary may be indexed according to labels and/or tags of the conversation summary to facilitate search and retrieval of the summary and/or the corresponding conversation.
The conversation turns may be processed to determine one or more labels of a label space to apply to the conversation turns. Any appropriate label space may be used. A label space may include one or more labels, and each label in the label space may have one or more values (including an optional value of “none” indicating that no value of a label applies). In some implementations, a label space may include labels for one or more of an intent, a dialogue act, a topic, a status, or a modifier of a status. A label and its values may correspond to any aspects of a conversation that facilitate processing of a conversation, such as summarizing a conversation or indexing a conversation.
An intent (or natural language intent) may correspond to what a user is attempting to accomplish within a conversation, and the possible intents may correspond to the purpose or type of conversation. For example, for customer support conversations, the possible intents may correspond to the products and services and other operations of the company, such as intents corresponding to the following: pay bill, change address, cancel service, add service, etc.
A dialogue act may correspond to classification of the act being performed by the person in providing a communication, such as a function of the communication. In some implementations, the label space may any of the following dialogue acts:
A topic may correspond to a subject of a communication or an object being discussed in a communication, and the possible topcis may correspond to the purpose or type of conversation. For example, for a customer support conversations for an airline, the possible topics may correspond to the following: arrival city, departure city, airport, etc.
A status may be a value corresponding to a topic, and the possible values may correspond to the purpose or type of conversation. For example, for a customer support conversations for an airline, the values for arrival city and departure city may correspond to the cities served by the airline. In some implementations, the possible values may be defined ahead of time. In some implementations, the possible values may be open ended and the values may be obtained from the text. For example, the topic may be a phone number, a person may include their phone number in a communication, and the value of the phone number may be extracted from the communication (e.g., using named entity recognition or regular expressions).
A modifier of a status may provide additional information relating to the status. Any appropriate modifiers may be used, such as the following modifiers:
In some implementations, a label score may be computed for each possible value of a label. For example, for the dialogue acts label, where there are 14 possible values of the label, 14 dialogue acts label scores may be computed for each conversation turn. For clarity of presentation,
For example, for the first conversation turn of
Any appropriate techniques may be used to determine label scores for the conversation turns. In some implementations, a classifier may be used to process a conversation turn and compute label scores (e.g., probabilities or likelihoods) for different values of a label. For example, where a label has 5 possible values, the classifier may output a probability for each label value that the label value corresponds to the conversation turn (and possibly a sixth value indicating that none of the label values correspond to the conversation turn). A different classifier may be used for each value or joint classifiers may be used to compute joint probabilities for combinations of some or all labels. Techniques for determining label values and label scores are described in greater detail below.
In some implementations, the storing and indexing of a conversation may include storing and/or indexing of one or more tags, labels, and/or a summary of the text. In some cases of resource-constrained devices (such as memory or processor speed), storage and indexing may include only the tags and/or the labels. In some cases, storage and indexing may include tags, labels, and the summary of the text. In some cases, storage and indexing may include storage and indexing of just the summary text.
In
A single classifier may compute label scores (e.g., probabilities or likelihoods) for the possible values of the label (and possible an additional score for no label). For example, for a first label with possible values of A1, A2, and A3, the single classifier for the first label may compute a label score for each of A1, A2, and A3. A joint classifier may compute label scores for all possible combinations of values. For example, for a second label with possible values of B1 and B2 and a third label with possible values of C1, C2, and C3, a joint classifier for the second and third labels may compute a label score for each of (B1, C1), (B1, C2), (B1, C3), (B2, C1), (B2, C2), and (B2, C3).
The classifiers may compute the label scores using any appropriate techniques. In some implementations, the text of the conversation turn may be processed to generate one or more convenient representations of the text, such as tokens, word pieces, or byte pairs. The text or a representation of it may then be processed to create embedding vectors or other mathematical representations of the text. In some implementations, the conversation turn (or a processed version of it) may be processed by a mathematical model to compute the label scores. For example, the mathematical model may be a neural network. Any appropriate mathematical model may be used, such as a convolutional neural network, a recurrent neural network, or a transformer neural network. In some implementations, techniques such as max pooling may be used to normalize the length of conversation turns before being processed by a mathematical model (e.g., a convolutional neural network).
In some implementations, the classifiers may process the conversation turns independently of other conversation turns. In some implementations, the classifiers may use information about other conversation turns when processing a conversation turn to better understand a conversation turn in the context of the conversation. For example, in some implementations, the classifiers may process the conversation turns sequentially and retain state information to use information learned from previous conversation turns when processing a current conversation turn. In some implementations, the classifiers may process a sliding window of all conversation turns or a sliding window of conversation turns for a user of the conversation.
Tag score computation component 1030 may receive the label scores and compute tag scores and/or select tags using tag scores. In some implementations, tag score computation component 1030 may receive all the label scores from the classifiers, and in some implementations, tag score computation component 1030 may receive only some of the label scores (e.g., label scores above a threshold).
Tag score computation component 1030 may compute tag scores using any appropriate techniques. In some implementations, tag score computation component 1030 may compute tag scores by determining all possible combinations of label scores from the classifiers. For example, where first classifier 1010 has 3 first label scores and second/third label joint classifier 1020 has 6 second/third label scores, tag score computation component 1030 may determine 18 possible combinations of the first label scores with the second/third label scores. More generally, the total number of combinations may correspond to the product of the number of label scores for each classifier.
A tag score for a tag may be computed from the label scores for the labels corresponding to the tag using any appropriate techniques, such as multiplying or adding the label scores. For example, for a tag (A3, B1, C2), the label scores corresponding to the tag are the label score for the label A3 computed by first classifier 1010 and the joint label score for the labels (B2, C2) computed by second/third label joint classifier 1020. In some implementations, the tag score for the tag (A3, B1, C2) may be computed as the product of the label score for label A3 and the joint label score for the labels (B1, C2).
In some implementations, tag score computation component 1030 may output tags and tag scores for all possible tags for the conversation turn (e.g., 18 possible tags for the example above). In some implementations, tag score computation component 1030 may output a subset of all possible tags for the conversation turn, such as outputting tags and tag scores for tags above a threshold. In some implementations, tag score computation component 1030 may output at most one tag and tag score for each conversation turn.
System 1000 of
In
Tag selection component 1110 may use any appropriate techniques to select the summary tags from the conversation tags. In some implementations, tag selection component 1110 may select a number of highest scoring tags, such as a number of tags with the highest scores or all tags with a score above a threshold. In some implementations, constraints may be imposed on the tag selection so that the selected tags are unique. For example, prior to tag selection, the highest scoring instance of each tag may be retained, and lower scoring instances of the same tag may be discarded.
In some implementations, constraints may be imposed on tag selection to prevent the selection of tags that have similar meanings to each other. For example, where the top scoring tag is (fix, computer, slow) and the second top scoring tag is (fix, computer, broken), the second top scoring tag may be discarded because its meaning is close to the meaning of the top scoring tag and doesn't provide significant additional information. Any appropriate techniques may be used to determine similarity of meaning between tags, such as semantic representations (e.g., word embeddings), decision trees, or heuristics.
In some implementations, more than one tag may be selected from a single conversation turn. In some implementations, tag selection may be constrained to select no more than one tag for each conversation turn. For example, where one conversation turn has the two highest scoring tags, one of the two highest scoring tags may be selected and the other may be discarded.
In some implementations, the output of tag selection component 1110 may be a list of tags. In some implementations, the tags may be grouped according to their conversation turns as illustrated in
Tag-to-text conversion component 1120 may process the summary tags selected by tag selection component 1110 and generate a text representation to use in the conversation summary.
In some implementations, the text representation may be generated in advance for each tag, and the pre-generated text representation may be selected for each of the tags. The text representation may be generated in advance using any appropriate techniques. For example, the text representation may be generated by a person or generated using a mathematical model, such as a neural network.
In some implementations, mathematical models may be used to generate text representations for the tags. For example, a mathematical model, such as a neural network, may process the tags and generate a text representation for each of the tags. Where two tags correspond to the same conversation turn, a single text representation may be generated for the conversation turn, such as illustrated in the second and fourth rows of
Summary generation component 1130 may process the text representations output by tag-to-text conversion component 1120 to generate a conversation summary to be presented to a user. Summary generation component 1130 may use any appropriate techniques such as concatenating the text representations or generating a bullet-point list for presentation to a user.
The conversation summary may then be presented to a user, and in some implementations, the user may be able to modify the conversation summary before it is finalized.
At step 1210, conversation information is received. Any appropriate conversation information may be received, such as text of a sequence of conversation turns. The conversation information may also include timing information (e.g., a timestamp or an index of a conversation in the sequence of conversation turns), information about users in the conversation (e.g., a user identifier, such as an identifier of an individual user or an identifier of a type of user). For example, the conversation turns may include a first conversation turn that corresponds to first text and a first user identifier and a second conversation turn that corresponds to second text and a second user identifier.
At step 1220, label scores are computed for the conversation turns. Label scores may be computed using any appropriate techniques, such as any of the techniques described herein. Any appropriate labels may be used, such as any of the labels described herein. For example, labels scores may be computed for a conversation turn by processing text of the conversation turn with a classifier. The label scores for a first conversation turn may include first label scores corresponding to a first label (e.g., dialogue acts) and second label scores corresponding to a second label (e.g., topic). The label scores for a second conversation turn may include third label scores corresponding to the first label (e.g., dialogue acts) and fourth label scores corresponding to a second label (e.g., topic).
At step 1230, tag scores are computed for tags of the conversation turns. Tag scores may be computed using any appropriate techniques, such as any of the techniques described herein. Any appropriate tags may be used, such as any of the tags described herein. For example, a tag may be determined by combining labels, and a tag score may be computed from the label scores corresponding to labels of the tag. In some implementations, a single tag score may be computed for a single tag of a conversation turn. In some implementations, multiple tag scores may be computed for multiple tags of a conversation turn. The tag scores for the first conversation turn may be computed using the first label scores and the second labels scores, and the tag scores for the second conversation turn may be computed using the third label scores and the fourth label scores.
At step 1240, a subset of tags is selected for generating a conversation summary. The subset of tags may be selected using any appropriate techniques, such as any of the techniques described herein. For example, a number of highest scoring tags may be selected.
At step 1250, a text representation is obtained for the subset of tags selected at step 1240. Any appropriate techniques may be used to obtain a text representation for a tag, such as any of the techniques described herein. In some implementations, the text representation for a tag may be determined in advance (e.g., by a person) and retrieved from a data store. In some implementations, the text representation for a tag may be generated using a neural network. In some implementations, a user identifier corresponding to the tag may be used to obtain a text representation of a tag.
At step 1260, a conversation summary is generated using the text representations of the selected tags. The conversation summary may be generated using any appropriate techniques, such as any of the techniques described herein. For example, the conversation summary may be a concatenation of the text representations of the selected tags or a bullet point presentation of the text representations of the selected tags. In some implementations, timing information, such as timestamps, may be used to generate the conversation summary.
The conversation summary may then be used for any appropriate business purpose. For example, the conversation may be presented to a user for review and possible modification, may be stored in a data store for later review or use, and may be indexed in a data store (e.g., by label and/or tag values) for business analysis
Computing device 1300 may include any components typical of a computing device, such as volatile or nonvolatile memory 1310, one or more processors 1311, and one or more network interfaces 1312. Computing device 1300 may also include any input and output components, such as displays, keyboards, and touch screens. Computing device 1300 may also include a variety of components or modules providing specific functionality, and these components or modules may be implemented in software, hardware, or a combination thereof. Computing device 1300 may include one or more non-transitory, computer-readable media comprising computer-executable instructions that, when executed, cause a processor to perform actions corresponding to any of the techniques described herein. Below, several examples of components are described for one example implementation, and other implementations may include additional components or exclude some of the components described below.
Computing device 1300 may have a classifier component 1320 that may process a conversation turn to compute classification scores using any of the techniques described herein. Computing device 1300 may have a label score computation component 1321 that may process a conversation turn to compute label scores using any of the techniques described herein. Computing device 1300 may have a tag score computation component 1322 that may process label scores of a conversation turn to compute tag scores using any of the techniques described herein. Computing device 1300 may have a tag selection component 1323 that may select a subset of tags using tag scores and using any of the techniques described herein. Computing device 1300 may have a tag-to-text component 1324 that may obtain a text representation of a tag using any of the techniques described herein. Computing device 1300 may have a summary generation component 1325 that may generate a summary of a conversation using text representations of selected tags and using any of the techniques described herein.
Computing device 1300 may include or have access to various data stores. Data stores may use any known storage technology such as files, relational databases, non-relational databases, or any non-transitory computer-readable media. Computing device 1300 may have a conversation data store 1330 that stores conversation information for facilitating conversations and for applications, such as the generation of conversation summaries. Computing device 1300 may have a conversation summary data store 1331 that stores conversation summaries, and which may be indexed by labels and/or tags corresponding to the conversation summaries.
The methods and systems described herein may be deployed in part or in whole through a machine that executes computer software, program codes, and/or instructions on a processor. “Processor” as used herein is meant to include at least one processor and unless context clearly indicates otherwise, the plural and the singular should be understood to be interchangeable. Any aspects of the present disclosure may be implemented as a computer-implemented method on the machine, as a system or apparatus as part of or in relation to the machine, or as a computer program product embodied in a computer readable medium executing on one or more of the machines. The processor may be part of a server, client, network infrastructure, mobile computing platform, stationary computing platform, or other computing platform. A processor may be any kind of computational or processing device capable of executing program instructions, codes, binary instructions and the like. The processor may be or include a signal processor, digital processor, embedded processor, microprocessor or any variant such as a co-processor (math co-processor, graphic co-processor, communication co-processor and the like) and the like that may directly or indirectly facilitate execution of program code or program instructions stored thereon. In addition, the processor may enable execution of multiple programs, threads, and codes. The threads may be executed simultaneously to enhance the performance of the processor and to facilitate simultaneous operations of the application. By way of implementation, methods, program codes, program instructions and the like described herein may be implemented in one or more thread. The thread may spawn other threads that may have assigned priorities associated with them; the processor may execute these threads based on priority or any other order based on instructions provided in the program code. The processor may include memory that stores methods, codes, instructions and programs as described herein and elsewhere. The processor may access a storage medium through an interface that may store methods, codes, and instructions as described herein and elsewhere. The storage medium associated with the processor for storing methods, programs, codes, program instructions or other type of instructions capable of being executed by the computing or processing device may include but may not be limited to one or more of a CD-ROM, DVD, memory, hard disk, flash drive, RAM, ROM, cache and the like.
A processor may include one or more cores that may enhance speed and performance of a multiprocessor. In embodiments, the process may be a dual core processor, quad core processors, other chip-level multiprocessor and the like that combine two or more independent cores (called a die).
The methods and systems described herein may be deployed in part or in whole through a machine that executes computer software on a server, client, firewall, gateway, hub, router, or other such computer and/or networking hardware. The software program may be associated with a server that may include a file server, print server, domain server, internet server, intranet server and other variants such as secondary server, host server, distributed server and the like. The server may include one or more of memories, processors, computer readable media, storage media, ports (physical and virtual), communication devices, and interfaces capable of accessing other servers, clients, machines, and devices through a wired or a wireless medium, and the like. The methods, programs, or codes as described herein and elsewhere may be executed by the server. In addition, other devices required for execution of methods as described in this application may be considered as a part of the infrastructure associated with the server.
The server may provide an interface to other devices including, without limitation, clients, other servers, printers, database servers, print servers, file servers, communication servers, distributed servers and the like. Additionally, this coupling and/or connection may facilitate remote execution of program across the network. The networking of some or all of these devices may facilitate parallel processing of a program or method at one or more locations without deviating from the scope of the disclosure. In addition, any of the devices attached to the server through an interface may include at least one storage medium capable of storing methods, programs, code and/or instructions. A central repository may provide program instructions to be executed on different devices. In this implementation, the remote repository may act as a storage medium for program code, instructions, and programs.
The software program may be associated with a client that may include a file client, print client, domain client, internet client, intranet client and other variants such as secondary client, host client, distributed client and the like. The client may include one or more of memories, processors, computer readable media, storage media, ports (physical and virtual), communication devices, and interfaces capable of accessing other clients, servers, machines, and devices through a wired or a wireless medium, and the like. The methods, programs, or codes as described herein and elsewhere may be executed by the client. In addition, other devices required for execution of methods as described in this application may be considered as a part of the infrastructure associated with the client.
The client may provide an interface to other devices including, without limitation, servers, other clients, printers, database servers, print servers, file servers, communication servers, distributed servers and the like. Additionally, this coupling and/or connection may facilitate remote execution of program across the network. The networking of some or all of these devices may facilitate parallel processing of a program or method at one or more locations without deviating from the scope of the disclosure. In addition, any of the devices attached to the client through an interface may include at least one storage medium capable of storing methods, programs, applications, code and/or instructions. A central repository may provide program instructions to be executed on different devices. In this implementation, the remote repository may act as a storage medium for program code, instructions, and programs.
The methods and systems described herein may be deployed in part or in whole through network infrastructures. The network infrastructure may include elements such as computing devices, servers, routers, hubs, firewalls, clients, personal computers, communication devices, routing devices and other active and passive devices, modules and/or components as known in the art. The computing and/or non-computing device(s) associated with the network infrastructure may include, apart from other components, a storage medium such as flash memory, buffer, stack, RAM, ROM and the like. The processes, methods, program codes, instructions described herein and elsewhere may be executed by one or more of the network infrastructural elements.
The methods, program codes, and instructions described herein and elsewhere may be implemented on a cellular network having multiple cells. The cellular network may either be frequency division multiple access (FDMA) network or code division multiple access (CDMA) network. The cellular network may include mobile devices, cell sites, base stations, repeaters, antennas, towers, and the like. The cell network may be a GSM, GPRS, 3G, EVDO, mesh, or other networks types.
The methods, programs codes, and instructions described herein and elsewhere may be implemented on or through mobile devices. The mobile devices may include navigation devices, cell phones, mobile phones, mobile personal digital assistants, laptops, palmtops, netbooks, pagers, electronic books readers, music players and the like. These devices may include, apart from other components, a storage medium such as a flash memory, buffer, RAM, ROM and one or more computing devices. The computing devices associated with mobile devices may be enabled to execute program codes, methods, and instructions stored thereon. Alternatively, the mobile devices may be configured to execute instructions in collaboration with other devices. The mobile devices may communicate with base stations interfaced with servers and configured to execute program codes. The mobile devices may communicate on a peer-to-peer network, mesh network, or other communications network. The program code may be stored on the storage medium associated with the server and executed by a computing device embedded within the server. The base station may include a computing device and a storage medium. The storage device may store program codes and instructions executed by the computing devices associated with the base station.
The computer software, program codes, and/or instructions may be stored and/or accessed on machine readable media that may include: computer components, devices, and recording media that retain digital data used for computing for some interval of time; semiconductor storage known as random access memory (RAM); mass storage typically for more permanent storage, such as optical discs, forms of magnetic storage like hard disks, tapes, drums, cards and other types; processor registers, cache memory, volatile memory, non-volatile memory; optical storage such as CD, DVD; removable media such as flash memory (e.g. USB sticks or keys), floppy disks, magnetic tape, paper tape, punch cards, standalone RAM disks, Zip drives, removable mass storage, off-line, and the like; other computer memory such as dynamic memory, static memory, read/write storage, mutable storage, read only, random access, sequential access, location addressable, file addressable, content addressable, network attached storage, storage area network, bar codes, magnetic ink, and the like.
The methods and systems described herein may transform physical and/or or intangible items from one state to another. The methods and systems described herein may also transform data representing physical and/or intangible items from one state to another.
The elements described and depicted herein, including in flow charts and block diagrams throughout the figures, imply logical boundaries between the elements. However, according to software or hardware engineering practices, the depicted elements and the functions thereof may be implemented on machines through computer executable media having a processor capable of executing program instructions stored thereon as a monolithic software structure, as standalone software modules, or as modules that employ external routines, code, services, and so forth, or any combination of these, and all such implementations may be within the scope of the present disclosure. Examples of such machines may include, but may not be limited to, personal digital assistants, laptops, personal computers, mobile phones, other handheld computing devices, medical equipment, wired or wireless communication devices, transducers, chips, calculators, satellites, tablet PCs, electronic books, gadgets, electronic devices, devices having artificial intelligence, computing devices, networking equipment, servers, routers and the like. Furthermore, the elements depicted in the flow chart and block diagrams or any other logical component may be implemented on a machine capable of executing program instructions. Thus, while the foregoing drawings and descriptions set forth functional aspects of the disclosed systems, no particular arrangement of software for implementing these functional aspects should be inferred from these descriptions unless explicitly stated or otherwise clear from the context. Similarly, it will be appreciated that the various steps identified and described above may be varied, and that the order of steps may be adapted to particular applications of the techniques disclosed herein. All such variations and modifications are intended to fall within the scope of this disclosure. As such, the depiction and/or description of an order for various steps should not be understood to require a particular order of execution for those steps, unless required by a particular application, or explicitly stated or otherwise clear from the context.
The methods and/or processes described above, and steps thereof, may be realized in hardware, software or any combination of hardware and software suitable for a particular application. The hardware may include a general-purpose computer and/or dedicated computing device or specific computing device or particular aspect or component of a specific computing device. The processes may be realized in one or more microprocessors, microcontrollers, embedded microcontrollers, programmable digital signal processors or other programmable device, along with internal and/or external memory. The processes may also, or instead, be embodied in an application specific integrated circuit, a programmable gate array, programmable array logic, or any other device or combination of devices that may be configured to process electronic signals. It will further be appreciated that one or more of the processes may be realized as a computer executable code capable of being executed on a machine-readable medium.
The computer executable code may be created using a structured programming language such as C, an object oriented programming language such as C++, or any other high-level or low-level programming language (including assembly languages, hardware description languages, and database programming languages and technologies) that may be stored, compiled or interpreted to run on one of the above devices, as well as heterogeneous combinations of processors, processor architectures, or combinations of different hardware and software, or any other machine capable of executing program instructions.
Thus, in one aspect, each method described above and combinations thereof may be embodied in computer executable code that, when executing on one or more computing devices, performs the steps thereof. In another aspect, the methods may be embodied in systems that perform the steps thereof, and may be distributed across devices in a number of ways, or all of the functionality may be integrated into a dedicated, standalone device or other hardware. In another aspect, the means for performing the steps associated with the processes described above may include any of the hardware and/or software described above. All such permutations and combinations are intended to fall within the scope of the present disclosure.
While the invention has been disclosed in connection with the preferred embodiments shown and described in detail, various modifications and improvements thereon will become readily apparent to those skilled in the art. Accordingly, the spirit and scope of the present invention is not to be limited by the foregoing examples, but is to be understood in the broadest sense allowable by law.
All documents referenced herein are hereby incorporated by reference in their entirety.