Text-based communication channels may include various conversations. Different conversations within a communication channel may be used for discussing topics that may relate to an overall topic of the communication channel. Knowing what topics the different conversations in a communication channel are about may allow for the conversations to be used in various manners, and it may be difficult and time consuming to determine these topics.
The accompanying drawings, which are included to provide a further understanding of the disclosed subject matter, are incorporated in and constitute a part of this specification. The drawings also illustrate implementations of the disclosed subject matter and together with the detailed description serve to explain the principles of implementations of the disclosed subject matter. No attempt is made to show structural details in more detail than may be necessary for a fundamental understanding of the disclosed subject matter and various ways in which it may be practiced.
Techniques disclosed herein enable conversation topic extraction, which may allow for topic phrases to be determined for conversations that are part of a communication channel. The text of a communication channel may be received. The text of the communication channel may be divided into conversation documents based on conversation threads of the communication channel. Phrases of the text of the conversation documents may be tokenized. Importance scores may be assigned to the tokenized phrases using unsupervised topic extraction to determine topic phrases for the conversation documents. The topic phrases for the conversation documents may be the tokenized phrase with the highest importance scores. Assigning importance scores to the tokenized phrases may include using supervised topic extraction to update the importance scores assigned to the tokenized phrases. A conversation thread may be sent to a recipient selected based on the topic phrases for the conversation document associated with the conversation thread. A summary for the communication channel may be generated and may include topic phrases for the conversation documents into which the text of the communication channel was divided.
The text of a communication channel may be received. The communication channel may be, for example, a channel for text-based communications that is part of a communications platform. The communication channel may include text for messages added to the channel by users of the communications platform. A communication channel may be designated for communicating about a general subject. For example, a communication channel that is a part of a communications platform for a business may be designated for discussing technical support issues within the business, while another communication channel on the same communications platform for the business may be designated for discussing a particular brand or product line. A communication channel may be threaded, and may include multiple separate conversations which may have their own threads within the communication channel. For example, a communication channel designated for discussing technical support issues may have separate conversation threads, with users starting new conversation threads when they post messages about new technical support issues. The text of a communication channel may be received at any suitable computing device. The received text may include, for example, the text of messages from the communication channel, and may preserve both differentiation between messages and any threading of the messages. The threading may be preserved by, for example, conversation identifiers assigned to messages from the same conversation by the communications platform. The conversation identifier for a message may be included along with the text of the message in the received text of the communication channel. Data identifying the users who added the textual messages to the communication channel may not be part of the received text, or users may be deidentified or otherwise have their identities obscured. Non-text data in a communication channel, such as file attachments and inline images, may not be received.
The text of the communication channel may be divided into conversation documents. A conversation document may include the text from a single conversation thread of the communication channel. The text may be divided into conversation documents based on threading information in the received text of the communication channel. For example, if messages are assigned conversation identifiers, text for a single conversation thread may be identified from the text of the communication channel as text that has the same conversation identifier. Text with the same conversation identifier may be added to a conversation document for the conversation thread. The text of a communication channel may be divided into any suitable number of conversation documents. For example, the text may be divided into one conversation document for each conversation thread in the text of the communication channel, as determined, for example, by the number of unique conversation identifiers in the received text of the communication channel. In some implementations, the text from a communications platform may be divided at other levels of granularity. For example, the messages in a conversation thread from a communication channel may be divided into their own conversation documents, with each conversation document including text from a single message from the conversation thread. As another example, a communications platform may have multiple communication channels, and the text of each communication channel, including all conversation threads in a communication channel, may be used as the basis for a conversation document. This may result in each conversation document including the text from all of the messages in all of the conversation threads of one of the communication channels of the communications platform.
For example, a communication channel designated for communicating about technical support issues may include a first conversation thread started by a user who has lost access to a VPN, a second conversation thread started by a user who needs a laptop replaced, and a third conversation thread started by a user who needs their password reset. The messages for the first conversation thread may have been assigned a first conversation identifier, the messages for the second conversation thread may have been assigned a second conversation identifier, and the messages for the third conversation thread may have been assigned a third conversation identifier. When a computing device receives the text of the communication channel, the text from messages of the first conversation thread may include the first conversation identifier, the text from messages of the second conversation thread may include the second conversation identifier, and the text from messages of the third conversation thread may include the third conversation identifier To divide the text of the communication channel into conversation documents, text that has the same conversation identifier may be added to a conversation document that includes only text with that conversation identifier. For example, text that has the first conversation identifier may be added to a first conversation document, text that has the second conversation identifier may be added to a second conversation document, and text that has the third conversation identifier may be added to a third conversation document. This may result in the first conversation document including text from textual messages of the conversation thread started by the user who has lost access to a VPN, the second conversation document including text from the textual messages of the conversation thread started by the user who needs a laptop replaced, and the third conversation document including text from textual messages of the conversation thread started by the user who needs their password reset.
Phrases of the text of the conversation documents may be tokenized. The conversation documents may be tokenized using any suitable tokenizer. The tokenizer may generate any number of n-gram tokenizations of phrases from the text of the conversation documents. For example, the tokenizer may generate token vectors that may include counts for one-word, two-word, and three-word phrases from the text of the conversation documents. The tokenization of the conversation documents may generate for each conversation document a vector representation of the phrases, which may be the tokens, in that conversation document. The vector representation may be, for example, a vector with indexes mapped to the phrases extracted from a conversation document and the cell at each index storing a count of the number of times the phrase the index is mapped to occurs in the conversation document. For example, tokenized phrases from text of a conversation document for a conversation thread started by a user who has lost access to a VPN may result in tokenized phrases such as “VPN”, “login” “passcode generator”, phone”, “help”, and “reset”, which may be represented in a vector for the conversation document that may store counts of how many times each of the phrases occurs in the conversation document. The tokenizer may tokenize a number of conversation documents together, so that the same indexes of the token vectors generated for each of the conversation documents are mapped to the same phrases. The tokenizer may also limit the size of the token vectors, for example, by counting the occurrence of phrases across the text of all of the conversation documents being tokenized together and generating the token vectors to represent the phrases that occur the most, for example, the 500 most recurrent phrases across the conversation documents. The text of the conversation documents may also be cleaned and prepared for tokenization in any suitable manner before being tokenized. The vectors generated by the tokenizer may be token vectors for the conversation documents they are generated from.
In some implementations, tokenization may use known phrases for a communication channel in determining how to tokenize phrases from the text of the conversation documents. The known phrases for a communication channel may be associated with the communication channel, for example, based on the general subject designated to the communication channel. For example, the known phrases for a communication channel with a designated subject of technical support issues may be taken from a corpus of technical support phrases. The tokenizer may prioritize the known phrases, ensuring that any known phrases that appear in the text of the conversation documents gets tokenized. For example, a communication channel may be designated to discuss a specific brand of shoes. Existing data about the brand of shoes, such as, for example slogans used by the brand, names of the brand's shoes, and names of features of the brand's shoes, may be used by the tokenizer when tokenizing text for conversation documents associated with the conversation channels of the communication channel. In this way, if the slogan used by the brand of shoes appears in the text of a conversation document, the tokenizer may prioritize tokenizing the slogan, even if the slogan is an n-gram longer than what a tokenizer may ordinarily tokenize. For example, the tokenizer may normally tokenize one-word, two-word, and three-word phrases, and the slogan may be five words long. Using the existing data about the brand of shoes may cause the tokenizer to tokenize the slogan anyway. An unsupervised model may be used to group words in conversation documents for a communication channel based on known phrases for the communication channel before the conversation documents are tokenized. This may assist the tokenizer in locating known phrases within the conversation documents. The known phrases for a communication channel may be come from any suitable source. For example, noun-phrase extraction may be performed across communication channels with similar designated subjects to generate known phrases that may be used in tokenizing conversation documents for conversation threads from any of the communication channels. A brand, for example, may have multiple different communication channels on a communications platform, which may all have designated subjects that are related to the brand. Known phrases for a communication channel may also be extracted from sources external to the communication channel. For example, a brand may have various online assets, such as websites, from which phrases may be extracted to be used as known phrases when tokenizing phrases from text of conversation documents for conversation threads from a communication channel for the brand.
Importance scores may be assigned to the tokenized phrases using unsupervised topic extraction to determine topic phrases for the conversation documents. The unsupervised topic extraction may be performed, for example, using a dimensionality-reduction technique, such as non-negative matrix factorization (NMF) or latent Dirichlet allocation (LDA), or using a neural network model. For example, the token vectors generated by the tokenizer for each conversation document may be used to generate a matrix that may include all tokens across all of the conversation documents that were tokenized, representing all of the conversation threads whose text was received from the communication channel. The matrix generated from the token vectors may then have dimensionality-reduction, such as NMF or LDA, performed on it. Performing dimensionality-reduction on the matrix generated from the token vectors may generate two matrices. The first matrix may be a topic distribution of the tokenized phrases which may include assigned weights to the tokenized phrases indicating how representative that tokenized phrase is of a topic in the topic distribution. The topics of the topic distribution created by performing dimensionality reduction may be unlabeled categories. The second matrix may include assigned weights that indicate which of the topics represented in the first matrix are most representative of the token vectors of the input matrix, and by association, of the conversation documents and conversation threads. An importance score may be assigned by the dimensionality-reduction to the tokenized phrases from the token vectors for each conversation document based on the first and second matrixes, for example, based on how representative a tokenized phrase is of a topic, and how representative a topic is of a token vector. For example, a tokenized phrase that is very representative of topic that is very representative of a token vector may be assigned a high importance score. The importance scores may be assigned on a per-token vector, and therefore per-conversation document, basis. The same tokenized phrase that appears in more than one of the conversation documents, and more than one of the token vectors, may assigned a different importance score between the two token vectors, and two conversation documents. For example, the phrase “password” may appear in both conversation documents with text from a conversation thread started by a user who has lost access to a VPN and a conversation thread started by a user who needs their password reset. “password” may be tokenized in generating the token vectors for both conversation documents, but may be assigned a different importance score for each conversation document, as the dimensionality-reduction may determine that “password” is more important, and more likely to be a topic phrase, for one of the conversation documents than for the other. For example, “password” may have a higher importance score for the conversation document with text from the conversation thread started by the user who needs their password reset.
Assigning importance scores to the tokenized phrases may also include using supervised topic extraction to update the importance scores assigned to the tokenized phrases. For example, the importance scores assigned using unsupervised topic extraction may be considered weak labels for the tokenized phrases. The token vectors and a subset of tokenized phrases and their importance scores may be used as a weakly labeled training data set to train a supervised topic extraction model, such as, for example, a supervised neural network model or supervised statistical model. The trained supervised topic extraction model may then be used to update importance scores for the all of the tokenized phrases in the token vectors.
The topic phrase for a conversation document may be the tokenized phrase with the highest importance score. Each conversation document may have its own set of importance scores for the tokenized phrases from the conversation document. The tokenized phrase assigned the highest importance score, either through unsupervised topic extraction alone or unsupervised topic extraction followed by supervised topic extraction, for a conversation document may be used as the topic phrase for the conversation document and its associated conversation thread. In some implementations, a conversation document may have multiple topic phrases. For example, the three tokenized phrases with the highest importance scores for a conversation document may be used as topic phrases for that conversation document and its associated conversation thread.
A conversation thread may be sent to a recipient selected based on the topic phrases for the conversation document associated with the conversation thread. The topic phrases for the conversation document associated with the conversation thread may be used to determine an appropriate recipient for the conversation thread to be sent to based on any suitable routing rules or heuristics. For example, if the topic phrase for a conversation document from a communication channel for technical support issues is “VPN”, this may be used to determine that the associated conversation thread should be sent to technical support personnel who specialized in VPN issues. A conversation thread may be sent to a recipient in any suitable manner, including, for example, as a link to the conversation thread on the communication platform.
A summary for the communication channel may be generated and may include topic phrases for the conversation documents into which the text of the communication channel was divided. The summary may be in any suitable format, and may be, for example, a message added to the communication channel. The summary may include the topic phrases for the conversation documents associated with the conversation threads of the communication channel. The topic phrases may be presented in order of importance score and alongside the text of messages from the conversations threads.
The text preprocessor 110 may be any suitable combination of hardware and software of the computing device 100 for generating conversation documents from the text of a communication channel. The text preprocessor 110 may receive the text of a communication channel in any suitable manner, including, for example, through crawling the communication channel, accessing the communication channel through an API, or through receiving the text of the communication channel in an already prepared file. The text may be text of messages posted in the communication channel by users. The text preprocessor 110 may divide the text of the communication channel into conversation documents based on the conversation threads of the communication channel. A conversation document may include the text of a single conversation thread from a communication channel. In generating conversation documents, the text preprocessor 110 may remove any non-text elements that have not already been removed from the received text of the communication channel, and may also remove any user identifiers, whether or not users have already been deidentified or had their user identifiers obscured. The text preprocessor 110 may determine the text that belongs to a conversation thread based on conversation identifiers attached to or otherwise associated with the text, so that each conversation document includes text from a single conversation thread of the communication channel. The conversation identifiers may have been added to the messages posted in the communication channel by the communications platform in order to track which messages belong to which conversation thread. Conversation documents generated by the text preprocessor 110 may be stored in the storage 150, for example, as conversation documents 161, 162, 163, and 164. Each of the conversation documents 161, 162, 163, and 164 may include text from a separate conversation thread of the communication channel whose text was received by the text preprocessor 110.
The tokenizer 120 may be any suitable combination of hardware and software of the computing device 100 for generating token vectors from conversation documents. The tokenizer 120 may generate any number of n-gram tokenizations of the text of the conversation documents generated by the text preprocessor 110, such as the conversation documents 161, 162, 163, and 164. For example, the tokenizer 120 may generate a tokenization that may include one-word, two-word, and three-word phrases from the text of the conversation documents, with counts of how many times each of the phrases occurs in each conversation document. The tokenization of the conversation documents may generate for each conversation document a vector representation of the phrases, which may be the tokens, in that conversation document, including counts of how many times each of the phrases occurs in that conversation document, along with a mapping of the indexes of generated token vectors to tokenized phrases. For example, if the conversation document 161 includes the phrase “VPN” seven times, the token vector generated by the tokenizer 120 from the conversation document 161 may include a cell whose index is mapped to the phrase “VPN” and that stores the number seven. The vectors generated by the tokenizer 100 may be the token vectors for the conversation documents they are generated from. The tokenizer 120 may generate tokenize the conversation documents 161, 162, 163, and 164 together, and may generate a separate token vector for each of the conversation documents 161, 162, 163, and 164. The same indexes across the token vectors for the conversation documents 161, 162, 163, and 164 may be mapped to the same phrases. The token vectors generated by the tokenizer 120 may be of any suitable size. For example, the tokenizer 120 may limit the size of the token vectors for the conversation documents 161, 162, 163, and 164 to the 500 phrases that occur most often across the conversation documents 161, 162, 163, and 164. This may result in, for example, the token vectors for the conversation documents 161, 162, 163, and 164 having indexes from 0 to 499, with the same indexes across token vectors mapped to the same phrases from the conversation documents 161, 162, 163, 164, and cells at those indexes storing the counts of occurrences of those phrases in each separate conversation document 161, 162, 163, and 164. The counts stored by a token vector may be specific to the conversation document used to generate the token vector. The token vectors generated by the tokenizer 120 may be stored in the storage 150, or may be sent directly to the unsupervised topic extractor 130.
In some implementations, the tokenizer 120 may use known phrases for a communication channel in determining how to tokenize phrases from the text of the conversation documents. The known phrases for a communication channel may be associated with the communication channel, for example, based on the general subject designated to the communication channel. The tokenizer 120 may prioritize the known phrases when generating the token vectors for the conversation documents 161, 162, 164, and 164. The known phrases may be received by the tokenizer 120 from any suitable source and may have been generated in any suitable manner. For example, the known phrases for a communication channel may have been generated using noun-phrase extraction across communication channels with similar designated subjects to the communication channel, or may have been generated through extraction from external sources, such as websites, associated with the designated subject of the communication channel.
The unsupervised topic extractor 130 may be any suitable combination of hardware and software of the computing device 100 for generating and assigning importance scores to tokenized phrases in token vectors using unsupervised topic extraction techniques. The unsupervised topic extractor 130 may, for example, use any suitable dimensionality-reduction technique, such as non-negative matrix factorization (NMF) or latent Dirichlet allocation (LDA), or a neural network model. The unsupervised topic extractor 130 may use as input the token vectors generated by tokenizer 120. For example, the token vectors may be used to generate a matrix that may include all tokens across all of the conversation documents 161, 162, 163, and 164, representing all of the conversation threads whose text was received from the communication channel by the text preprocessor 110. The tokenizer 120 may then perform dimensionality-reduction on the matrix generated from the token vectors, assigning importance scores to the tokenized phrases of the token vectors. The importance scores may be assigned on a per-token vector, and therefore per-conversation document, basis. For example, the same phrase may be represented in the token vectors for the conversation document 161 and the conversation document 162. The unsupervised topic extractor 110 may assign the phrase an importance score in the token vector for the conversation document 161 that is different from the importance score the unsupervised topic extractor 110 assigns to the same phrase in the token vector for the conversation document 162.
The importance scores assigned to the tokenized phrases of the token vectors by the unsupervised topic extractor 130 may be used to determine which tokenized phrases are topic phrases for the conversation documents 161, 162, 163, and 164. For example, the tokenized phrase with the highest importance score in the token vector for the conversation document 161 may be used as the topic phrase for the conversation document 161, and the conversation thread associated with the conversation document 161, and may be stored, for example with topic phrases. Each conversation document 161, 162, 163, and 164 may have its own topic phrase, and may have more than one topic phrase, for example, having n topic phrases based on the tokenized phrases with the n highest importance scores in their respective token vectors.
The supervised topic extractor 140 may be any suitable combination of hardware and software of the computing device 100 for updating assigned importance scores using any suitable supervised topic extraction techniques. The importance scores assigned to tokenized phrases by the unsupervised topic extractor 130 may be considered weak labels for the tokenized phrases. The token vectors and a subset of tokenized phrases and their importance scores may be used as a weakly labeled training data set to train the supervised topic extractor 140, which may implement any suitable supervised topic extraction model, such as, for example, a supervised neural network model or supervised statistical model. After being trained using the importance scores generated and assigned by the unsupervised topic extractor 143, the supervised topic extractor 140 may then be used to update importance scores for the all of the tokenized phrases in the token vectors. The updated importance scores may be used to determine the topic phrases for the conversation documents 161, 162, 163, and 164, which may be stored with the topic phrases 170.
The summary generator 180 may be any suitable combination of hardware and software of the computing device 100 for generating a summary of a communication channel. The summary generator 180 may, for example, use topic phrases from the topic phrases 170 to generate a summary of the communication channel whose text was used to generate the conversation documents 161, 162, 163, and 164. The summary generator 180 may add the summary as a message in the communication channel.
The conversation router 190 may be any suitable combination of hardware and software of the computing device 100 for sending a conversation thread to recipient selected based on topic phrases for the conversation thread. The conversation router 190 may, for example, use a topic phrase from the topic phrases 170 for one of the conversation documents, for example, the conversation document 161, to determine a recipient to send the conversation thread associated with the conversation document. For example, the topic phrase for the conversation document 161, as stored in the in the topic phrases 170, may be “VPN.” The conversation router 190 may select a recipient based on this topic phrase, for example, an appropriate technical support personnel, and send the conversation thread associated with the conversation document 161 to the selected recipient. The conversation router 190 may send a conversation thread to a recipient in any suitable manner, including sending a link to the conversation thread on the communication platform, or sending the text of the conversation thread itself, to the recipient.
The storage 150 may be any suitable combination of hardware and software for storing data. The storage 150 may include any suitable combination of volatile and non-volatile storage hardware, and may include components of the computing device 100 and hardware accessible to the computing device 100, for example, through wired and wireless direct or network connections. The storage 150 may store the conversation documents 161, 162, 163, and 164 and the topic phrases 170. The storage 150 may also store, as necessary, token vectors, matrices generated from the token vectors, and any output from the unsupervised topic extractor 130 and supervised topic extractor 140, including the importance scores assigned to the tokenized phrases in the token vectors. The storage 150 may also store known phrases that may be used by the tokenizer 120 when tokenized the conversation documents 161, 162, 163, and 164.
The text preprocessor 110 may receive the text of the communication channel 220 in any suitable manner. For example, the text preprocessor 110 may crawl the communication platform 220, access the communication channel 220 through an API of the communications platform 210, or directly access the stored data for the communication channel 220. The text of the communication channel 220 may include the text of messages posted in all of the conversation threads of the communication channel 220, for example, the conversation threads 221, 222, 223, and 224, each of which may be a conversation started by a user of the communications platform 210 regarding a subject related to the designated subject of the communication channel 220. For example, the communication channel 220 may be designated for discussing technical support issues, and the conversation threads 221, 222, 223, and 224 may have been started by users with their own technical supports issues and include messages discussing those issues. The text of the messages from the conversations threads 221, 222, 223, and 224 received as the text of the communication channel 220 by the text preprocessor 110 may include conversation identifiers that may be used to preserve the threading and differentiate between the text of messages posted in each of the conversation threads 221, 222, 223, and 224. The text of the communication channel 220 may also be deidentified or otherwise have user identifiers removed or obscured, and non-text data, such as file attachments and inline images, may also be removed, either before or after the text of the communication channel 220 is received by the text preprocessor 110.
The text preprocessor 110 may divide the text of the communication channel 220 into the conversation documents 161, 162, 163, and 164. Each of the conversation documents 161, 162, 163, and 164 may include the text of one of the conversation threads 221, 222, 223, and 224. For example, the text preprocessor 110 may generate the conversation document 163 using the text of the conversation thread 221, generate the conversation document 163 using the text of the conversation thread 221, generate the conversation document 163 using the text of the conversation thread 223, and generate the conversation document 164 using the text of the conversation thread 224. The conversation documents 161, 162, 163, and 164 may include the text of the conversation thread whose text was used to generate them, stripped of conversation identifiers, user identifiers, and any non-text data.
At 704, the text of the communication channel may be divided into conversation documents based on conversation threads. For example, the text preprocessor 110 may divide the communication channel text 620 into the conversation documents 161, 162, 163, and 164, which may include, respectively, text of the messages from the conversation threads 221, 222, 223, and 224. The text preprocessor 110 may use the conversation identifiers in the communication channel text 620 to determine how to divide the text in the communication channel text 620 into the conversation documents 161, 162, 163, and 164. The text preprocessor 110 may remove any non-text data, such as obscured user identifiers or conversation identifiers, when dividing the communication channel text 620 into the conversation documents 161, 162, 163, and 164, but may preserve punctuation and whitespace.
At 706, phrases of the conversation documents may be tokenized. For example, the tokenizer 120 may generate token vectors 231, 232, 233, and 234, and tokens 240, from the conversation documents 161, 162, 163, and 164 by counting the occurrence of phrases in the conversation documents 161, 162, 163, and 164. The tokenized phrases may be n-grams of words of any suitable length found in the conversation documents 161, 162, 163, and 164. The tokenizer 120 may also search the conversation documents 161, 162, 163, and 164 for known phrases related to a designated subject of the communication channel 220 when tokenizing phrases. The tokens 240 may include the phrases tokenized by the tokenizer 120, which may be any number of phrases that occur the most, for example, the top n most frequent phrases, across all of the conversation documents 161, 162, 163, and 164, and may map the tokenized phrases to index numbers that correspond to cells of the token vectors 231, 232, 233, and 234. The token vectors 231, 232, 233, and 234 may store counts of how many times the tokenized phrases in the tokens 240 occur in, respectively, the conversation documents 161, 162, 163, and 164.
At 708, topic phrases for the conversation documents may be determined. For example, the token vectors 231, 232, 233, and 234 may be input to the unsupervised topic extractor 130 as the matrix 280. The unsupervised topic extractor 130 may perform dimensionality reduction, such as NMF or LDA, on the matrix 280, generating matrices that may be used to assign importance scores 281, 282, 283, and 284 for the tokenized phrases in the tokens 240 on a per-token vector, and per conversation document, basis for the token vectors 231, 232, 233, and 234 and their associated conversation documents 161, 162, 163, and 164. The topic phrases with the highest n importance scores in the importance scores 281, 282, 283, and 284 for the respective conversation documents 231, 232, 233, and 234 may be stored, for example, as topic phrases 321, 322, 323, and 324, and may be used as topic phrases for the conversation threads 221, 222, 223, and 224.
In some implementations, the importance scores assigned by the unsupervised topic extractor 130 may be used with token vectors 231, 232, 233, and 234 and tokens 240 to generate the training data set 510 for the supervised topic extractor 140. The training data set 410 may, for example, include a subset of the importance scores 281, 282, 283, and 284, and may be used in the supervised training of the supervised topic extractor 140. The supervised topic extractor 140, after being trained with the training data set 410, may be used to update the assigned importance scores 281, 282, 283, and 284, for example, generating the importance scores 481, 482, 483, and 484 from the token vectors 231, 232, 233, and 234. The topic phrases with the highest n importance scores in the importance scores 481, 482, 483, and 484 for the respective conversation documents 231, 232, 233, and 234 may be stored, for example, as topic phrases 321, 322, 323, and 324, and may be used as topic phrases for the conversation threads 221, 222, 223, and 224.
At 710, summaries of conversation threads may be generated or a conversation thread may be sent to a selected recipient. For example, the summary generator 180 may generate a summary of the communication channel 220 using the topic phrases 321, 322, 323, and 324 for the conversation threads 221, 222, 223, and 224, along with, for example, samples of messages from the conversation threads 221, 222, 223, and 224. The conversation router 190 may select an appropriate recipient for a conversation thread, for example, the conversation thread 221, based on the topic phrases for that conversations thread, for example, the topic phrases 321. The conversation router 190 may send the conversation thread to the selected recipient in any suitable manner using any suitable form of electronic communication, for example, sending the recipient a message that includes a link to the conversation thread 221 or has the conversation thread 221 embedded in the message.
Implementations of the presently disclosed subject matter may be implemented in and used with a variety of component and network architectures.
The computer (e.g., user computer, enterprise computer, etc.) 20 includes a bus 21 which interconnects major components of the computer 20, such as a central processor 24, a memory 27 (typically RAM, but which may also include ROM, flash RAM, or the like), an input/output controller 28, a user display 22, such as a display or touch screen via a display adapter, a user input interface 26, which may include one or more controllers and associated user input or devices such as a keyboard, mouse, WiFi/cellular radios, touchscreen, microphone/speakers and the like, and may be closely coupled to the I/O controller 28, fixed storage 23, such as a hard drive, flash storage, Fibre Channel network, SAN device, SCSI device, and the like, and a removable media component 25 operative to control and receive an optical disk, flash drive, and the like.
The bus 21 enable data communication between the central processor 24 and the memory 27, which may include read-only memory (ROM) or flash memory (neither shown), and random access memory (RAM) (not shown), as previously noted. The RAM can include the main memory into which the operating system and application programs are loaded. The ROM or flash memory can contain, among other code, the Basic Input-Output system (BIOS) which controls basic hardware operation such as the interaction with peripheral components. Applications resident with the computer 20 can be stored on and accessed via a computer readable medium, such as a hard disk drive (e.g., fixed storage 23), an optical drive, floppy disk, or other storage medium 25.
The fixed storage 23 may be integral with the computer 20 or may be separate and accessed through other interfaces. A network interface 29 may provide a direct connection to a remote server via a telephone link, to the Internet via an internet service provider (ISP), or a direct connection to a remote server via a direct network link to the Internet via a POP (point of presence) or other technique. The network interface 29 may provide such connection using wireless techniques, including digital cellular telephone connection, Cellular Digital Packet Data (CDPD) connection, digital satellite data connection or the like. For example, the network interface 29 may enable the computer to communicate with other computers via one or more local, wide-area, or other networks, as shown in
Many other devices or components (not shown) may be connected in a similar manner (e.g., document scanners, digital cameras and so on). Conversely, all of the components shown in
More generally, various implementations of the presently disclosed subject matter may include or be implemented in the form of computer-implemented processes and apparatuses for practicing those processes. Implementations also may be implemented in the form of a computer program product having computer program code containing instructions implemented in non-transitory and/or tangible media, such as floppy diskettes, CD-ROMs, hard drives, USB (universal serial bus) drives, or any other machine readable storage medium, wherein, when the computer program code is loaded into and executed by a computer, the computer becomes an apparatus for practicing implementations of the disclosed subject matter. Implementations also may be implemented in the form of computer program code, for example, whether stored in a storage medium, loaded into and/or executed by a computer, or transmitted over some transmission medium, such as over electrical wiring or cabling, through fiber optics, or via electromagnetic radiation, wherein when the computer program code is loaded into and executed by a computer, the computer becomes an apparatus for practicing implementations of the disclosed subject matter. When implemented on a general-purpose microprocessor, the computer program code segments configure the microprocessor to create specific logic circuits. In some configurations, a set of computer-readable instructions stored on a computer-readable storage medium may be implemented by a general-purpose processor, which may transform the general-purpose processor or a device containing the general-purpose processor into a special-purpose device configured to implement or carry out the instructions. Implementations may be implemented using hardware that may include a processor, such as a general purpose microprocessor and/or an Application Specific Integrated Circuit (ASIC) that implements all or part of the techniques according to implementations of the disclosed subject matter in hardware and/or firmware. The processor may be coupled to memory, such as RAM, ROM, flash memory, a hard disk or any other device capable of storing electronic information. The memory may store instructions adapted to be executed by the processor to perform the techniques according to implementations of the disclosed subject matter.
The foregoing description, for purpose of explanation, has been described with reference to specific implementations. However, the illustrative discussions above are not intended to be exhaustive or to limit implementations of the disclosed subject matter to the precise forms disclosed. Many modifications and variations are possible in view of the above teachings. The implementations were chosen and described in order to explain the principles of implementations of the disclosed subject matter and their practical applications, to thereby enable others skilled in the art to utilize those implementations as well as various implementations with various modifications as may be suited to the particular use contemplated.