DIALOGUE ACT CLASSIFICATION IN GROUP CHATS WITH DAG-LSTMS

Information

  • Patent Application
  • 20210335346
  • Publication Number
    20210335346
  • Date Filed
    April 19, 2021
    3 years ago
  • Date Published
    October 28, 2021
    3 years ago
  • Inventors
    • IRSOY; Ozan (New York, NY, US)
    • GOSANGI; Rakesh (Long Island City, NY, US)
    • ZHANG; Haimin (Short Hills, NJ, US)
    • WEI; Mu-Hsin (Redmond, WA, US)
    • LUND; Peter John (New York, NY, US)
    • PAPPADOPULO; Duccio (New York, NY, US)
    • FAHY; Brendan Michael (New York, NY, US)
    • NEPHYTOU; Neophytos (Glen Cove, NY, US)
    • DIAZ; Camilo Ortiz (New York, NY, US)
  • Original Assignees
Abstract
Systems and methods for classifying a dialogue act in a chat log are provided. Each word of the dialogue act is mapped to a word vector representation. An utterance vector representation of the dialogue act is computed based on the word vector representations. An additional utterance vector representation of the dialogue act is computed based on the utterance vector representation. The additional utterance vector representation is mapped to a classification of the dialogue act.
Description
TECHNICAL FIELD

The present invention relates generally to classification of dialogue acts, and in particular to classification of dialogue acts in group chats with DAG-LSTMs (directed-acyclic-graph long short-term memory).


BACKGROUND

A dialogue act is an utterance in conversational dialogue that serves a function in the dialogue. Examples of a dialogue act include a question, an answer, a request, or a suggestion. Classification of dialogue acts is an important task for workflow automation and conversational analytics. Conventionally, machine learning techniques have been applied for classification of dialogue acts. Such conventional machine learning techniques typically predict classifications of dialogue acts based on textual content of the dialogue acts, the user who generated the dialogue acts, and contextual information of the dialogue acts.


With the increasing prevalence of chat and messaging applications, classification of dialogue acts in group chats is of particular importance. However, classification of dialogue acts in group chats has a number of challenges. Group chats may include multiple participants simultaneously conversing, leading to entanglements of utterances. Further, unlike spoken conversations, written conversations do not have any prosodic cues. In addition, due to the informal nature of group chats, they tend to include domain-specific jargon, abbreviations, and emoticons. Accordingly, group chats do not include sufficient information for classification of dialogue acts using conventional techniques.


BRIEF SUMMARY OF THE INVENTION

In accordance with one or more embodiments, systems and methods for classifying a dialogue act in a chat log are provided. Each word of the dialogue act is mapped to a word vector representation. An utterance vector representation of the dialogue act is computed based on the word vector representations. An additional utterance vector representation of the dialogue act is computed based on the utterance vector representation. The additional utterance vector representation is mapped to a classification of the dialogue act.


In one embodiment, the additional utterance vector representation is computed based on utterance vector representations of all prior dialogue acts in the chat log and an utterance vector representation of an immediately prior dialogue act of the same participant as the dialogue act.


In one embodiment, the utterance vector representation is computed using a bidirectional long short-term memory (LSTM) architecture and the additional utterance vector representation is computed using a modified tree long short-term memory (LSTM) based architecture.


In one embodiment, the chat log is a transcript of a conversation between a plurality of participants.


These and other advantages of the invention will be apparent to those of ordinary skill in the art by reference to the following detailed description and the accompanying drawings.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 shows a framework for classifying dialogue acts in a chat log, in accordance with one or more embodiments;



FIG. 2 shows a method for classifying dialogue acts in a chat log, in accordance with one or more embodiments;



FIG. 3 shows a framework implementing one or more embodiments;



FIG. 4 shows an architecture implementing chat rooms, in accordance with one or more embodiments;



FIG. 5 shows a table of frequency counts of dialogue acts in a dataset used for experimentally validating embodiments described herein;



FIG. 6 shows a table comparing results of embodiments described herein against conventional models;



FIG. 7 shows confusion matrices comparing misclassifications of embodiments described herein against a conventional model;



FIG. 8 shows a table comparing classifications of dialogue acts predicted in accordance with embodiments described herein against a conventional model; and



FIG. 9 shows a high-level block diagram of a computer.





DETAILED DESCRIPTION

