The invention relates to a method of determining if an action requiring values can be performed based on a dialogue, in particular where the action is a routine invokable by an API call and where the dialogue is between a user and an automated agent, such as a chatbot. The invention also relates to a related system and computer program product. The invention also relates to a method of automatically determining a state structure for a dialogue tracking system, together with a related system and computer program product.
Dialogue systems, sometimes called conversational agents, are systems designed to converse with humans in natural language in a coherent way, typically in order to help the user achieve some goal. Uses of such systems include responding to customer questions, replying to queries regarding a knowledge base, automating help desk functions or providing technical support or training and education.
Conversational agents that both converse with users and autonomously take actions on their behalf are particularly challenging to build. One method for designing such conversational agents is though statistical dialogue systems, which maintain a distribution over multiple hypotheses regarding correct state of the dialogue, so as to be robust to complex requests by users stated using utterances that may be noisy or ambiguous. Quality of tracking of a correct dialogue state at different points in a conversation has a strong impact on achieving a high system-wide performance Dialogue systems comprise a dialogue state tracker (DST), which infers a user's intentions as a conversation progresses. DST systems represent the user's intention at a point in a conversation as a belief-state, composed of a set of slot-value pairs. Assigning a specific value to a slot reflects a constraint or requirement a user has.
For example, an automated subscription management system may allow creating, freezing or canceling subscriptions to various magazines, such as Sports, Arts or Science magazines. In this case, a person may have subscriptions to any subset of the magazines, and a subscription can be frozen for a month, a quarter (three months) or a whole year (assuming that a created subscription lasts until canceled, and that once a subscription is canceled, no magazines are sent until the user creates a new subscription). Thus, a conversational agent talking to a customer has to determine which action the user wants to take (create, freeze or cancel), which magazine they want to take the action on (Sports, Arts or Science); in the case of freezing a subscription, the agent must also determine the duration (a month, quarter or a year). A DST system for the above example domain might include three allowed actions: Create, Freeze, Cancel. Further, it is reasonable to track two slots: a Magazine slot (which can take the values Sports, Arts or Science), and a Duration slot (which can take the values Month, Quarter, Year, depending on how long the user wants to freeze the subscription for). The list of slots and the possible values each can take are referred to as the state-structure. This example is referred to throughout.
It is an object of the present invention to provide a way to automatically take actions based on dialogue.
An example conversation, along with the desired belief-state that a DST would ideally output at every point in the conversation, is provided in
A big shortcoming of the current approach for building DST systems is the lack of labelled data. Many firms do typically store historical logs of past conversations between human agents and customers. However, these conversations do not come annotated with the correct belief state at every point in the conversation. In order to get training data to build the DST, researchers have proposed using a Wizard-of-Oz approach. In this approach, a human domain expert first examines the historical chat logs to identify key slots to track through the conversation, and the values that these slots may take; the domain expert then constructs the full state-structure for the DST. Then, human annotators are asked to examine each conversation in the historical chat logs; they are asked to provide the belief-state at every point in each such conversation, under the state-structure specified by the domain expert. Such annotations are indicated on the right in
The above described approach is referred to as a “tight supervision” approach, as the machine learning system gets a supervision signal at every point in every conversation in the training set. As this tight supervision approach requires annotations to be done manually, it is very costly and does not scale. Furthermore, it restricts DST models from being easily generalizing across different domains.
In accordance with a first aspect of the present invention, there is provided a method comprising: receiving input of a dialogue; processing the dialogue by a neural network based system, to output, for each of a plurality of slots, a probability distribution over a range of values associated with the respective slot, the neural network based system being trained using a training dataset comprising a plurality of dialogues and, for each dialogue, a value corresponding to each slot, wherein each dialogue resulted in an action; determining, based at least on the probability distribution for each slot, if an action requiring a values for at least some of the slots can be performed; if not, causing continuing of the dialogue.
Thus, where the neural network based system is trained with such a dataset, it can be determined whether an action can be performed, for example a routine executed, based on the dialogue, and if the action cannot be performed, the dialogue system can be instructed to continue the dialogue. The method may be applied for each utterance input by a user.
The need to annotate training datasets is thus avoided.
The determining if the action can be performed may comprise: determining, for each slot, if one of the values can be selected based at least on the probability distribution and at least one selection criterion; determining if the action can be performed at least based also on a result of the determining if one of the values can be selected for each slot.
The method may further comprising: for each of the slots for which a value can be selected, selecting the value for the slot; and if the required values are selected, causing the action to be performed using the selected values.
For each slot, if a result of the determining is that no value can be selected for a slot, an indication that no value can be selected may be associated with the slot.
The selecting the values for the slots may comprise selecting the mode value of the probability distribution for the respective slot.
The at least one selection criterion may comprise determining if the probability distribution indicates that a probability score for the mode value meets a requirement for the extent to which the probability score for the mode value is greater than the probability score for other of the values.
The at least one selection criterion may comprise: determining, for each slot, a prior distribution of the values for that slot in the training dataset; determining, for each slot, a divergence value indicative of divergence of the probability distribution from the prior distribution; comparing the divergence value to a predetermined threshold value; determining that one of the values can be selected based on a result of the comparing.
The determining, for each slot, the divergence value, may comprise evaluating the Kullback-Leibler divergence between the prior distribution and the probability distribution.
According to the method, the action may have parameters, and each slot may correspond to a respective one of the parameters.
The determining if an action requiring at least some of the values can be performed may comprise determining if a value is selected for each of the slots.
The action may comprise an API routine.
The training dataset may comprise API calls data comprising the plurality of dialogues, for each dialogue, information indicative of each parameter, and, for each parameter a respective value, each of the values was recorded by a human agent when such a value was known to the human agent from the corresponding dialogue, and the human agent invoked an API call to the corresponding routine.
The neural network based system may comprise a recurrent neural network component and, for each slot, a respective classifier, wherein the processing the input dialogue comprises: generating word representation vectors for the dialogue; inputting the vectors into the recurrent neural network component, and outputting a further vector for each slot; processing, for each slot, the respective further vector, using the respective classifier, to generate the probability distribution for the values of the respective slot.
The determining, for each slot, if an action requiring at least one of the values can be performed may comprise: inputting a selected value or an indication that a value cannot be selected for each slot to a decision module; determining, by the decision module, to perform at least one of: causing the action to be performed, and the causing continuing of the dialogue by a non-person agent.
The method may comprise: determining, using the training dataset, the slots; determining possible values for each of the slots; setting the determined values for each slot as a range for that slot.
The method may further comprise: trained the neural network based system using the training dataset comprising a plurality of dialogues and, for each dialogue, the value corresponding to each slot, wherein each dialogue resulted in the action in the form of an API call invocation.
According to a second aspect of the present invention, a system may comprise: a neural network based system configured to: receive input of a dialogue; process the dialogue by a neural network based system; output, for each of a plurality of slots, a probability distribution over a range of values associated with the respective slot, the neural network based system being trained using a training dataset comprising a plurality of dialogues and, for each dialogue, a value corresponding to each slot, wherein each dialogue resulted in an action; a decision module configured to: determine, based at least on the probability distribution for each slot, if an action requiring a value for at least some of the slots can be performed; if not, causing continuing of the dialogue.
According to a third aspect of the present invention, a computer program product comprising computer program code stored on a computer readable storage medium, wherein, the computer program code is configured to, when run on a processing unit, perform the steps of: receiving input of a dialogue; processing the dialogue by a neural network based system, to output, for each of a plurality of slots, a probability distribution over a range of values associated with the respective slot, the neural network based system being trained using a training dataset comprising a plurality of dialogues and, for each dialogue, a value corresponding to each slot, wherein each dialogue resulted in an action; determining, based at least on the probability distribution for each slot, if an action requiring a value for at least some of the slots can be performed; if not, causing continuing of the dialogue.
In accordance with a fourth aspect of the present invention, there is provided a method of determining a state structure for API calls to a predetermined API, comprising: determining one or more slots of an API using past API calls data, wherein the API calls data comprises information indicative of one or more slots and a plurality of values for the or each of the parameters; determining a plurality of possible values for the or each slot; setting the determined values for each slot as a range for that slot.
The API calls data may comprise one or more parameters for an API, wherein the or each slot corresponds to a respective parameter, wherein the API calls data represents the one or more parameters and the plurality of values for the or each slot in a first format, the method further comprising converting the API call data to a second format, wherein the determining the one or more slots of the API and the plurality of possible values for the or each slot is performed using the API calls data in the second format.
The converting may comprise: inputting each API call in the first format using a trained neural network (RNN) based on a sequence-to-sequence model; processing each API call in the first format by the neural network and outputting each API call in the second format.
The trained neural network may comprise a recurrent neural network having an encoder-decoder architecture. The creating of the slot for each parameter and the setting of the determined values for each slot is performed using a parsing function.
In accordance with a fifth aspect of the present invention, there is provided a system for determining a state structure for API calls to a predetermined API, comprising: a determining unit configured to: determine one or more slots of an API using past API calls data, wherein the API calls data comprises information indicative of one or more slots and a plurality of values for the or each of the parameters; determine a plurality of possible values for the or each slot; set the determined values for each slot as a range for that slot.
In accordance with a sixth aspect of the present invention, there is provided a computer program product comprising computer program code stored on a computer readable storage medium, wherein, the computer program code is configured to, when run on a processing unit, perform the steps of: comprising: determining one or more slots of an API using past API calls data, wherein the API calls data comprises information indicative of one or more slots and a plurality of values for the or each of the parameters; determining a plurality of possible values for the or each slot; setting the determined values for each slot as a range for that slot.
For better understanding of the present invention, embodiments will now be described, by way of example only, with reference to the accompanying Figures in which:
Embodiments of the invention relate to a system configured to automatically determine values required to perform an action, and to determine whether the values required for the action have been automatically determined. Actions in the form of routines that can be caused to be performed by invocation of API calls to an external system are referred to herein, but embodiments of the system are not limited to such. Embodiments may be implemented in other systems where values required to perform an action are to be determined based on dialogue.
The term “utterance” is to be understood herein as an uninterrupted sequence of words. An utterance may be input as text by the user, or spoken, in which case the system includes a conversion module to convert the speech to text. In the context of the embodiments, a dialogue consists of alternating utterances by the user and provided by a computerised agent.
An API consists of stored protocols and routines for using the external system. An API routine name identifies a single routine that can be called. An invocation of that routine relates to a specific call to that routine and includes specific values for parameters of the routine that are passed to the routine.
For instance, the routine “Freeze” may be used to access a subscription management system to freeze a subscription, and take two parameters: “Magazine”, relating to the specific magazine (such as “Sport” for the Sports Magazine or “Art” for the Arts Magazine) and “Duration”, relating to the time frame to freeze the subscription for (such as “Month” for a single month, “Quarter” for three months or “Year” for a full year). An API call invocation may result from a GUI (graphical user interface) call. For instance, when manipulating the GUI, a user may select a specific magazine and time duration from drop-down menus, and click a “freeze subscription” button. This would result in an API call invocation for freezing a subscription. For example, a call for freezing a certain user's Sports Magazine for a month might look like “Freeze(Magazine=Sport, Duration=Month)”, where “Freeze” is the API routine name, and where “Magazine” and “Duration” are the names of the parameters and where “Sports”, and “Month” are the concrete parameter values in the call.
The routine requires values for certain parameters in order to execute the routine, which have to be provided. Accordingly, an API call to the external system for the routine has to identify a value for each of the parameters, as well as typically the routine. Embodiments of the invention relate to a state structure extractor (SSE). The SSE is configured to determine parameters required by the API and also a set of possible values for each of the parameters, using a corpus of API calls data of past calls to the API. Embodiments also relate to a system for determining, based on a dialogue, values for use in performance of an action and determining if required values for the performance of the action have been determined with acceptable certainty.
The SSE is configured to determine, based on the corpus of API calls data to the particular API, a state structure defining dialogue state tracking (DST) slots and possible values for each slot. Each of the slots corresponds to a respective parameter of the routine that was the subject of at least one API call. The possible values for each slot are referred to as the range of that slot. The corpus comprises dialogues and API calls data, where dialogue was between a user and a human agent, and resulted in the human agent causing an API call using parameter values that the human agent determined from the dialogue.
Referring to
However, there are many alternative formats for API calls which could be used; the delimiters may be different, parameters names and their values may be separated by other characters, and so on. For instance, API calls could be given as an XML under some schema, or in a JSON structure. When the API calls data is not provided in the canonical API format, the SSE is configured to convert API calls data into the canonical API as a prior step. This is achieved using a sequencer-to-sequencer conversion module in which the original API call data is input into the model and the canonical API format is output.
The state structure is denoted herein as a tuple R=(S, ƒ), which describes a set of slots to be tracked in a conversation, and values that each slot can take. The set of slots is denoted as S={s1, . . . sk}. For a slot si, which can take di different values, different possible values that the slot si can take are denoted as Vi=vi,1, vi,2, . . . , vid
In some implementations, in which it may be wanted to indicate the user has not, in the dialogue, expressed a desire or a constraint for a certain slot. In this case, the range of a slot may include an indicator Ø indicating that the user has not yet expressed an intent regarding this slot.
If the user has indicated in the dialogue that any value for a particular slot is acceptable to them, the SSE is configured to assign a value A to that slot indicative of such.
In the canonical format, each API call is represented by a respective routine, in association with each parameter for the routine and a value for each parameter. This may be represented, for example, as
Routine(param1=v1;param2=v2, . . . ,paramu=vu)
The term “routine” relates to the name of the called routine, “parami” is the name of the “i” th parameter, and vi is the value passed to this parameter.
For example, given an API data set of the form:
freeze−subscription(duration=month;magazine=art)
freeze−subscription(duration=quarter;magazine=sports)
freeze−subscription(duration=year;magazine=cooking)
The state structure becomes:
action:[freeze−subscription]
duration:[3;7;4]
magazine:[art;sports;cooking]
Formally, given an API routine r, the set of API calls to the routine r in the corpus of API calls is denoted as Ar=(c1, c2, . . . , cn
The SSE is configured to create one slot for every parameter. Given a routine r and its set Ar of API calls in the data as defined above, creation of the u slots is denoted (where u is the number of parameters observed in calls to r) as follows:
s
r,1
:=p
1
;s
r,2
:=p
2
, . . . ,s
r,u
:=p
u
where sr,j denotes the j'th slot created for routine r, and where the symbol “:=” is used to denote a creation of a slot (where the name of the slot sr,j is the same as the name for the j'th parameter in the call to routine r).
The SSE is also configured, after creating the slots Sr=(sr,1, sr,2, . . . , sr,u) for routine r, to generate the ranges for each slot. The SSE sets the range for each slot to be a union of all the values observed in the corpus of API calls data. The range generated for slot sm (i.e. the range for the m'th slot created for routine r) is denoted by Vs
where yj,k denotes the value passed to the k'th parameter in the j'th call to routine r in the corpus of API calls Ar, and where the symbol Ør,k is a special value indicating that no constraint has yet been specified for parameter k of routine r.
Given a corpus containing API calls over the c routines I=(r1, r2, . . . , rc), where routine ri has ui parameters, all the slots can be created for all the routines. Sr
where sr
S=∪
r∈I
S
r
=(sr
For each slot j (which relates to some parameter) of each routine ri, a range is generated where Vr
The final dialogue state structure is denoted as: D=(S, ƒ) where the slots are S as defined above, and where ƒ(sr
The trained sequence-to-Sequence (“Seq2Seq”) conversion module is configured to convert previously unobserved API call formats to the canonical format. In an alternative embodiment, an algorithm may be provided configured to convert a specific API call format to the canonical format.
The API calls data in a non-canonical format comprise text, in the form of strings of symbols (including at least letters and numbers). Referring to
The encoder and decoder have recurrent neural network (RNN) architectures. The RNN may include long short term memory (LSTM) or gated recurrent unit (GRU) cells. Alternatively, a feedforward neural network architecture may be used in place on an RNN architecture, although the outputs may be less accurate particularly for longer sequences.
In an example a set of input symbols is denoted by A, and an input sequence is denoted by (x1, x2, . . . , xn), where each element is a symbol (i.e. xiϵA for all i). Given a required hidden size d, a recurrent neural network (RNN) design iteratively processes the input text to yield a low dimensional embedding htϵRd by applying a cell function c: A×Rd→Rd; the RNN iterates over the equation: ht=c(xt,ht−1).
Given the RNN hidden states {ht}t−1n an output ytϵRk (with k denoting the output's dimensionality) is produced at every timestep, by applying a transformation function g:Rd⇒Rk.
The Seq2Seq conversion module is trained using a historical training set. The historical training set comprises an input sequence, denoted by ai, and an output sequence, denoted by bi. The encoder is referred in the following as RNN E and the decoder is referred to as RNN D. The RNN E is configured to receive an input sequence a=(x1, . . . , xn) and to yield the hidden states (h1, . . . , hn). The final hidden state of the RNN2 hn is then copied as the first hidden state of the decoder.
During training the decoder RNN D receives as an input the ground truth output text shifted by one location, b=(s; z1, . . . , zn) (where s is a special start symbol); at every timestep t the decoder yields a decoder hidden state h′t and an output yt, where the dimensionality of yt is chosen so that yt encodes a distribution over the words in a vocabulary. The desired output from the decoder after digesting the t'th ground truth output word zt is a probability distribution placing most of the probability mass on the next ground truth word zt+1.
The encoder and decoder are jointly trained so that once the encoder receives text as input, the decoder will produce the desired output (predicting the next ground truth word at every timestep). A loss function used for training is the sum of the softmax cross entropy losses between the output distribution and the one-hot encoding of the correct word. Given a vocabulary V, the decoder input at time t is denoted as s for t=1 and zt−1 for t>1, and the decoder output is denoted at time t as yt=(rt1, rt2, . . . , rt|V|) This is transformed into a normalized distribution as ut=(ut1, ut2, . . . , ut|V|) by applying the softmax operator
The target output word at time t is zt, and its “one-hot” encoding is denoted as
α(zt)=(αt1, . . . ,αt|V|)
Where αti=1 for i=zt and at =1 elsewhere (i.e. if zt is the k'th word in the vocabulary, then α(zt) is a vector with all coordinates set to 0 except in the k'th location, where it is set to 1). The overall loss is the cross entropy loss between ut and α(zt) along all the timesteps:
=−Σt=1nΣi=1|V|αti log uit.
The seq2Seq model may be trained by applying a variant of stochastic gradient descent (SGD) backpropagation over a training set consisting of inputs and their ground truth outputs. Training results in setting parameters of the encoder and decoder RNN cells so as to achieve a low loss.
The training data to train the Seq2seq model may be prepared by a human. For example, a state structure may have three slots, and each slot may have 10,000 values. To create the training data, values are sampled to fill their respective slots. A list of different symbols are used as delimiters, parenthesis, etc. These are uniformly sampled to create the structure of each x. The targets (y) may be simultaneously created with each x, by simply placing the slots and values in a constant canonical format. The x's and y's are illustrated in
Referring to
At step 402, the SSE determines slots for the or each routine using the API calls data in the canonical format. This is achieved by scanning the calls data and identifying the parameters of each routine, and creating and storing a slot for a parameter each time that a new parameter is identified.
At step 404, the SSE determines a set of possible values for each slot, that is, the range of each slot. This is achieved by scanning the values in the API calls data for each parameter and, each time a new value is found, storing the value in association with the slot for that parameter.
The system comprises a DST and a decision module in the form of a “strategy network”. The DST is configured to receive the state structure and a dialogue as inputs and to predict values for each slot in a state structure. The DST is configured to output a prediction for each slot, yielding an element:
T=V
r
,1
×V
r
,2
× . . . ×V
r
,u
×V
r
,1
×V
r
,2
× . . . ×V
r
,u
× . . . ×V
r
,1
×V
r
,2
× . . . ×V
r
,u
where “x” denotes a Cartesian product. A probability distribution
is required for each slot sr
and the mode of this distribution is output as the prediction (or the value; indicating no constraint if the distribution fails the tests described below). Thus, any element of the set T is a valid possible DST output.
The strategy network is configured to use the values predicted by the DST and to determine whether a routine can be executed or if more information is needed. The the DST and the strategy network, and their operation, are described in detail in the following.
The system is coupled to a dialogue system, for example a chatbot engine. Components of a dialogue system may include an automatic speech recognition module (for cases where the dialogue is voice based rather than chat based), a natural language understanding unit for obtaining semantic information for utterances or parts of the conversation (name identification, part of speech tagging, semantic parsing), a dialogue manager which keeps the history and state of the dialogue and manages the flow of the conversation, and an output generator which produces utterances for continuing the conversation. Detailed description of the dialogue system is outside the scope of this description. The dialogue system may be a chatbot.
Referring to
The RNN is configured to receive an utterance and to output a dense numerical vector representation of the utterance in a latent space. For example, the RNN may be a bidirectional long-short term memory (LSTM) RNN.
Each such DST head is configured to receive the numerical vector representation produced by the RNN, and to output a prediction regarding the correct value for the slot. Each DST head is in the form of a simple classifier; for example each DST head may be configured to classify the vector using a logistic regression to output a probability distribution over the range of each slot in the state structure, or use a feedforward neural network configured to receive the vector and to output the probability distribution. Alternatively, other kinds of classifier may be used.
Preferably, the dialogue is processed by the DST immediately following receipt of a new utterance from the user. This means that the conversation need only continue for the least time necessary, since the dialogue can be ended after the strategy network determines that there is sufficient information to execute a routine. However, the DST can also receive as inputs a prefix of a conversation, or an entire conversation, C.
Before it can be used, the DST is trained using the API calls data. This is the same API calls data from which the state structure was extracted by the SSE, although, to train the DST, dialogue associated with each API call from that API calls data is also used. The data consists of pairs (g; s) where g is a text representing a conversation or a part of it, and where s is a belief-state structure adhering to the state structure (i.e. s assigns a value for every slot from the range of that slot)
The training set uses conversations along with their API call invocation. A conversation c is a sequence of utterances, denoted as ui, and API call invocations, denoted as ai. For instance, a possible conversation could be c=(u1, u2, u3, u4, a1, u5, u6, a2, u7, u8) (where locations 1, 2, 3, 4 are utterances, location 5 is an API call invocation, locations 6 and 7 are utterances, location 8 is an API call invocation and locations 9 and 10 are utterances). t(c) denotes the set of indices where an API call occurs, so in the above example we have t(c)={5, 8}. pi(c) denotes a prefix of the conversation up until (but not including) index i; for instance, in the above example p5(c)=(u1, u2, u3, u4) and p8(c)=(u1, u2, u3, u4, a1 u5, u6). For a set of indices J, we denote by PJ (c) the set of all conversation prefixes up until each of the indices in J (i.e. every prefix of c ending in an index from J). Thus, Pt(c)(c) is the set of prefixes ending in (but not including) API calls (and in the previous example, Pt(c)(c)={p5(c), p8(c)}.
At every point in a conversation where an API call is executed, we can obtain a ground-truth supervision for the correct belief-state at that point in the conversation, by converting the API call invocation to its canonical format and extracting the passed parameter values as described above. For every API call invocation a occurring in an index j of a conversation c a training instance (g, s) where g=Pj(c) (the prefix up until the API call), and where s is the belief-state 5 In extracted from the API call invocation. Thus, for a conversation c containing multiple API call invocations, we generate multiple training instances with the prefixes Pt(c)(c) along their respective belief-states. By applying this process to all the conversations in the training set, the DST training set is obtained.
Following the training, the DST can receive as an input a previously unobserved conversation (or part of a conversation) and predict the correct value for each slot.
Preferably, both the encoder RNN and DST heads are trained simultaneously. The loss of a single DST head is a softmax cross-entropy, the standard classifier loss. The overall loss of the network is the sum of the losses across all the slots (the sum of the DST head losses). Co-training the encoder and DST heads makes the network generate a latent embedding that is expressive with respect to slot values (and to ignore information that does not pertain to any of the slots).
By way of specific example, the encoder may be a bidirectional RNN with LSTM cells, and each DST head may be a small feedforward network with one hidden layer. The DST head for a slot S with a range V may have the form:
In the above equations, cenc is an RNN cell such as an LSTM cell, hi is the i'th hidden state of the encoder network, which is digesting a text sequence consisting of T utterances denoted (u1, u2, . . . , uT); Wi is a parameter weight matrix for slot i of dimension d×|Vi| (with d denoting the hidden layer size of the RNN cell), and where σ(x) denotes the sigmoid function
The output Πs=(π1, π2, . . . , π|V|) forms a normalized distribution over the range V of the slot s.
The softmax cross entropy function may be used to calculate the loss for a single head for the slot s using:
The index g above relates to the training instance g, so πg,i is the distribution associated with the i'th value for the slot s when feeding in the training instance g, and where yg,i is an indicator variable denoting the ground truth value for the slot (i.e. yg,i=1 for the value i which is the correct value for the slot s on the training instance g, and yg,i=0 otherwise). The overall loss for the DST network is the sum of the head losses across all slots (and across the fed training instances):
where G denotes the training instances used for the training procedure, and where S is the set of all tracked slots.
During training, model parameters may be iteratively tuned after examining mini-batches of training set instances, by applying backpropagation, for example by stochastic gradient descent with an Adam optimizer.
The DST system, for a state structure R=(S, ƒ) takes an input a conversation, as indicated at 600 in
The DST head then processes the representation vector to generate a probability distribution over the range of that slot at 604. Thus, given a conversation C, for every sentence in the conversation, for every slot si the DST outputs a probability distribution πi over the range of si, i.e. list of values:
(πi(vi,1),πi(vi,2), . . . ,πi(vi,d
Where, for any j∈{1, 2, . . . , di}, πi,j(vi,j)≥0 and for any slot si we have Σj=1diπi(vi,j)=1
The DST then determines a mode of the probability distribution for each slot at step 606.
The DST then determines whether a first selection criterion is met for the mode value for each of the slots at step 608 and 610, to determine if the mode value has been determined for the slot with an acceptable degree of certainty. If the probability distribution for the slot is heavily weighted towards a particular one of the possible values for a slot, this value is determined to be the correct one for the slot (proceed to step 612); if the probability distribution is spread across several of the possible values, indicated by not having an obvious “peak” for the model's output probability distribution, the DST system determines that a value has not been determined for the slot. In this case, an indication of no value is assigned to the slot (step 614).
The purpose of applying the first selection criterion is to address a problem that the DST's RNN and the DST head have been trained with the API data sets where values have been specified for all slots, and thus have not been trained with data sets where a value is unspecified. Accordingly, the DST will not make a prediction that a value the slot is unspecified.
The first selection criterion requires examining the distribution to determine that it places significant mass on the mode value, so maxj=1d
The DST also applies at step 612 a second selection criterion to determine that the reason that the probability distribution is heavily weighted towards a slot is due to the additional information gained after examining the dialogue, rather than information regarding the prior distribution of the values of the slots.
A priori, without even examining the input dialogue to the DST task, some values are more likely to occur than other values for a slot. For instance, referring to the example above, if 80% of the dialogues regarding subscriptions relate to the Sports magazine (and only 20% are regarding other magazines), the magazine slot is far more likely to take the value sport than the other values.
The prior distribution over the possible values can be computed over the possible values {vi,1, vi,1, . . . , vi,d
The prior distribution over the values slot si can take is denoted as Qi=(qi,1, qi,2, . . . , qi,d
Determining whether the second selection criterion is met requires examining the degree to which the posterior distribution differs from the prior distribution Q by evaluating the Kullback-Leibler divergence DKL(Πi∥Qi) between them. The Kullback-Leibler divergence DKL(Πi∥Qi) is a measure of the amount of information gained in the posterior model distribution Πi relative to the prior probability distribution Qi, and is defined as:
A high the value of DKL(Πi∥Qi) indicates that the prior and posterior distributions are very different, indicating that the reason for the certainty for the value of si is the dialogue; a low value indicates that the reason for the certainty is the information known a priori, with the dialogue contributing little to no new information. If DKL(Πi∥Qi<β for some threshold parameter β, the A value of β=0.05 has been used in inventor experiments.
If both the first and second selection criterion are met, so both maxj=1d
In an embodiment, the prior distribution may be uniform, so
every value for this slot is equally likely a priori and the divergence value is:
As Π is a probability distribution over the values Vi that the slot can take
denotes the Shannon entropy of the distribution Πi.
In variant embodiments, other ways of determining a divergence value may be used in determining whether one of the values should be selected for a slot from the range of possible values for that slot. Other selection criteria may also be used generally.
If the second selection criterion is met, the selected value for the slot is passed to the strategy network. Otherwise, an indication of that a value has not bee assigned is allocated to the respective slot at step 616.
The strategy network is configured to determine whether a routine can be executed based on the determined values and either to cause an action relating to the routine, such as invocation of an API call to that routine, or to cause the dialogue system to continue the dialogue with the user. Such an action may simply be communication to a human agent of the determined values and that the routine is able to be executed.
A routine may require values to have been determined by the DST system for all of the parameters of the routine. As described above, one or more slots may have an indication in the form of a value Ø, indicating that no value is assigned to the slot. If a routine requires a slot to have a value and the value for that slot is Ø, then that routine cannot be performed and further dialogue is required.
Alternatively, values may be essential for some parameters and not others, and in this case the strategy network is configured to determine that the routine can be executed if essential values are output from the DST system.
In a variant embodiment, the strategy network may determine whether each of at least two routines can be executed based on the determined values. In this case, the strategy network can be configured to cause execution of any one or more of the routines for which required values are output by the DST system, and optionally instruct the dialogue system to continue the dialogue with the user. Alternatively, if the strategy network causes execution of any routine, or any particular one or more routines, the strategy network may also be configured to instruct the dialogue system that there is no more need for information and the dialogue can thus be ended.
The strategy network may be configured to determine whether any of the slots for which values are required by the routine can be executed using algorithms.
In the embodiment indicated in
The neural network is a feedforward neural network, although other kinds of neural network may be used. For instance, an implementation with one hidden layer would be applying a linear transformation followed by a sigmoid non-linearity to get the hidden layer h=α(W1a+b1), then applying another linear transformation followed by a sigmoid nonlinearity to obtain the outputs h=σ(W2a+b2), where W1, W2 are matrix parameters and b1, b2 are vector parameters to be learned during training. The loss of this neural network is the softmax cross-entropy loss with the ground truth (the identity of the executed routine, or the value specifying that no routine was called), similarly to the loss of the DST heads.
The neural network is configured with an output to indicate that there is insufficient values for the routine to be performed, and an output to indicate that there are the required values for the routine. Where more than one routine may be called, there may be an output corresponding to each routine. The strategy network is configured to indicate to the dialogue system if dialogue with the user should be continued. If the conversation state is not properly constrained, then the conversation agent continues the dialogue with the customer, asking for information until the missing constraints are filled. Formally, the strategy network is denoted by y=softmax(V·OT+b)
where V is a weight vector of length
and b,y∈IR, and softmax is the softmax operator over some vector v, producing v′:
where v′=[v′1, . . . , v′m] is a probability distribution.
Referring again to
Given the context of the conversation and outputs from the DST, the strategy network infers whether the state space is properly constrained i.e. if the system has learned enough information from the user to issue an API call.
The neural network can be trained by taking historical conversations and creating a training instance qu=(a,t) for every utterance u in each such conversation. If an API call was not executed following the utterance u, the correct SN output t is conversing (not invoking an API call), and if an API call was executed, it is the identity of the executed routine. The training instance's input a is the DST's belief-state following the utterance u (i.e. the belief-state after the DST ingesting the prefix of the conversation ending with the utterance u). The SN can then be trained using backpropagation (applying stochastic gradient descent), similarly to the DST neural network.
The processes described above are implemented by computer programs. The computer programs comprise computer program code. The computer programs are stored on one or more computer readable storage media and may be located in one or more physical locations.
The computer programs may be implemented in any one or more of a number of computer programming languages and/or deep learning frameworks, for example Pytorch, TensorFlow, Theano, DL4J. When run on one or more processors, the computer programs are configured to enable the functionality described herein.
As will be apparent to a person skilled in the art, the processes described herein may be carried out by executing suitable computer program code on any computing device suitable for executing such code and meeting suitable minimum processing and memory requirements. For example, the computing device may be a server or a personal computer. Some components of such a computing device are now described with reference to
The processor 702 may be a conventional central processing unit (CPU). The processor 702 may be a CPU augmented by a graphical processing unit (GPU) to speed up training. Tensor processing units (TPU) may also be used. The computer readable storage media 704 may comprise volatile and non-volatile, removable and non-removable media. Examples of such media include ROM, RAM, EEPROM, flash memory or other solid state memory technology, optical storage media, or any other media that can be used to store the desired information including the computer program code and to which the processor 702 has access.
As an alternative to being implemented in software, the computer programs may be implemented in hardware, for example GPU, CPU or special purpose logic circuitry such as field programmable gate array or an application specific integrated circuit such as a TPU. Alternatively, the computer programs may implemented in a combination of hardware and software.
Embodiments of the invention are not limited to use with any particular kind of API. The API may be, for example, a web API or a Java API.
It will be appreciated by persons skilled in the art that various modifications are possible to the embodiments.
The applicant hereby discloses in isolation each individual feature or step described herein and any combination of two or more such features, to the extent that such features or steps or combinations of features and/or steps are capable of being carried out based on the present specification as a whole in the light of the common general knowledge of a person skilled in the art, irrespective of whether such features or steps or combinations of features and/or steps solve any problems disclosed herein, and without limitation to the scope of the claims. The applicant indicates that aspects of the present invention may consist of any such individual feature or step or combination of features and/or steps. In view of the foregoing description it will be evident to a person skilled in the art that various modifications may be made within the scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
1713746.4 | Apr 2017 | GB | national |