Skip to content

ujja/cui

 
 

Repository files navigation

A Conversational UI Prototype

During our university masters seminar we build a chat bot prototype to enhance the user experience on the MOOC platform Open SAP. In the following we will give a short overview over our experiment including how to train models and use the conversational UI prototype.

Table of contents

Introduction

Rasa is an open source platform for building chat bots. It consists of two major parts: the Rasa Core and the Rasa NLU. On top of that we additionally build our own Chat UI frontend in ReactJS.

CUI Architecture

Rasa NLU

The Rasa NLU is responsible for the Natural Language Understanding of the chatbot. It receives an input (e.g. a sentence) from the user through the UI and predicts an intent of that sentence. The intent defines how the chatbot will react to a certain input.

Rasa Core

Rasa Core takes the output of the NLU (a structured input e.g. an intent) and decides on an action to perform on it. Actions can be several things: an API Call, a response in form of an utterance or just an input validation (read more Actions). These actions are send back to the frontend as the bots response.

Chat UI

The chat UI is a simple reactJS frontend. It consits of a simple input mask where the user can enter question or actions to the bot and communicate with it.

Getting Started

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes. You will train a model for both the dialogue engine and the NLU and send your first message to the bot.

Prerequisities

  • Docker with Docker Compose

Installation

  1. Clone the repository.
    git clone [email protected]:schul-cloud/cui.git
  2. Build the images by going to the root directory and execute the following command.
    docker-compose build
    This may take a while...
  3. Train the models, so the chatbot knows how to behave.
    docker-compose run rasa-core python -m rasa_core.train -d data/opensap_faq/domain.yml -s data/opensap_faq/stories.md -o model/opensap_faq --epochs 200
    docker-compose run rasa-nlu python -m rasa_nlu.train -c config.yml -d data/opensap_faq -o projects --project opensap_faq
  4. Start the containers.
    docker-compose up
  5. Open http://localhost:3000 to access the chat interface. The first request to the bot may take a few moments, since the NLU has to be initialized.

Add intent with simple utterance

  1. Define examples of what the user might say to express the intent. This is done in the training data of the NLU in one or multiple Markdown files. These can be located in rasa-nlu/data/<project-name>.
    ## intent:sound_of_cat
    - what does the cat say
    - what does a cat sound like
  2. Now the dialogue engine might receive the sound_of_cat intent, which has to be added to its domain. Since the bot should only output a simple text response, its template can also be specified in rasa-core/data/<project-name>/domain.yml.
    intents:
        - sound_of_cat
    
    actions:
        - utter_sound_of_cat
    
    templates:
        utter_sound_of_cat:
            - text: Meow!
            - text: Meow meow!
    Since there are multiple templates defined, Rasa Core will choose one randomly.
  3. Add training data for the conversational flow, so that the bot triggers the correct action utter_sound_of_cat after the intent sound_of_cat. This training data is located in rasa-core/data/<project-name>/stories.md.
    ## Make meow sound <this line is just a comment>
    * sound_of_cat
        - utter_sound_of_cat
  4. Train the models as described in Training Models.

Docker Services

Service Description Port URL
Chat UI Demo to show the interface on the openSAP landing page. 3000 http://localhost:3000
Rasa Core Rasa Core instance for a predefined project. 5005 http://localhost:5005/conversations/default/respond?q=hello
Rasa NLU Rasa NLU instance, which can be used for multiple projects. 5000 http://localhost:5000/parse?q=hello&project=opensap_faq
Rasa NLU Training Runs a cron job, which starts the NLU training daily at midnight.  
Duckling Entitiy extraction service for predefined entities. For more information see the Rasa and duckling documentation. 8000

Training Models

To train the respective service run one of the following commands from the root directory.

Rasa Core

docker-compose run rasa-core python -m rasa_core.train \
    -d data/opensap_faq/domain.yml \
    -s data/opensap_faq/stories.md \
    -o model/opensap_faq \
    --epochs 200

Rasa NLU

docker-compose run rasa-nlu python -m rasa_nlu.train \
    -c config.yml \
    -d data/opensap_faq \
    -o projects \
    --project opensap_faq

Actions

Actions are the things the bot can do. As described in the Getting Started section one action type are simple utterances, that can be defined in the domain of your project. Furthermore variables can be used in the templates to fill them with slot entries. But you can also define your own custom actions with some Python code to call an API or do whatever you can think of.

Rasa provides a basic Action class to inherit from and a more specific FormAction. The latter one is a simplification for use cases, where you need a specific set of data values from the user to perform an action. You can find a small example in rasa-core/actions/opensap_faq/account.py. The class ActionEmailForm gets an email address from the user and prompts him to confirm it. Only if these two steps are done, the submit function is called.

To use your custom actions in your stories they have to be added to your projects domain.

actions:
    - opensap_faq.account.ActionEmailForm

User Feedback

What if the answer of the bot was not what the user was expecting or did not help with the users problem?

If the NLU was not able to clearly classify the intent, which means the confidence is below a specific threshold, the user is presented a selection of alternatives. To do this we extended the Core server with a mapping from an intent to a question. For example the intent sound_of_cat might be mapped to the question Did you want to know what a cat sounds like?.

To offer this to the user, you need to define these questions for each intent in a intent_questions.json file in your projects data folder, e.g., rasa-core/data/opensap_faq/intent_questions.json.

{
    "sound_of_cat": "Did you want to know what a cat sounds like?"
}

When the user chooses one of the alternatives, the endpoint http://localhost:5005/conversations/<sender_id>/tracker/reset_intent?intent=<alt_intent> is called with the respective intent name. This resets the tracker for the current conversation to the last user input and executes the actions for the new intent.

To improve the NLU the input of the user is saved as an example for the alternative intent in rasa_nlu/data/<project_name>/user_input. These markdown files are used in the next training for the model of the given project.

Future Work

As already mentioned before this is just a prototype and there are some things that can be implemented in the future to introduce it as a beta feature. Two things we want to point out a bit more detailed:

  1. Session Management
  2. Authorization for Actions

Session Management & Authorization

Session Management and Authorization for Actions come hand in hand. Session Management is an important feature for every online service especially chat bots and therefore every session should be time-boxed. At the end of each session the user needs to authorize once again. This is on the one hand an important aspect for the actions which the bot wants to perform. For example, in order to change the email-address of the user, the bots needs to have the permission to access the users settings. On the other hand, it is a necessary security feature to limit the bots access to certain commands and prevent unwanted actions.

About

A Conversational UI experiment

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HTML 57.0%
  • Python 26.2%
  • JavaScript 12.4%
  • Dockerfile 2.4%
  • CSS 1.9%
  • Shell 0.1%