Embodiments described herein provide for the classification of dialogue acts in a chat log using directed-acyclic-graph long short-term memory networks (DAG-LSTMs). Such DAG-LSTMs are implemented with skip connections to incorporate contextual information from all prior dialogue acts in the chat log and prior dialogue acts from the same participant. Advantageously, by incorporating such contextual information, embodiments described herein provide of the classification of dialogue acts with higher accuracy as compared to conventional approaches.


Formally, a chat log U comprises a set of dialogue acts (or utterances) {uk}k=1K, of a chat sessions, where each dialogue act uk comprises a set of words {wtk}t=1T. Each dialogue act uk is generated by one of the participants pk∈P, where P denotes the set of participants in the chat session. Given the set of dialogue acts {uk}k=1K, embodiments described herein assign each dialogue act uk with a classification yk∈Y, where Y denotes the set of predefined classifications.


The classification of dialogue acts uk is formulated as a sequence modeling task solved using a variant of Tree-LSTMs. First, each word wtk of a dialogue act uk is mapped to a dense fixed-size word vector representation ωtk. Then, an utterance vector representation vk of the dialogue act uk is computed using an utterance model based on the set of word vector representations {ωtk}t=1T. Next, an additional utterance vector representation ϕk of the dialogue act uk is computed using a conversation model based on the utterance vector representation vk of the dialogue act uk, all previously computed utterance vector representations {vk}j=1k, and the prior utterance vector representation from the same participant, thereby contextualizing dialogue act uk and summarizes the state of the conversation at that point in time. The additional utterance vector representation ϕk is mapped to a classification yk using a classifier to classify the dialogue act.


In summary, classification of dialogue acts uk is performed based on the following operations:





ωt=WordLookup(wtk)






v
k=UtteranceModel({ωtk}t=1T)





ϕk=ConversationModel({vk}j=1T)






y
k=Classifier(ϕk)



FIG. 1 shows a framework 100 for classifying dialogue acts, in accordance with one or more embodiments. Framework 100 illustrates embodiments described herein implemented on a large scale messaging application. In particular, framework 100 shows architecture of a scalable system that provides dialogue act classification labels. FIG. 2 shows a method 200 for classifying dialogue acts, in accordance with one or more embodiments. FIGS. 1 and 2 will be described together. The steps of method 200 may be performed by one or more suitable computing devices, such as, e.g., computer 702 of FIG. 7.


At step 202, a chat log U comprising one or more dialogue acts {uk}k=1K, is received. As shown in framework 100 of FIG. 1, the dialogue acts may be dialogue acts 104-A, 104-B, 104-C, 104-D, 104-E, 104-F, and 104-G (collectively referred to as dialogue acts 104) generated by participants or users 102-A, 102-B, 102-C, and 102-D (collectively referred to as users 102, where the same reference number refers to the same user). As used herein, a chat log refers to a transcript of a conversation between a plurality of participants. The conversation may be in any format, such as, e.g., a messaging thread (e.g., instant messaging, direct messaging, social networking posts, text messaging, email, messaging boards posts, chat rooms, etc.), a spoken conversation (e.g., a telephone call, a video conference, etc.), or any other suitable format whereby a plurality of participants communicate with each other. The chat log may be received by loading the chat log from a storage or memory of a computer system or by receiving the chat log from a remote computer system.


Steps 204-210 of FIG. 2 will be repeated for each particular dialogue act uk of the one or more dialogue acts {uk}k=1K, in the chat log, starting from the first dialogue act u1 to the last dialogue act uK. Accordingly, during the first iteration, steps 204-210 are performed using the first dialogue act u1 as the particular dialogue act.


At step 204, each word wtk of the particular dialogue act uk is mapped to a word vector representation ωtk. For example, in framework 100 of FIG. 1, each word 106-A(1), 106-A(2), 106-A(3), 106-A(4), 106-A(5), 106-A(6), and 106-A(7) (collectively referred to as words 106-A) of dialogue act 104-A is mapped to a word vector representation 108-A(1), 108-A(2), 108-A(3), 108-A(4), 108-A(5), 108-A(6), and 108-A(7) (collectively referred to as word vector representations 108-A). Although not specifically identified in framework 100 for simplicity, words 106-B, 106-C, 106-D, 106-E, 106-F, and 106-G (collectively, together with words 106-A, referred to as words 106) are similarly mapped to word vectors representations 108-B, 108-C, 108-D, 108-E, 108-F, and 108-G (collectively, together with word vector representation 108-A, referred to as word vector representations 108). As shown in FIG. 1, words wtk include punctuation, such as, e.g., periods, question marks, exclamation points, commas, ellipses, etc.


