In the literature on artificial dialogue agents, a distinction is often made between “goal-oriented” dialogue, where an agent is tasked with filling slots or otherwise obtaining or disseminating specified information from the user to help complete a task, and open-domain “chit-chat”, where an agent should imitate human small talk. Modeling goal-oriented dialogue can have advantages over chit-chat imitation as it gives clearer metrics of success and perhaps more meaningful learning signals; but goal-oriented dialogue data is often more specialized, covering only a narrow slice of natural language. Current goal-oriented datasets study settings like booking restaurants or airline tickets, or obtaining weather information, as standalone tasks (Raux et al., 2005; Henderson et al., 2014; Bordes et al., 2017; El Asri et al., 2017; Budzianowski et al., 2018). Chit-chat agents, by contrast, might focus on coarse statistical regularities of dialogue data without accurately modeling the underlying “meaning”; but the data often covers a much wider space of natural language. For example, Twitter or Reddit chit-chat tasks (Li et al., 2016a; Yang et al., 2018; Mazaré et al., 2018) cover a huge spectrum of language and diverse topics. Chit-chat and goal-oriented dialogue are not mutually exclusive: when humans engage in chit-chat, their aim is to exchange information, or to elicit specific responses from their partners. Modeling such goals, however, is made difficult by the fact that it requires large amounts of world knowledge, and that goals in real life are implicit.
In this work, we introduce a family of tasks that bridge the divide between goal-oriented and chit-chat dialogue, combining clearer metrics and learning signals on the one hand, with the richness and complexity of situated but open-domain natural language on the other. The tasks are set in a multi-player text-based fantasy environment (Urbanek et al., 2019) with grounded actions and reference objects. Given a particular character to play in a particular scenario (location, set of objects and other characters to interact with), an agent should conduct open-ended dialogue with the aim of persuading their dialogue partner to execute a specified action. The action could be an emote (smile, laugh, ponder, etc), or a game action (wear chain mail, drink mead, put glass on table, etc). The richness of the environment means that there are a huge set of possible tasks and scenarios in which to achieve a wide range of actions. We plan to make our entire setup, code and models publicly available.
We train a variety of baseline models to complete the task. We compare agents trained to imitate human actions given a goal (an “inverse model”) to two different RL approaches: optimizing actions with latent discrete variables (topics), or via rewarding actions sampled from the model (via the top- outputs). We show that both types of RL agent are able to learn effectively, outperforming the inverse model approach or the chit-chat imitation baseline, and can converse naturally with their dialogue partner to achieve goals.
In short, our main contributions are: a new family of tasks that combines goal-oriented dialogue and chit-chat in a rich, fully realized environment, and the results and analysis of scalable RL algorithms and behavioral-cloning models (and simple heuristic methods) on these tasks.
2 LIGHT Game Environment
We work in the LIGHT game environment (Urbanek et al., 2019), which is a multi-user text-based game. Characters can speak to each other via free text, send emote actions like applaud, nod or pout (22 emote types in total), and take actions to move to different locations and interact with objects (e.g. get cutlery, put cutlery in drawer, etc.), see Appendix B for a full list of game actions.
The game engine itself is formally defined as a graph, where each location, object and character is a node, and they are connected by labeled edges, for example contained-in, path-to or has-property. Actions in the game result in changes in state of the graph. To a player (agent) a local view of the graph can be seen expressed as text, as are the game actions and changes of state. This text then naturally interleaves with the dialogue utterances of the speakers as well to form an input context sequence from which a character can base their subsequent actions. See Appendix Figure 3 for an example episode of interactions between two humans in a given environment.
To make the world and its textual descriptions, LIGHT consists of a large set of human-written game locations, characters, and objects, all based within a fantasy medieval setting. Their names, descriptions and properties were crowd-sourced, yielding a total of 663 locations, 1755 characters, and 3462 objects. They range from beaches with crabs and seaweed to crypts with archaeologists and coffins, yielding an extremely rich environment for agents to learn within.
Crowdworkers were then asked to play the role of characters within the game. This involved them making utterances, game actions and emotes, while interacting with each other (in pairs). The resulting gameplay data consists of 10,777 episodes with an average of 18.3 actions each of rich human play. These are split into train (8538), validation (500) and test (1739) portions, the latter being split into new episodes in existing settings (test seen, 1000) and completely new settings (test unseen, 739). Players were not given specific goals, but instead asked to play the role convincingly of the character given, during play some of them effectively defined their own goals during the interactions, see Appendix Figure 3. Existing work (Urbanek et al., 2019) does not consider using this data to learn goal-based tasks, but instead has only used this for chit-chat and action imitation learning.
The tasks we introduce in this work involve achieving open-domain goals during interaction between two agents in a given LIGHT scenario. One of the agents, which we will call the “environment agent” and write in symbols as , together with the game engine, effectively functions as an environment for the other agent, which we will write . We assume that the environment agent is fixed; in this work it will be a model trained via behavioral cloning from human-human interaction data. must conduct open-ended dialogue such that a given goal action is executed in the future by the environment agent.
More formally: the two agents and are given their views of the scenario ( and respectively). These consist of the setting name, scenario description, character names, and their own persona, all described as a sequence of text (see Fig 1). Note that each agent can only access their own persona but not the persona of the partner with whom they are conversing, but they do know the name of their partner. Denote by the time-step of the environment, and the utterances of the agents and respectively, and denote by the environment actions by . Hence the interaction sequence looks like
The agent is additionally given a persuasion goal to achieve. That is, the objective of is for to take the action . An episode ends when or when becomes larger than a set number of turns.
We experiment separately with two different types of goals: game actions and emote actions. We use the same train, valid, test (seen and unseen) split of the original human-human LIGHT episodes, assign roles and randomly, and randomly pick an action by that occurs in the episode as the goal. We can then present the corresponding setting to our agents in order to form a new interaction, but within the same scenario and with a goal that was naturally desirable and achievable within that setting.
In our experiments, only speaks, it does not perform game or emote actions. This was chosen in order to study grounded dialogue between agents; it guarantees that the player cannot force the goal to be reached by performing actions itself. It has to produce appropriate utterances such that eventually takes the action .
The state observation at time given to a model consists of the agent’s setting description (), the utterance and action history up to that time step (), and the agent’s goal (). Our models for consume as a flattened sequence of tokens, and return a dialogue utterance . Each structured component is represented in the flattened sequenced separated by a special token denoting the types, e.g. names, settings, etc., see Fig. 1.
3.1 Reinforcement learning formulation
Our task set-up can be easily framed as a Markov decision process. Because the entire history and goal is given to, the environment is Markovian. For the reward, we can give a terminal reward of +1 only if the goal is achieved and 0 otherwise, i.e, it is +1 if the environment agent takes the goal action . The episode ends after steps. In our experiments we consider and .
When we formulate our tasks as a reinforcement learning problem, we will also refer to as the “RL agent”.
In this section we describe the models for and . In this work these are retrieval models, using the LIGHT dialogue training corpus as candidates (111k utterances). We leave generative models to future work.
Base agent architecture
For all our models we adopt the same base architecture, which is a 12-layer bidirectional transformer (Vaswani et al., 2017) pre-trained on a large dialogue corpus (Reddit, 174M examples), and then fine-tuned on our task. To score retrieval candidates, we use a bi-encoder as in (Humeau et al., 2019; Urbanek et al., 2019)
. That is, two transformers are used, one to encode the context, and another to encode a candidate response, and a dot product between the first output vector of each scores the match. To produce a dialogue utterance, we take the utterance with the largest score from the training set candidates (111k in this case). The same procedure is followed for actions and emotes. For actions, the candidates are the set of admissible actions at that game state, which are provided by the game engine, for exampleget apple is only available in the candidate set if it is a valid action (an apple is present in the room). For emotes, all 22 candidates are always available. To train the model, a cross entropy loss is used. Similar to Mazaré et al. (2018), during training we consider the other elements of the batch as negatives.
The environment agent is the base agent described above, and stays fixed over episodes where an RL agent is trained. This helps guarantee our RL models stick to using the semantics of natural language (English) rather than so-called language drift of learning a new emergent language on the same tokens (Lee et al., 2019).
We design two RL approaches for our tasks - learn to pick the right latent discrete variables (topics) that lead to goal-achieving utterances ; or learn to pick the correct from the top candidates. These are described in more detail in Sections 4.2 and 4.3. We also discuss a baseline “inverse” model trained via behavioral cloning on the human-human data.
4.1 Inverse model
We consider an inverse model, trained to imitate human actions given a goal, as both a baseline for comparing to RL models, and for producing weights from which we can fine-tune. The inverse model consists of a bi-encoder, as described above, which takes as input an observation , and outputs an utterance. We train it by extracting from the human-human game logs training set (which does not have goals) every instance where a game action occurs at time in , that is where
and where is not null (no action that turn); note, for or for might be null. We then construct a training example for the inverse model with observation . i.e. setting the goal to be , and with the desired action to be taken by the agent as . Here we use the subscripts “player” and “env” just to mark the relative positions in the sequence, as all actions and utterances come from the human logs. Note also that unlike the RL agents we train, the human in the player agent “position” can take game actions.
We can thus train this model in a supervised manner using a cross entropy loss as described before. This model does not learn a policy interactively, and hence might not learn to plan or strategize optimally for goal completion. The data distribution it is trained on is different than the data distribution seen by the RL agents. However, it serves as a strong baseline. Further, when training our RL agents, we initialize their weights to the weights of this model, and then fine-tune from that point.
4.2 Latent Discrete Variable (Topic) Model
Optimizing all the parameters of a large transformer architecture by RL is both incredibly costly in data efficiency and computing time, and is also known to have the problem of language drift (Lee et al., 2019) – that is, there is no guarantee after training with self-chat that the models will output recognizable natural language utterances. A solution to both problems is to train most of the parameters of the model with human-human language data, and then to either disentangle or only optimize some of the parameters with model self-chat (Yarats and Lewis, 2017).
Here, we propose a straight-forward model for that purpose. We assume an RL agent that consists of two components.
The first component maps from an observation to a discrete variable with possible values. It consists of a chain of two functions: a transformer that takes in the observation, and outputs a state representation , and a policy chooser which takes in the state representation and outputs the value of the discrete latent variable.
The second component is an additional transformer that takes as input the observation as well as the output of the first component, and outputs a dialogue utterance. The entire model is thus the chain . We make this explicit decomposition so that we can train only part of the model with RL; note that the “action” trained via RL is choosing , not outputting the final utterance.
We first pre-train the transformer using the inverse model described in Section 4.1, which produces a vectorial representation of a given observation. We then run -means over the vectorial representations of all observations from the training set to provide the mapping to one of values, which represent dialogue topics, which we use as our initial function . These two functions together give us our initialization of . Table 1 shows the cluster ID and the topic denoted by that cluster along with the most representative sentences (closest to the center) for that cluster for a model trained with topics. As we can see, the clusters learnt can be coherent about a topic. We use the set of topics as a set of actions for our RL setup.
|19||animal sounds||‘Meow! Purr!’, ‘Bah-Buk! Tasty!’, ‘Woof! Very!’, ‘Bock! Bock!’|
|12||find the cost||‘I would love some fruit. What are your prices?’, ‘They are beautiful.|
|How much do the cost?’, ‘It flows easily, how much are you selling it for?’|
|28||prayer,||‘Then your poor life is a sign from God for you to join us in the churchand serve him!’, ‘If you say so priest.|
|God||From now I will pray every night for wealth and good food!’, ‘Continue to love, worship, and serve Him.’|
|45||ask favor||‘Yes but do you mind doing me a favor?’, ‘Since I have helped you, could you do me a favor?’,|
|‘If I offer to solve your problem, what will you personally do for me in return?’|
Given our initial choice of , we can also pre-train . We simply take our initial human-human training data, and for each observation append the topic computed by to it. This allows our model to be able to generate an action (utterance) conditional on both an input and a topic. We can now train a policy by RL that optimizes the topic at any given point in the episode.
We keep the pre-trained portions of the model and fixed and during fine-tuning only optimize . The cluster chooser is redefined (from the initial
-means) to be an MLP network consisting of 2 layers. A discrete action is sampled from a categorical probability distribution over the possible topics, given by, where .
The state vector also encodes the goal and thus, the policy is conditioned on the goal of the agent. Hence, the policy can learn strategies that will result in picking actions at each time step that will help the agent to achieve its goal . As our RL agent can only choose topics, it cannnot redefine easily the meaning of words to cause language drift. We use the Advantage Actor-Critic implementation A2C (Kostrikov, 2018) to train the policy and the value function in both this and the subsequently described Top- model.
4.3 Top- model
The Top- model, related to (Dulac-Arnold et al., 2015), is another approach to keeping the number of trainable parameters small. As above it keeps close to the base retrieval model to avoid drift. It first uses the inverse model to get a context embedding from the observation, and a list of candidate utterance embeddings corresponding to utterances . These are the encodings by the inverse model of the utterances it considers most likely given the context and goal.
We form scores , and obtain a probability distribution over these candidates for our policy:
Here the trainable parameters of the RL agent are the map and biases .
Alternatively, we can train a small (2-layer) Transformer model that takes as input the set . Instead of a softmax over dot products as in (3), we use the attention weights in the last layer of above against the candidates as the distribution over the candidates for sampling an utterance. In this case, the weights of are the trainable parameters of the RL agent. We call the former model a policy “bi-encoder” (Top--Bi in tables) and the latter simply Top-.
5 Related work
There is an increasing body of work in the domain of chit-chat, where the primary approaches being currently tried are end-to-end neural approaches. They are typically large pre-trained and then fine-tuned transformers, either generative or retrieval. Retrieval models work best, or match generative models, on a number of tasks (Zhang et al., 2018; Dinan et al., 2018; Li et al., 2019). Our work shares a commonality with these approaches in that the original LIGHT dialogue data we use has no specified goals, and humans chit-chat together (and act). Thus, the conversations cover a rich number of diverse topics. In Urbanek et al. (2019) models were trained in a similar fashion to chit-chat task models, and we adopt similar architectures here, but instead adapt them to learn to pursue goals.
|Test Seen||Test Unseen|
|Random Utterance||game act||0.183||0.349||2.54||0.161||0.344||2.57|
|Inverse model (no goal)||game act||0.185||0.345||2.55||0.160||0.345||2.57|
|Inverse model||game act||0.223||0.414||2.42||0.193||0.410||2.48|
|Top- RL||game act||0.402||0.537||2.18||0.331||0.449||2.35|
|Top--BE RL||game act||0.327||0.491||2.26||0.278||0.442||2.34|
|Topic RL||game act||0.359||0.561||2.15||0.313||0.496||2.26|
|Top- RL (1-step 3x)||game act||-||0.526||2.14||-||0.475||2.26|
|Topic RL (1-step 3x)||game act||-||0.493||2.22||-||0.479||2.29|
|Inverse model (no goal)||emote||0.072||0.219||2.77||0.075||0.212||2.78|
|Top- RL (1-step 3x)||emote||-||0.336||2.58||-||0.293||2.65|
|Topic RL (1-step 3x)||emote||-||0.406||2.42||-||0.348||2.50|
|Self: guard Partner: archer||Self: swimmer Partner: turtles|
|Persona:||I guard the castle. I guard the king.||Persona:||I am a huge fan of deep sea exploration,|
|I would kill to protect the royal family||but I take any chance I can get to go for a swim…|
|Setting:||The armory, Inside Tower.||Setting:||Bank, Swamp|
|The near top of the tower 6 feet before the very top.||This is a grassy area that surrounds much of the swamp.|
|Where the watchers keep their eye…||It’s a plain field with some trees nearby along…|
|This is the armory!||Just keep taking good care of your beautiful little|
|The king keeps the best weapons here.||turtle family! Your species is quite unique and I love|
|Take a look -||to see you about when I go for a swim.|
|Hello, I need to get into the palace to see the||Well, thank you for that. Do you happen to know|
|king. I think he might like to see these weapons.||where my other turtle friend is? You haven’t captured|
|any turtles have you?|
|get weapon||hug swimmer|
|Self: townsperson Partner: villager||Self: songbird Partner: wasp|
|Persona:||We are the people who live in this town.||Persona:||I fly high and bring beautiful music to the people.|
|We are common, and there are many…||I soar high and low going where the …|
|Setting:||The Lagoon, Lake||Setting:||Meadow, Countryside|
|The Lagoon is a dark and mysterious place||Large clear outdoor meadow. Flowers of blue and|
|during the night hours. A lot of moss and lily…||white appearing in bunches here and there. The …|
|It is cold up here. Would you like my coat||Get out of here, wasp!|
|Oh yes please if I may. My shoe has become sodden||You? Fly away from me? You’re in my forest, bird.|
|from running to the market I should love to dry it a bit.||I control this land.|
|remove Cloak||hit a songbird|
|Top- RL (1-st. 3x)||act||-||0.737||1.62|
|Topic RL (1-st. 3x)||act||-||0.660||1.87|
|Top- RL (1st. 3x)||emote||-||0.587||1.96|
|Topic RL (1-st. 3x)||emote||-||0.570||1.99|
Traditional goal-oriented dialogue has focused on narrow tasks that would typically be useful for a dialogue-based assistant, for example restaurant (Henderson et al., 2014), taxi, train, and hotel (Budzianowski et al., 2018) or trip (El Asri et al., 2017) booking. Hence, each task typically focuses on a narrow slice of natural language and world knowledge for a specialized domain. Earlier work focused on labeled state representations, slot filling mechanisms and dialogue managers (Rieser and Lemon, 2011), and more recent work has shifted to an end-to-end approach (Bordes et al., 2017), in line with chit-chat models, but still the two sets of tasks are rarely considered together, or by using the same methods. Recently, Tang et al. (2019) used coarse-grained keywords as targets for open-domain chit-chat but in this work the target can be achieved when either the human or the agent uses the keyword in the response.
RL for dialogue
The classical goal-oriented dialogue literature studies RL extensively (Singh et al., 2000). Typically, they used RL to improve dialogue managers, which manage transitions between dialogue states (Singh et al., 2002; Pietquin et al., 2011; Rieser and Lemon, 2011; Gasic et al., 2013; Fatemi et al., 2016). Recent works have focused more on end-to-end learning. Some works have focused on self-play type mechanisms for end-to-end reinforcement learning, where the reward is derived from the goal. A related approach to ours is the negotiation task of Lewis et al. (2017); Yarats and Lewis (2017), which requires two agents to swap 3 item types (hats, balls, books) where the value of the items is different for the two agents, and derives their personal reward. In contrast, our setup encompasses a rich world of settings and characters – with 3462 object types, and a corresponding large number of actions. This is reflected in the vocabulary size itself (32,000 versus 2,000 in the negotiation tasks). Other notable uses of RL in dialogue include within visual question answering (Das et al., 2017), in the domain of chit-chat where RL has been used to decrease repetitive and generic responses through the the use of self-play (Li et al., 2016b), and through human-bot conversation (Sankar and Ravi, 2019).
RL for language and games
RL is used extensively for learning to play games, one of the most well known examples being AlphaGo (Silver et al., 2016). Since then, language in games has started to be more deeply explored, for example in graphical games such as Minecraft (Oh et al., 2017), Real-time strategy war games (Hu et al., 2019), or in text adventure games (Narasimhan et al., 2015; Côté et al., 2018). The latter are related to our setting. However, those approaches use RL to optimize the set of actions given feedback in a single-player rather than multi-player game, so the text only refers to the environment, and there is no dialogue or actions from other agents. Our work focuses on the latter.
We compare our various models on the game action and emote action tasks. We experiment with differing number of steps allowed to complete the goal, and . Apart from the models described in Sec. 4, we design two naive baselines to check the sanity of our environment models. The Random Utterance model picks a random utterance from the set of all candidates and returns that response to the environment. We also report results for the inverse model which does not get a goal to achieve. Our main results for both seen and unseen test environments (§2) are given in Table 2. We report the average reward and for the average number of turns before completion. The results show clear improvements for our Topic RL (§4.2) and Top-K RL (§4.3) compared to the inverse model and other baselines for each , for both game actions and emotes.
We show the training curves for Topic RL in Fig. 2, reporting rewards averaged over the batch (512 for , and 128 for ). They show relatively smooth improvements over time, with clear gains over the baseline. As a sanity check we also tried, after training, to replace the Topic RL policy with random topic prediction, which yielded poor results, e.g. 0.217 reward for test seen game actions. Our model is clearly learning appropriate topic acts.
Example successful episodes
We show examples of successful utterances, achieving goal actions in Fig. 3 for a diverse range of scenarios, actions and language. For example, for the guard’s goal to encourage the archer to get weapon the Topic RL model utters “This is the armory! The king keeps the best weapons here. Take a look”, which ends up leading to the desired action in the subsequent turn. More examples (for ) are given in Appendix D.
Analysis of utterance choice
To understand the semantics the models are learning that ground language to actions, we visualize the top scoring utterances, averaged over their probabilities on the 1-step test set, broken down by verb type. We observe a clear improvement in semantic connection for the Topic RL model over the inverse model. For example utterances such as “Have a taste of this” are highly scoring for drink goals, “hmmnnnn.. this sure smells nice” for eat goals, “Ew you vile beast, do not touch me! I will have you removed” for hit goals, and “How I love being pampered by you, sweetheart” for hug goals. Given there are 111,000 possible utterances in our setting, the model has clearly learned meaningful representations. Detailed results are given in Appendix Tables 9 and 10 for the inverse model and Topic RL model respectively.
Train vs. test performance
We compare training performance of our models in Table 4. We see the same trends that models that performed better on test fit better on train (e.g. Top- vs. Topic RL on 1-step tasks). Nevertheless, we do observe significant overfitting can occur, indicating that future work could explore either models that improve through better generalization, or by exploiting more training data – for example by self-play with more goals, rather than just using goals from human logs, as we have done here.
We evaluate different values of or numbers of topics for Top- and Topic RL. Full results are given in Appendix Table 7. They show that increasing the capacity of both models improves performance up to 200 clusters or , after which performance saturates. However, (56.1%) is substantially better than (47.7%) on the 3-step task, for example.
Performance breakdown by goal
We show the breakdown of test performance by goal type in Table 5 (splitting by verb type) and Appendix Table 8 (splitting by emote type). The results show that the easiest tasks are common actions with clear differentiation such as hug (85% success) and hit (75%). Actions like get, drop, give which are more confusable have somewhat lower numbers, with more rare actions (e.g. wear) faring worse.
Performance breakdown by difficulty
We can break down the test results into difficulty by considering in the 3-step task, which examples are 1-step achievable given the model’s possible actions under the policy (i.e. the possible Top- utterances or Topic RL cluster choices), and reporting results separately. The results are given in Table 6. They show that non 1-step achievable goals are much harder, representing a significant challenge to future systems.
1-step 3x baseline
To investigate further the quality of our 3-step task models, we consider an additional baseline of taking a 1-step task trained model (Topic RL or Top-) and applying it on the 3-step task, which it has not been optimized for. The results in Table 2 show test results are inferior for this approach. Breaking down further by goal type (Table 5 and Appendix Table 8) shows that there are large improvements for the 3-step model on goals which are more often expressed in the data. Table 6 shows that 3-step models outperform the 1-step 3x models on both 1-step achievable and the harder 1-step unachievable goals. Training performance (Table 4) further validates these results.
3-step task repeats
We analyze the number of repeated utterances in an episode. The Topic RL model repeats at least one utterance 25.8% of the time, with 15.59% utterances overall repeated. The 1-step 3x baseline in comparison repeats 37.3% at least once, and 22.94% on average. We note that repeating an utterance may possibly bring the desired goal in some cases, just as in real life.
In this paper, we investigate agents that can interact (speak or act) and can achieve goals in a rich world with diverse language, bridging the gap between chit-chat and goal-oriented dialogue. We achieve this by defining a task for an agent, where the goal is for the other player to execute a particular action. We explore two reinforcement learning approaches to solve this task, and compare them against a strong inverse model baseline. We show that these approaches effectively learn dialogue strategies that lead to successful completion of goals, while producing natural chat.
Future work should develop improved agents that learn to act and speak in natural language at scale in our proposed open-domain task environment. This setup is exciting because it can be further generalized to richer and richer goal (game) states as we develop models capable of them.
- Learning end-to-end goal-oriented dialog. In Proceedings of the International Conference on Learning Representations (ICLR), Cited by: §1, §5.
- Multiwoz-a large-scale multi-domain wizard-of-oz dataset for task-oriented dialogue modelling. arXiv preprint arXiv:1810.00278. Cited by: §1, §5.
- Textworld: a learning environment for text-based games. arXiv preprint arXiv:1806.11532. Cited by: §5.
Learning cooperative visual dialog agents with deep reinforcement learning.
Proceedings of the IEEE International Conference on Computer Vision, pp. 2951–2960. Cited by: §5.
Wizard of wikipedia: knowledge-powered conversational agents. arXiv preprint arXiv:1811.01241. Cited by: §5.
- Deep reinforcement learning in large discrete action spaces. arXiv preprint arXiv:1512.07679. Cited by: §4.3.
- Frames: a corpus for adding memory to goal-oriented dialogue systems. In Proceedings of the 18th Annual SIGdial Meeting on Discourse and Dialogue, Saarbrücken, Germany, pp. 207–219. Cited by: §1, §5.
- Policy networks with two-stage training for dialogue systems. arXiv preprint arXiv:1606.03152. Cited by: §5.
- POMDP-based dialogue manager adaptation to extended domains. In Proceedings of the SIGDIAL 2013 Conference, pp. 214–222. Cited by: §5.
- The second dialog state tracking challenge. In Proceedings of the 15th Annual Meeting of the Special Interest Group on Discourse and Dialogue (SIGDIAL), pp. 263–272. Cited by: §1, §5.
- Hierarchical decision making by generating and following natural language instructions. arXiv preprint arXiv:1906.00744. Cited by: §5.
- Real-time inference in multi-sentence tasks with deep pretrained transformers. arXiv preprint arXiv:1905.01969. Cited by: §4.
- PyTorch implementations of reinforcement learning algorithms. GitHub. Note: https://github.com/ikostrikov/pytorch-a2c-ppo-acktr-gail Cited by: §4.2.
- Countering language drift via visual grounding. arXiv preprint arXiv:1909.04499. Cited by: §4, §4.2.
- Deal or no deal? end-to-end learning for negotiation dialogues. arXiv preprint arXiv:1706.05125. Cited by: §5.
- A persona-based neural conversation model. arXiv preprint arXiv:1603.06155. Cited by: §1.
- Deep reinforcement learning for dialogue generation. arXiv preprint arXiv:1606.01541. Cited by: §5.
- ACUTE-eval: improved dialogue evaluation with optimized questions and multi-turn comparisons. arXiv preprint arXiv:1909.03087. Cited by: §5.
- Training millions of personalized dialogue agents. arXiv preprint arXiv:1809.01984. Cited by: §1, §4.
- Language understanding for text-based games using deep reinforcement learning. arXiv preprint arXiv:1506.08941. Cited by: §5.
- Zero-shot task generalization with multi-task deep reinforcement learning. In Proceedings of the 34th International Conference on Machine Learning-Volume 70, pp. 2661–2670. Cited by: §5.
- Sample-efficient batch reinforcement learning for dialogue management optimization. ACM Transactions on Speech and Language Processing (TSLP) 7 (3), pp. 7. Cited by: §5.
- Let’s go public! taking a spoken dialog system to the real world. In Ninth European conference on speech communication and technology, Cited by: §1.
Reinforcement learning for adaptive dialogue systems: a data-driven methodology for dialogue management and natural language generation. Springer Science & Business Media. Cited by: §5, §5.
- Deep reinforcement learning for modeling chit-chat dialog with discrete attributes. arXiv preprint arXiv:1907.02848. Cited by: §5.
Mastering the game of go with deep neural networks and tree search. nature 529 (7587), pp. 484. Cited by: §5.
Optimizing dialogue management with reinforcement learning: experiments with the njfun system.
Journal of Artificial Intelligence Research16, pp. 105–133. Cited by: §5.
- Reinforcement learning for spoken dialogue systems. In Advances in Neural Information Processing Systems, pp. 956–962. Cited by: §5.
- Target-guided open-domain conversation. In Proceedings of the 57th Annual Meeting of the Association for Computational Linguistics, pp. 5624–5634. Cited by: §5.
- Learning to speak and act in a fantasy text adventure game. arXiv preprint arXiv:1903.03094. Cited by: Table 11, §1, §2, §2, §4, §5.
- Attention is all you need. In Advances in Neural Information Processing Systems, pp. 5998–6008. Cited by: §4.
- Learning semantic textual similarity from conversations. arXiv preprint arXiv:1804.07754. Cited by: §1.
- Hierarchical text generation and planning for strategic dialogue. arXiv preprint arXiv:1712.05846. Cited by: §4.2, §5.
- Personalizing dialogue agents: i have a dog, do you have pets too?. arXiv preprint arXiv:1801.07243. Cited by: §5.
Appendix A Additional Results
|Test Seen||Test Unseen|
|Model||Goal Type||# Clusters||Reward||Reward||Turns||Reward||Reward||Turns|
|Topic RL||game act||50||0.324||0.477||2.31||0.277||0.470||2.24|
|Topic RL||game act||100||0.348||0.523||2.21||0.282||0.488||2.28|
|Topic RL||game act||200||0.359||0.561||2.15||0.313||0.496||2.26|
|Topic RL||game act||500||0.362||0.505||2.23||0.307||0.46||2.35|
|Topic RL||game act||1000||0.372||0.510||2.20||0.333||0.464||2.32|
|Top- RL||game act||50||0.329||0.503||2.24||0.261||0.439||2.39|
|Top- RL||game act||100||0.370||0.521||2.12||0.292||0.468||2.33|
|Top- RL||game act||200||0.402||0.537||2.18||0.331||0.449||2.35|
|Top- RL||game act||500||0.402||-||-||0.299||-||-|
|Top- RL||game act||1000||0.426||-||-||0.337||-||-|
|get||213||’Why hello there, I haven;t seen you in awhile.’, ”Oh hello, I didn’t expect to find anyone else here.”, ”Well hello there, wasn’t expecting to see you here.”, ’Wow! What a fine place this is.’, ”Oh, hello! I didn’t see you all here.”, ’Well hello there! I did not expect to see anyone here.’, ”Isn’t this place so wonderful!?”, ’I need some light.’, ’So how is buisiness going?’, ’”Ah, what a long day we have ahead of us!”’|
|put||25||’Why hello there, I haven;t seen you in awhile.’, ”Well hello there, wasn’t expecting to see you here.”, ”Oh hello, I didn’t expect to find anyone else here.”, ’Wow! What a fine place this is.’, ’Eerie. I must light a candle. And say a prayer’, ”Oh, hello! I didn’t see you all here.”, ’Well hello there! I did not expect to see anyone here.’, ”Isn’t this place so wonderful!?”, ’Greetings! How are my subjects doing this fine day?’, ’Good morning. Someone needs to tend to this rickety rectory. I almost fell through the floor.’|
|drink||3||’Eerie. I must light a candle. And say a prayer’, ’It is a wonderful day to drink! Time to get my drunk on!’, ’I need another drink.’, ”Greetings m’lord! Cold day isn’t it?”, ’I am person just trying to enjoy the ambiance of this room’, ’I need some light.’, ’It appears you need some guidance.’, ’Hello person! How are you on this fine evening?’, ’Good evening good evening sir! Can I help you?’, ”Well hello there, wasn’t expecting to see you here.”|
|eat||10||’Why hello there, I haven;t seen you in awhile.’, ’Hello bird, how are you doing?’, ’Ahh, what a great day to nibble at the feet of humans.’, ’I hope there is food in here.’, ’Mmmm a human come into my territory. My lucky day indeed.’, ’Ugh I am so tired of being used as food around here.’, ’I am so delighted to not have to scavenge for food in the village.’, ’WOW! So much food to eat here’, ’”Come here! I need to eat!”’, ’man i hope i can find something to eat here’|
|steal||55||’well what a fine mess i have gotten myself into this time’, ’*ARGH* you must let me out of this place.’, ’I have seen you before! Thief what is it you think you will get today?’, ’Wow, this lavoratory is filthy!’, ’Hey, you there. Come here!’, ’Hey, you over there! You look like you could use a little something I have.’, ’Hello! You look as though you are in need of some of my wares.’, ’It appears you need some guidance.’, ’Why hello there, I haven;t seen you in awhile.’, ’Enjoy! You finally have a place of your very own.’|
|hit||172||’Whatchit! You almost crushed me!’, ’*ARGH* you must let me out of this place.’, ’Hey, you there. Come here!’, ’well what a fine mess i have gotten myself into this time’, ’Wow, this lavoratory is filthy!’, ’You must bow before me.’, ’Why are you in here! Back away from me or I will strike!’, ’Why hello there, I haven;t seen you in awhile.’, ’”Come here! I need to eat!”’, ’Ugh not another one of these beasts.’|
|hug||222||’Why hello there, I haven;t seen you in awhile.’, ’Minister! It is so good to see you!’, ”Well hello there, wasn’t expecting to see you here.”, ”Oh hello, I didn’t expect to find anyone else here.”, ”I’m so glad you’re here with me”, ’It is so nice and warm in here.’, ’Wow! What a fine place this is.’, ’I am so happy for this day.Even if is in this filthy place’, ”Oh, hello! I didn’t see you are.”, ’Hail, friend. How are things?’|
|wear||10||’Why hello there, I haven;t seen you in awhile.’, ”Well hello there, wasn’t expecting to see you here.”, ”Oh hello, I didn’t expect to find anyone else here.”, ’Wow! What a fine place this is.’, ’Good afternoon sir! I did not expect to find you here.’, ’Well hello there! I did not expect to see anyone here.’, ’Why I did not expect to see you here, sir! Please join us.’, ’Good evening good evening sir! Can I help you?’, ’It appears you need some guidance.’, ’”Ah, what a long day we have ahead of us!”’|
|drop||27||”Well hello there, wasn’t expecting to see you here.”, ’Why hello there, I haven;t seen you in awhile.’, ”Oh hello, I didn’t expect to find anyone else here.”, ’Wow! What a fine place this is.’, ”Oh, hello! I didn’t see you all here.”, ’Well hello there! I did not expect to see anyone here.’, ’”Ah, what a long day we have ahead of us!”’, ’well what a fine mess i have gotten myself into this time’, ’Oh, hello! I was just checking to see if anyone dropped these goblets. Ha, ha, ha.’, ’So how is buisiness going?’|
|give||136||’Why hello there, I haven;t seen you in awhile.’, ”Well hello there, wasn’t expecting to see you here.”, ’Wow! What a fine place this is.’, ”Oh hello, I didn’t expect to find anyone else here.”, ’Good evening good evening sir! Can I help you?’, ”Isn’t this place so wonderful!?”, ’Well hello there! I did not expect to see anyone here.’, ”Oh, hello! I didn’t see you all here.”, ’Wow this is such a nice place.’, ’I must get this place cleaned at once!’|
|remove||127||”Well hello there, wasn’t expecting to see you here.”, ’Why hello there, I haven;t seen you in awhile.’, ”Oh hello, I didn’t expect to find anyone else here.”, ”Oh, hello! I didn’t see you all here.”, ’Wow! What a fine place this is.’, ’Well hello there! I did not expect to see anyone here.’, ’It appears you need some guidance.’, ’Good evening good evening sir! Can I help you?’, ’Another hectic day in this place.’, ’”Ah, what a long day we have ahead of us!”’|
|get||213||’Here sir, I found this.’, ’Oh hello there brothers! Why whose towel is this thats left all by its self?’, ’How did this get here?’, ’Meh. Whats this you have here?’, ”What is this? Is this someone’s head?!”, ”Thank you, sir. What’s with all this silk?”, ’What is this here?’, ’It looks like there is something missing!’, ”Oh, look, somethin’ shinny”, ’what is this ston slab’|
’How did this get here?’, ’Oh hello there brothers! Why whose towel is this thats left all by its self?’, ’Where did you find this?’, ’Ah…. I wonder what this doll looked like before…’, ”Thank you, sir. What’s with all this silk?”, ’Wait… one… MOMENT. What is my royal CUP doing in here?’, ’Here sir, I found this.’, ’What is this room here for? Miaow!’, ’Have you noticed this artwork on this wood maam?’, ’So you decided to look at this one?’
|drink||3||’Oh, what is this? It smells heavenly!’, ”What’s that stuff? Smells good.”, ’hmmnnnn.. this sure smells nice’, ’Hello monk, that incense smells amazing.’, ’I wish I can just have a taste of that’, ’Do you smell that? It smells DIVINE!’, ’I wonder how this tastes?’, ’Hmmnnn… This smells great!’, ’Have a taste of this’, ’Where did you get this? I could use a smoke afterwards!’|
|eat||10||’Oh, what is this? It smells heavenly!’, ”Hmmm, sniff. This doesn’t smell edible.”, ’Something in here smells good…I hope I can eat it.’, ’I wonder how this tastes?’, ”What’s that stuff? Smells good.”, ’I wish I can just have a taste of that’, ’hmmnnnn.. this sure smells nice’, ’Ew this is disgusting. Even for me.’, ’Mmm look at all this delicious trash.’, ’Hmmnnn… This smells great!’|
|steal||55||’”Hey! I think you dropped this!”’, ’How did this get here?’, ’Here sir, I found this.’, ’Wow, where were you hiding this?’, ’What about this! Is this yours or was it already here?!’, ”What is this? Is this someone’s head ?!”, ’Where did you find this?’, ’Tell me where you found this!’, ’Where did you steal that from?’, ’See this? Do you think I just found this laying around some house?’|
|hit||172||’Foul scourge! How dare you bring your taint here!’, ’Ooooh, how horrid! Away with you you filthy creature! GUARDS! GUARDS!’, ’You come to my place and are trying to take my land! Is that what you are doing? You dirty scumbag!’, ’Why are you in here! Back away from me or I will strike!’, ’Ew you vile beast, do not touch me! I will have you removed!’, ’GUARD! Get this scum off of me at once. How dare you, you scoundril!’, ’Be gone you foul beast!’, ’Quickly?! You started this you repugnant beast of a man!’, ’I want out! this place is evil.’, ’How dare someone of your low status attack me?? Have at you, you maggot!’|
|hug||222||’he loves me so much’, ’ahhhh i love you to dear’, ’How I love being pampered by you, sweetheart!’, ”Aw you are so cute I can’t resist cuddling with you”, ”I’m so glad to be here in everyone’s company.”, ’awww. I love you child’, ’Oh how i have missed you.’, ’I love you so dang much.’, ’Lord of Light, I adore you.’, ”I’m so happy to be here today”|
|wear||10||’Here sir, I found this.’, ’Like this broken weapon here?’, ’Oh hello there brothers! Why whose towel is this thats left all by its self?’, ’Hello my king, do you know where this weapon came from?’, ’Here sir…you dropped this…you may need it.’, ”Thank you, sir. What’s with all this silk?”, ’Meh. Whats this you have here?’, ’How did this get here?’, ’Meow. I need this hay’, ’Are you here to purchase that amazing blue knight armor sir?’|
|drop||27||’Here sir, I found this.’, ’How did this get here?’, ”Oh, look, somethin’ shinny”, ’Oh hello there brothers! Why whose towel is this thats left all by its self?’, ”Thank you, sir. What’s with all this silk?”, ’It looks like there is something missing!’, ’What is this here?’, ’I heard theres some valuable stuff in here mate, know anything about that?’, ’Meh. Whats this you have here?’, ”Let’s stuff it here!”|
|give||136||’Here sir, I found this.’, ’Meh. Whats this you have here?’, ’Wow, this looks to be very old. Where is it from?’, ”My goodness I wonder how that got there! It sure is pretty isn’t it?”, ’Say, where did you get this?!’, ’Oh hello there brothers! Why whose towel is this thats left all by its self?’, ’Someone left this bag in this pew. Do you know what it is?’, ’Tell me where you found this!’, ”What is this? Is this someone’s head?!”, ’what is this ston slab’|
|remove||127||’I suppose for today we may as well look at some garbs.’, ’Hey there! Got time to take a look at something?’, ”Thank you, sir. What’s with all this silk?”, ’Hmm, where am i and why is everything so sharp?’, ’Ah, squire Lawrence. Did you polish my armor?’, ’What are you jotting down, sir?’, ’Hello ratty. I am looking to clean my clothes!’, ’Yes sir what is this good news? Did you finally get me a new dress!?’, ’At least my hat is clean.’, ”Oh, hello there. Pardon my, erm, dusty appearance. It’s been quite journey to get even this far!”|
Appendix B Game actions within LIGHT
|get object||actor and object in same room||actor is carrying object|
|object is gettable|
|drop object||actor is carrying object||object is in room|
|object is gettable|
|get object1 from object2||Actor and object2 in same room||actor is carrying object1|
|object1 is gettable|
|object2 is surface or container|
|object2 is carrying object1|
|put object1 in/on object2||Actor and object2 in same room||object2 is carrying object1|
|object2 is container or surface|
|actor is carrying object1|
|give object to agent||Actor and agent in same room||agent is carrying object|
|object is a member of actor|
|steal object from agent||actor and agent in same room||actor is carrying object|
|object is a member of agent|
|hit agent||Actor and agent in same room||inform agent of attack|
|hug agent||Actor and agent in same room||inform agent of hug|
|drink object||actor is carrying object||inform actor of drinking successfully|
|object is a drink|
|eat object||actor is carrying object||inform actor of eating successfully|
|object is a food|
|wear object||actor is carrying object||actor is wearing object|
|object is wearable|
|wield object||actor is carrying object||actor is wielding object|
|object is a weapon|
|remove object||actor is wearing/wielding object||actor is carrying object|
|object is wearable or a weapon|
Appendix C LIGHT example
|Persona 1: Village youth||Persona 2: Horse|
|I am a youth who lives in the village. I am adventurous and||I live on a farm. I work for humans.|
|curious about everything. I get bored easily, so I will always try||I like hay.|
|to slip away from mundane daily tasks to find something more|
|interesting to do. I am smart for my age and a bit smug.|
Setting: Royal stables, Outside Castle - The royal stables hold all of the horses of the noble
|people living in the castle. They are very well constructed, consisting of expert mason work and fixtures|
|of some sort of heavy, forest-scented wood. Each horse has a large stall, lined with fresh hay replenished|
|by stable hands daily. On the walls of stable, there are tools used to care for and groom the horses, hung|
|on hooks. The stables are lit by lanterns hung throughout the stables.|
Village Youth This is so boring cleaning out the stables every day
|Horse Thank you for taking such good care of us|
|Village Youth I’ll be getting you some treats soon as well|
|Horse Mmm. It’s also nice to have your company.|
|Village Youth I wonder what it’d be like to just take one of these horses and roam the countryside|
|Horse Let’s go. It’s been a while since I’ve been taken out to stretch my legs Emote: nudge|
|Village Youth Yeah, let’s break out of here. The royalty don’t even care about the horses like I do|
|Horse It’s starting to get dark. I think we will need this lantern. Action: get lantern|
|Village Youth Good idea. I do need some supplies before we go Action: get Tool|
|Horse I’ll probably want a snack while we are gone. Action: get wheat|
|Village Youth Let’s see, what else do I need? Emote: ponder|
|Horse Maybe the wood for a fire? Action: give lantern to village youth|
|Servant: Yeah, we’ll need a bundle for sure Action: get wood|
|Horse I’ve got the hay. I think we are ready to go. Let’s get out of here Action: get hay|
Appendix D 3-Step Episode Examples
|Self: a cowardly young man in armour Partner: guard||Self: bodyguard Partner: intruder|
|Persona:||I have just been trained as a royal soldier.||Persona:||I am an immortal bodyguard.|
|I am 18 years old and terrified…||The gods have appointed me to protect the king…|
|Setting:||Trash Heap, Wasteland||Setting:||Treasure Cavern, Inside Temple|
|A largest trash heap in the kingdom has been burned||Glittering as far as the eye can see the Treasure Cavern is|
|out so many times that it no longer resembles anything…||filled with gold, silver, precious gems,…|
|I’m also in need of a new shield.||Step back intruder!|
|You have no business in the king’s treasure cavern!|
|Squire, my shield fatigues me.||Ha! I’m here to take all of this treasure.|
|End the king’s reign!|
|hug a cowardly young man in armour||get gold|
|Thank you, sir. I needed a hug.||You come to my place and are trying to take my land!|
|Is that what you are doing? You dirty scumbag!|
|Yes. I need you to hold this shield for me.||Then I will get away with your gold!|
|remove shield||hit bodyguard|
|Self: cat Partner: challenger||Self: peasant Partner: the man|
|Persona:||I live in the barn of a small farm.||Persona:||I am poor and dirty.|
|I protect the farm from pests…||I hate that I am starving to death…|
|Setting:||The Dungeon, Inside Palace||Setting:||Cottage, Countryside|
|The dungeon is in the very most bottom room of the Palace.||The small cottage was white with two, shuttered windows.|
|Many have gone down to the dungeon…||It was in the unique shape of a…|
|Goal:||drop poison||Goal:||put coin in dinner table|
|What’s that stuff? Smells good.||Oh, what is this? It smells heavenly!|
|That’s smells like the good stuff alright!||Yes it is top quality.|
|give poison to cat||steal moldy bread from peasant|
|i thought so too, well that’s gone. What are you up to?||Excellent! What have you been doing out here on this fine day?|
|ive been hidden waiting for the perfect time to make an escape||I have no bread. I have just come to get some rest before moving on.|
|remove bag of herbs||eat moldy bread|
|I thought you might be eating my herb again.||No, but perhaps you can use it to cleanse your bread!|
|I did it, I confess! I stole these precious herbs.||I would love to. I fear I look disheveled.|
|I will wear this blanket to cover my filthy clothes|
|drop bag of herbs||hug peasant|