A bidirectional LSTM is used to represent the particular dialogue act. Accordingly, let lstm({xj}j=1t) be recursively defined as follows:





lstm({xj}j=1t=steplstm(xt,lstm({xj}j=1t−1))  (Equation 1)





(ht,ct)=steplstm(xt,(ht−1,ct−1))  (Equation 2)


where the step function is defined such that:






h
t=sigmoid(Wixxt+Wihht−1+Wicct−1+bi)  (Equation 3)






f
t=sigmoid(Wfxxt+Wfhht−1+Wfcct−1+bf)  (Equation 4)






o
t=sigmoid(Woxxt+Wohht−1+Wocct+b0)  (Equation 5)






g
t=tan h(Wcxxt+Wchht−1+bc)  (Equation 6)






c
t
=f
t
⊙c
t−1
+i
t
⊙g
t  (Equation 7)






h
t
=o
t⊙ tan h(ct)  (Equation 8)


where W are weight matrices and b. are bias vectors. it, ft, and of are input, forget, and output gates, respectively, and ⊙ denotes elementwise product.


When the recurrence is defined in terms of the past (as in Equations 1-8), the LSTM is a forward directed LSTM, denoted {right arrow over (lstm)}. Alternatively, the LSTM may be defined in terms of the future, referred to as a backward directed LSTM and denoted custom-character:






custom-character({xj}j=1t)=stepcustom-character(xt,custom-character({xj}j=t+1t−1))  (Equation 9)





(custom-character,custom-character)=stecustom-character(xt,(custom-character,custom-character))  (Equation 10)


Concatenating {right arrow over (ht)} and custom-character results in a contextualized representation of word wtk inside the dialogue act uk:





({right arrow over (ht)},{right arrow over (ct)})={right arrow over (lstm)}({ωj}j=1t)  (Equation 11)





(custom-character,custom-character)=custom-character({ωj}j=1T)  (Equation 12)






custom-character=[{right arrow over (ht)},custom-character]  (Equation 13)


At step 206, an utterance vector representation vk of the particular dialogue act uk is computed based on the word vector representations ωtk. For example, as shown in framework 100 of FIG. 1, utterance vector representations 110-A, 110-B, 110-C, 110-D, 110-E, 110-F, and 110-G (collectively referred to a utterance vector representations 110) are computed based on respective word vector representations 108.


Contextualized representations of the word vector representations cot are (affinely) transformed into a feature space, which is then pooled across all the words in the dialogue acts:











υ
~

t

=



W
u




h
t




+

b
u






(

Equation





14

)






υ
=


max
t




υ
~

t






(

Equation





15

)







where max denotes the elementwise maximum across multiple vectors, Wu is the weight matrix, and bu is the bias vector. At the end of this operation, a single fixed size utterance vector representation v that represents the dialogue act u={wtk}t=1T.


At step 208, an additional utterance vector representation ϕk of the particular dialogue act uk is computed based on the utterance vector representation vk of the particular dialogue act uk. In one embodiment, the additional utterance vector representation is also computed based on utterance vector representations of all prior dialogue acts in the chat log and an utterance vector representation of an immediately prior dialogue act of the same participant. For example, as shown in framework 100 of FIG. 1, additional utterance vector representations 112-A, 112-B, 112-C, 112-D, 112-E, 112-F, and 112-G (collectively referred to as additional utterance vector representations 112) are computed based on respective utterance vector representations 110, utterance vector representations 112 of all prior dialogue acts 104 (shown as solid arrows between utterance vector representations 112 in FIG. 1), and an utterance vector representation of an immediately prior dialogue act of the same participant (shown as dashed arrows between utterance vector representations 112 of the same participant 102 in FIG. 1). In one example, additional utterance vector representation 112-B in FIG. 1 is computed based on utterance vector representation 110-B and utterance vector representation 112-A (i.e., utterance vector representations of all prior dialogue acts). In another example, additional utterance vector representation 112-E in FIG. 1 is computed based on utterance vector representation 110-E, utterance vector representations 112-A through 112-D (i.e., utterance vector representations of all prior dialogue acts), and utterance vector representation 112-A (i.e., the utterance vector representation of an immediately prior dialogue act of the same participant).


One approach for computing the additional utterance vector representation from a set of utterance vector representations {vk}j=1k is to use another LSTM model and feed the contextualized (given the history of past dialogue acts) utterance vector representations to a final classifier layer as follows:





kk)=lstmv({vk}i=1k)  (Equation 16)






ŷ
k=softmax(Wyϕk+by)  (Equation 17)






y
k=argmax ŷk  (Equation 18)


where Wy is a weight matrix, by is a vector, and ŷk denotes the predicted probability distribution over the dialogue act set Y.


In this approach, a conversation would be represented as a flat sequence of utterance with no information about which dialogue act is generated by which participant. In order to address this, skip connections are added between consecutive dialogue acts generated by the same participant. Accordingly, dialogue acts may have two antecedents: 1) all past dialogue acts, and 2) the past dialogue act from the same participant. Accordingly, the model can build up a user history and link each dialogue act to a user's particular history within a conversation. Dialogue acts from the same participant are also closer in the computation graph.


Accordingly, Tree-LSTM equations are utilized. Let tlstm({xη′}η′∈Sp(η)) denote a Tree-LSTM where η is a node in a given tree or graph, Sp(η) denotes the index set for the subtree (subgraph) spanned by η, and {xη′}η′∈Sp(η) denotes the nodes spanned by η. Then, the tlstm is recursively defined in terms of children of η, denoted ch(η), as follows:





tlstm({xη′}η′∈Sp(η))=steptlstm(xη,Uη′∈ch(η)tlstm(({xη″}η″∈Sp(η)))   (Equation 19)





(hη,cη)=steptlstm(xη,Uη′∈ch(η)(hη′,cη′))  (Equation 20)


where the step function is defined such that:






i
η=sigmoid(Wixxηη′∈ch(η)Wihe(η′,η)hη′+bi)  (Equation 21)






f
ηη′=sigmoid(Wfxxηη′∈ch(η)Wfhe(η′,η)e(η″,η)hη″+bf)  (Equation 22)






o
η=sigmoid(Woxxtη′∈ch(η)Wohe(η′,η)hη′+b0)  (Equation 23)






g
η=tan h(Wcxxtη′∈ch(η)Wghe(η′,η)hη′+bg)  (Equation 24)






c
η
=i
η
⊙g
ηη′∈ch(η)fηη′⊙cη′  (Equation 25)






h
η
=o
η⊙ tan h(cη)  (Equation 26)


where e(η′,η)∈E denotes the edge type (or label) that connects η′ to η. In general, E can be an arbitrary fixed size set. In one embodiment, E is of size two: 1) edges that connect all prior dialogue acts to a current dialogue act, and 2) edges that connect an immediately prior dialogue act from the same participant to the current dialogue act. Since weights are parameterized by the edge types e(η′,η), contribution of past dialogue acts and past dialogue acts from the same participant are computed differently.


It is noted that Tree-LSTM equations are applied even though the computation graphs are not trees but directed acyclic graphs (DAGs), since each node feeds into two parents (i.e., a next dialogue act and a next dialogue act from the same participant).


Since each node cell cη contributes to two other cells cη′ and cη″ additively, recursively unfolding Equation 25 for csink, the cell corresponding to the last dialogue act in the chat log, gives exponentially many additive terms of cη in the length of the shortest path from η and sink. This very quickly causes state explosions in the length of a conversation, which was experimentally confirmed. To address this, Equation 25 is modified as follows:










c
η

=



i
η



g
η


+


max


η




c


h


(
η
)








f

ηη





c

η










(

Equation





27

)







where max denote the elementwise maximum over multiple vectors, which effectively picks (in an elementwise fashion) a path through either one of the children. Thus, cell growth will be at worst linear in the conversation length. Since the modified equations are more appropriate for DAGs compared to Tree-LSTMs, the modified model is referred to as DAG-LSTM.


At step 210, the additional utterance vector representation ϕk is mapped to a classification yk of the particular dialogue act uk. For example, as shown in framework 100 of FIG. 1, additional utterance vector representations 112 are respectively mapped to a classification 114-A, 114-B, 114-C, 114-D, 114-E, 114-F, and 114-G (collectively referred to as classifications 114).


The additional utterance vector representation is mapped to a classification as follows:





kk)=daglstmv({vi}i=1k)  (Equation 28)






ŷ
k=softmax(Wyϕk+by)  (Equation 29)


At step 212, it is determined whether there are any dialogue acts remaining in the chat log. If it is determined that there is at least one dialogue act remaining in the chat log at step 212, method 200 returns to step 204 and steps 204-212 are repeated using the next dialogue act in the chat log as the particular dialogue act. Accordingly, steps 204-212 are repeatedly performed for each dialogue act in the chat log.


If it is determined that there are not any dialogue acts remaining in the chat log at step 212, method 200 proceeds to step 214 where the classifications of the dialogue acts are output. For example, the classifications of the dialogue acts can be output by displaying the classifications of the dialogue acts on a display device of a computer system, storing the classifications of the dialogue acts on a memory or storage of a computer system, or by classifications of the dialogue acts to a remote computer system.


While embodiments described herein are described for classification of dialogue acts, it should be understood that embodiments described herein may also be utilized for classification of emotions, sentiment analysis, thread disentanglement, or any other aspect of dialog modeling.



FIG. 3 shows an illustrative framework 300 implementing one or more embodiments described herein. In framework 300, a stateless service instance 302 is defined that will serve requests coming from posts from any chat root of a given instant messaging system. A request 304 is received by stateless service instance 302 (at arrow 1). Request 304 is a dialogue act defined by a chatroom number, a user, and the text of the dialogue act. Once request 304 is received, the dialogue act is represented as an utterance vector representation 306 (according to Equation 15). Stateless service instance 302 then determines an additional utterance vector representation 308 based on utterance vector representation 306 (from arrow 2.a), the last state 310 of the chatroom (input at arrow 2.b), and the last state 312 of the same participant in that chatroom (input at arrow 2.c). A response 314 (according to Equation 29) classifying the dialogue act is determined from additional utterance vector representation 308. The current state 316 of the chatroom (output at arrow 3.b) and the current state 318 of the participant (output at arrow 3.c), which are computed according to Equation 28, are output, for example, by saving the current state 316 of the chatroom and the current state 318 of the participant in a central state storage for other stateless service instances to retrieve if needed.



FIG. 4 shows an illustrative architecture 400 implementing one or more embodiments described herein. Architecture 400 shows how several chat rooms can be served using stateless service instances. This guarantees that the response of the system are dialogue act labels or classifications produced according to method 200 of FIG. 2. In addition, the instances being stateless guarantees that the system can linearly scale as more instances are added and the central state store scales accordingly.


Embodiments described herein were experimentally validated and compared with four baseline models. The first baseline model utilized convolutional neural networks (CNNs) for both dialogue act and context representation. The second baseline model utilized Bidirection LSTMs (BiLSMTs) for dialogue act representation and LSTMs for context representation. The third baseline model utilized CNNs for dialogue act representation and LSTMs for context representation. The fourth baseline model utilized BiLSTMs for dialogue act representation and had no context representation. Embodiments described herein were implemented with BiLSTMs for dialogue act representation and DAG-LSTMs for context representation. BiLSTMs were not utilized for context representation because such architectures are not suitable for live systems.


The evaluation of embodiments described herein against the baseline models was performed on a dataset comprising conversations from an online version of a game where trade negotiations were carried out in a chat interface. The dataset comprises over 11,000 utterances from 41 games annotated for various tasks, such as anaphoric relations, discourse units, and dialog acts. For the experimental evaluation, only the dialog act annotations were utilized. The dataset comprises six different dialogue acts, but one of those dialogue acts named Preference had very low prevalence (only 8 dialogue act) and was therefore excluded from the evaluation. FIG. 5 shows a table 500 of frequency counts for dialogue acts in the dataset.


The dataset was randomly split into three groups: a training group (29 games with 8,250 dialog acts), a dev group (4 games with 851 dialog acts), and a test group (8 games with 2,329 dialog acts). The dialog acts were tokenized using the Stanford PTBTokenizer and the tokens were represented by GloVe (Global Vectors for Word Representation) embeddings.


The Adam optimizer in the stochastic gradient descent setting was used to train all models. A patience value of 15 epochs was used (i.e., training was stopped after no observing an improvement for 15 epochs in the validation data) and each model was trained for a maximum of 300 epochs. The best iteration was selected based on the validation macro-F1 score. All models were hyperparameter-tuned using validation set macro-F1 using simple random search. A total of 100 experiments were performed to evaluate random hyperparameter candidates based on the following distributions (whenever applicable to a particular architecture):


Learning rate ˜10Uniform(−1, −3)


Dropout rate ˜Uniform(0, 0.5)


Word dropout rate ˜Uniform(0, 0.3)


Word vector update mode ˜Uniform{fixed, fine-tune}


# Units in utterance layer ˜Uniform{50, 75, 100, 200}


# Units in conversation layer ˜Uniform{50, 75, 100, 200}


# filters in CNNs ˜Uniform{50, 75, 100, 200}


Window size for CNNs ˜Uniform{2, 3, 4}



FIG. 6 shows a table 600 comparing results of embodiments described herein against the four baseline models. Table 600 summarizes results in terms of F1 scores for individual classes, overall accuracy, and macro-F1 score. The BiLSTM+DAG-LSTM architecture, in accordance with embodiments described herein, achieved the best F1 score for four classes. The overall accuracy of 87.69% for the BiLSTM+DAG-LSTM architecture is 0.86% better than the second best model (BiLSTM+LSTM). Likewise, the macro-F1 score of 75.78% for the BiLSTM+DAG-LSTM architecture is over 1% better than the next best model.


The owners of the dataset that was utilized for the experimental validation presented results using CRFs (conditional random fields) on a preliminary version of the dataset, which included dialog acts from only 10 games. The owner CRF model reported to have achieved 83% accuracy and a 73% macro-F1 score. Though these results are not directly comparable with the results shown in table 400, they are presented herein for context.



FIG. 7 shows confusion matrix 700 for a BiLSTM+LSTM architecture and confusion matrix 710 for a BiLSTM+DAG-LSTM architecture in accordance with embodiments described herein. Rows of matrices 700 and 710 denote the correct classifications while columns denote the predicted classifications, where darker shading represents a relatively higher mismatch count between the correct classification and the predicted classification. As shown in FIG. 7, the BiLSTM+DAG-LSTM architecture has less confusion correctly classifying offers, specifically by avoiding mistakenly classifying an offer as a counteroffer. This suggests that using additional context information provided by skip connections in accordance with embodiments described herein is helpful, since the dialog acts for offer and counteroffer are typically similar. The BiLSTM+DAG-LSTM architecture also has less confusion misclassifying refusal as other.



FIG. 8 shows a table 800 comparing classifications of dialogue acts (labelled as “conversation”) predicted using the DAG-LSTM architecture and the LSTM architecture against the correct classification to show errors made by the models. In the dialogue acts in table 800, it is again observed that the DAG-LSTM architecture, in accordance with embodiments described herein, has less confusion between offer and counteroffer classifications. It is also observed that both architectures failed to correctly classify some dialogue acts.


Systems, apparatuses, and methods described herein may be implemented using digital circuitry, or using one or more computers using well-known computer processors, memory units, storage devices, computer software, and other components. Typically, a computer includes a processor for executing instructions and one or more memories for storing instructions and data. A computer may also include, or be coupled to, one or more mass storage devices, such as one or more magnetic disks, internal hard disks and removable disks, magneto-optical disks, optical disks, etc.


Systems, apparatus, and methods described herein may be implemented using computers operating in a client-server relationship. Typically, in such a system, the client computers are located remotely from the server computer and interact via a network. The client-server relationship may be defined and controlled by computer programs running on the respective client and server computers.


Systems, apparatus, and methods described herein may be implemented within a network-based cloud computing system. In such a network-based cloud computing system, a server or another processor that is connected to a network communicates with one or more client computers via a network. A client computer may communicate with the server via a network browser application residing and operating on the client computer, for example. A client computer may store data on the server and access the data via the network. A client computer may transmit requests for data, or requests for online services, to the server via the network. The server may perform requested services and provide data to the client computer(s). The server may also transmit data adapted to cause a client computer to perform a specified function, e.g., to perform a calculation, to display specified data on a screen, etc. For example, the server may transmit a request adapted to cause a client computer to perform one or more of the steps or functions of the methods and workflows described herein, including one or more of the steps or functions of FIG. 2. Certain steps or functions of the methods and workflows described herein, including one or more of the steps or functions of FIG. 2, may be performed by a server or by another processor in a network-based cloud-computing system. Certain steps or functions of the methods and workflows described herein, including one or more of the steps of FIG. 2, may be performed by a client computer in a network-based cloud computing system. The steps or functions of the methods and workflows described herein, including one or more of the steps of FIG. 2, may be performed by a server and/or by a client computer in a network-based cloud computing system, in any combination.


Systems, apparatus, and methods described herein may be implemented using a computer program product tangibly embodied in an information carrier, e.g., in a non-transitory machine-readable storage device, for execution by a programmable processor; and the method and workflow steps described herein, including one or more of the steps or functions of FIG. 2, may be implemented using one or more computer programs that are executable by such a processor. A computer program is a set of computer program instructions that can be used, directly or indirectly, in a computer to perform a certain activity or bring about a certain result. A computer program can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment.


A high-level block diagram of an example computer 902 that may be used to implement systems, apparatus, and methods described herein is depicted in FIG. 9. Computer 902 includes a processor 904 operatively coupled to a data storage device 912 and a memory 910. Processor 904 controls the overall operation of computer 902 by executing computer program instructions that define such operations. The computer program instructions may be stored in data storage device 912, or other computer readable medium, and loaded into memory 910 when execution of the computer program instructions is desired. Thus, the method and workflow steps or functions of FIG. 2 can be defined by the computer program instructions stored in memory 910 and/or data storage device 912 and controlled by processor 904 executing the computer program instructions. For example, the computer program instructions can be implemented as computer executable code programmed by one skilled in the art to perform the method and workflow steps or functions of FIG. 2. Accordingly, by executing the computer program instructions, the processor 904 executes the method and workflow steps or functions of FIG. 2. Computer 902 may also include one or more network interfaces 906 for communicating with other devices via a network. Computer 902 may also include one or more input/output devices 908 that enable user interaction with computer 902 (e.g., display, keyboard, mouse, speakers, buttons, etc.).


Processor 904 may include both general and special purpose microprocessors, and may be the sole processor or one of multiple processors of computer 902. Processor 904 may include one or more central processing units (CPUs), for example. Processor 904, data storage device 912, and/or memory 910 may include, be supplemented by, or incorporated in, one or more application-specific integrated circuits (ASICs) and/or one or more field programmable gate arrays (FPGAs).


Data storage device 912 and memory 910 each include a tangible non-transitory computer readable storage medium. Data storage device 912, and memory 910, may each include high-speed random access memory, such as dynamic random access memory (DRAM), static random access memory (SRAM), double data rate synchronous dynamic random access memory (DDR RAM), or other random access solid state memory devices, and may include non-volatile memory, such as one or more magnetic disk storage devices such as internal hard disks and removable disks, magneto-optical disk storage devices, optical disk storage devices, flash memory devices, semiconductor memory devices, such as erasable programmable read-only memory (EPROM), electrically erasable programmable read-only memory (EEPROM), compact disc read-only memory (CD-ROM), digital versatile disc read-only memory (DVD-ROM) disks, or other non-volatile solid state storage devices.


Input/output devices 908 may include peripherals, such as a printer, scanner, display screen, etc. For example, input/output devices 908 may include a display device such as a cathode ray tube (CRT) or liquid crystal display (LCD) monitor for displaying information to the user, a keyboard, and a pointing device such as a mouse or a trackball by which the user can provide input to computer 902.


Any or all of the systems and apparatus discussed herein may be implemented using one or more computers such as computer 902.


One skilled in the art will recognize that an implementation of an actual computer or computer system may have other structures and may contain other components as well, and that FIG. 9 is a high level representation of some of the components of such a computer for illustrative purposes.


The foregoing Detailed Description is to be understood as being in every respect illustrative and exemplary, but not restrictive, and the scope of the invention disclosed herein is not to be determined from the Detailed Description, but rather from the claims as interpreted according to the full breadth permitted by the patent laws. It is to be understood that the embodiments shown and described herein are only illustrative of the principles of the present invention and that various modifications may be implemented by those skilled in the art without departing from the scope and spirit of the invention. Those skilled in the art could implement various other feature combinations without departing from the scope and spirit of the invention.

Claims
  • 1. A computer implemented method for classifying a dialogue act in a chat log, comprising: mapping each word of the dialogue act to a word vector representation;computing an utterance vector representation of the dialogue act based on the word vector representations;computing an additional utterance vector representation of the dialogue act based on the utterance vector representation; andmapping the additional utterance vector representation to a classification of the dialogue act.
  • 2. The computer implemented method of claim 1, wherein computing an additional utterance vector representation of the dialogue act based on the utterance vector representation comprises: computing the additional utterance vector representation based on utterance vector representations of all prior dialogue acts in the chat log.
  • 3. The computer implemented method of claim 1, wherein computing an additional utterance vector representation of the dialogue act based on the utterance vector representation comprises: computing the additional utterance vector representation based on an utterance vector representation of an immediately prior dialogue act of the same participant as the dialogue act.
  • 4. The computer implemented method of claim 1, wherein computing an utterance vector representation of the dialogue act based on the word vector representations comprises: computing the utterance vector representation of the dialogue act using a bidirectional long short-term memory (LSTM) architecture.
  • 5. The computer implemented method of claim 1, wherein computing an additional utterance vector representation of the dialogue act based on the utterance vector representation comprises: computing the additional utterance vector representation of the dialogue act using a modified tree long short-term memory (LSTM) based architecture.
  • 6. The computer implemented method of claim 1, wherein the chat log is a transcript of a conversation between a plurality of participants.
  • 7. An apparatus comprising: a processor; anda memory to store computer program instructions for classifying a dialogue act in a chat log, the computer program instructions when executed on the processor cause the processor to perform operations comprising:mapping each word of the dialogue act to a word vector representation;computing an utterance vector representation of the dialogue act based on the word vector representations;computing an additional utterance vector representation of the dialogue act based on the utterance vector representation; andmapping the additional utterance vector representation to a classification of the dialogue act.
  • 8. The apparatus of claim 7, wherein computing an additional utterance vector representation of the dialogue act based on the utterance vector representation comprises: computing the additional utterance vector representation based on utterance vector representations of all prior dialogue acts in the chat log.
  • 9. The apparatus of claim 7, wherein computing an additional utterance vector representation of the dialogue act based on the utterance vector representation comprises: computing the additional utterance vector representation based on an utterance vector representation of an immediately prior dialogue act of the same participant as the dialogue act.
  • 10. The apparatus of claim 7, wherein computing an utterance vector representation of the dialogue act based on the word vector representations comprises: computing the utterance vector representation of the dialogue act using a bidirectional long short-term memory (LSTM) architecture.
  • 11. The apparatus of claim 7, wherein computing an additional utterance vector representation of the dialogue act based on the utterance vector representation comprises: computing the additional utterance vector representation of the dialogue act using a modified tree long short-term memory (LSTM) based architecture.
  • 12. The apparatus of claim 7, wherein the chat log is a transcript of a conversation between a plurality of participants.
  • 13. A non-transitory computer readable medium storing computer program instructions for classifying a dialogue act in a chat log, the computer program instructions when executed by a processor cause the processor to perform operations comprising: mapping each word of the dialogue act to a word vector representation;computing an utterance vector representation of the dialogue act based on the word vector representations;computing an additional utterance vector representation of the dialogue act based on the utterance vector representation; andmapping the additional utterance vector representation to a classification of the dialogue act.
  • 14. The non-transitory computer readable medium of claim 13, wherein computing an additional utterance vector representation of the dialogue act based on the utterance vector representation comprises: computing the additional utterance vector representation based on utterance vector representations of all prior dialogue acts in the chat log.
  • 15. The non-transitory computer readable medium of claim 13, wherein computing an additional utterance vector representation of the dialogue act based on the utterance vector representation comprises: computing the additional utterance vector representation based on an utterance vector representation of an immediately prior dialogue act of the same participant as the dialogue act.
  • 16. The non-transitory computer readable medium of claim 13, wherein computing an utterance vector representation of the dialogue act based on the word vector representations comprises: computing the utterance vector representation of the dialogue act using a bidirectional long short-term memory (LSTM) architecture.
  • 17. The non-transitory computer readable medium of claim 13, wherein computing an additional utterance vector representation of the dialogue act based on the utterance vector representation comprises: computing the additional utterance vector representation of the dialogue act using a modified tree long short-term memory (LSTM) based architecture.
  • 18. The non-transitory computer readable medium of claim 13, wherein the chat log is a transcript of a conversation between a plurality of participants.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application claims the benefit of U.S. Provisional Application No. 63/016,601, filed Apr. 28, 2020, the disclosure of which is herein incorporated by reference in its entirety.

Provisional Applications (1)
Number Date Country
63016601 Apr 2020 US