-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Redid the installation to make it simpler. Updated README.md with scr…
…eenshots and list of new features. Added required NLTK models to help installation. Updated the GUI.
- Loading branch information
Showing
16 changed files
with
255 additions
and
130 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,37 +1,110 @@ | ||
# JokeBot | ||
An interactive bot made with Rasa that tells the user jokes. The bot is a friend trying to become a comedian and the user's role is to give feedback on their jokes. | ||
|
||
## Installation | ||
|
||
To install, enter the following into a terminal, after switching to/activating a virtual environment if needed: | ||
`pip3 install -r requirements.txt`. This should install all required dependencies. | ||
|
||
### Other Troubleshooting | ||
If you have issues with the installation, know that to run the bot you must have `rasa` installed on `Anaconda` or any python virtual environment. | ||
For detailed instructions on the installation of Rasa please refer to the official documentation: [How to Install Rasa](https://rasa.com/docs/rasa/installation/). | ||
|
||
|
||
## How to Run | ||
To run the bot, make sure you have `rasa` installed on `Anaconda` or any python virtual environment. For detailed instructions on the installation of Rasa please refer to the official documentation: [How to Install Rasa](https://rasa.com/docs/rasa/installation/). | ||
**TO RUN THE BOT, YOU WILL NEED TO RUN 3 TERMINAL WINDOWS AS FOLLOWS:** | ||
|
||
### Terminal Window 1 - Main Rasa Model | ||
Navigate to the root folder of the project, and enter the following into the console: | ||
|
||
Usually all you need to do to install rasa is run the following command: | ||
```pip3 install rasa``` | ||
If the above doesn't work, refer to the documentation linked above. | ||
`rasa run --m ./models --endpoints endpoints.yml --port 5002 -vv --enable-api --cors "*"` | ||
and wait for it to launch. **Note:** This may take a while depending on your system. | ||
|
||
__Note: If there is an error about `spacy` model not being able to load, run the following command, and it should work: `python -m spacy download en_core_web_md`__ | ||
|
||
Once Rasa has been installed, navigate to the root folder of the project, and do the following: | ||
- run `rasa run --m ./models --endpoints endpoints.yml --port 5002 -vv --enable-api --cors "*"` and wait for it to launch. **Note:** This may take a while depending on your system. | ||
- _**VERY IMPORTANT**_ : In a **separate** terminal window/tab, run the command `rasa run actions`, to run a custom actions server for the bot to be able to work properly. | ||
- If there is an error about `spaCy` model not being able to loaded, run the following command, and it should work: `python -m spacy download en_core_web_md` | ||
|
||
Once the commands finish running, in another **separate** terminal (That's 3 in total), navigate to the `GUIWebsite` folder using something like `cd GUIWebsite` from the root folder. | ||
Then type the following into the console to start up the server: `python -m http.server 8000` | ||
### Terminal Window 2 - Rasa Custom Actions Server | ||
Again in the root folder of the repository, enter the following into the console: | ||
|
||
`rasa run actions` | ||
|
||
The command above will run a custom actions server for the bot to be able to work properly. | ||
|
||
### Terminal Window 3 - HTML Page for Bot GUI | ||
Once the commands finish running, in another **separate** terminal, | ||
**navigate to the `GUIWebsite` folder** using something like `cd GUIWebsite` from the root folder. | ||
Then type the following into the console to start up the GUI: | ||
|
||
`python -m http.server 8000` | ||
|
||
Once that is done, type `localhost:8000` into your browser's URL field, and you should be greeted | ||
with this page: | ||
|
||
data:image/s3,"s3://crabby-images/66390/66390382a98faaa2ea9fc22c832c9d365a7ac100" alt="JokeBot chat window" | ||
|
||
Have fun talking to our bot! | ||
Have fun talking to our bot! :) | ||
|
||
_**Aside**: The current GUI for the bot will use text-to-speech, so don't be alarmed when the bot speaks to you!_ | ||
|
||
## Issues | ||
Feel free to raise any issues you might encounter on the repository, and we'll be happy to help! :) | ||
|
||
## New Features for A3 | ||
- ### Graphical User interface | ||
For A3, we implemented a simple GUI for Rasa chatbots, that was adapted from [Scalable Minds' Chatroom Repository](https://github.com/scalableminds/chatroom). | ||
This GUI has the typical text input field through which the usercan speak to our bot, and it also has a speak-to-talk option, but only for Chrome. | ||
It also has a function to read out the messages the bot sends using text-to-speech. | ||
|
||
By adding these features to our GUI, we can now keep track of conversation history in a clean and readable format. The speak-to-talk, and text-to-speech add | ||
another layer of accessibility to our bot, so the conversation can be enjoyed to its fullest extent. Here is another picture of the GUI in action: | ||
data:image/s3,"s3://crabby-images/66390/66390382a98faaa2ea9fc22c832c9d365a7ac100" alt="Jokebot GUI" | ||
|
||
- ### Extra Topic | ||
For A3, We decided to include an extra topic for our joke bot in the form of memes. Since "memes" are another form of jokes that are part of a rapidly | ||
We decided to include an extra topic for our joke bot in the form of memes. Since "memes" are another form of jokes that are part of a rapidly | ||
advancing movement that brings humour to the internet, we included them as an extra topic for our bot. When the user asks for memes, the bot will deliver by | ||
showing them a link to a few galleries filled with some memes, which are | ||
showing them a link to a few galleries filled with some memes, which should entertain the user. | ||
|
||
By adding this feature to our bot, we improve the breadth of knowledge it has and made sure that the conversation had ample opportunities to be interesting, | ||
rather than just being an infinite loop of jokes and responses. Here is a snippet of a conversation showing this feature in action: | ||
data:image/s3,"s3://crabby-images/cb0b0/cb0b0aa247ddb35c9a288aa5221b3e7ec2fd3299" alt="Bot shows user a meme" | ||
|
||
- ### Out of Scope Message Handling | ||
For A3, We also chose to add extra functionality to the out-of-scope messages in our bot. We previously implemented fallback, and default options, | ||
which are similar to out-of-scope messages. In our bot, if the user enters a message that is outside the scope of the two topics our bot can currently handle, | ||
i.e. jokes and memes, then the bot will respond appropriately. For example, if the user enters something like: "Can I order a pizza?" the bot classifies this as | ||
out-of-scope, and responds with something like "Can we please focus on the jokes?" | ||
|
||
By adding this feature to our bot, we directly improve the flow of language to ensure that the bot doesn't break when the user enters something | ||
completely unexpected. Here is a snippet of a conversation showing this feature in action: | ||
data:image/s3,"s3://crabby-images/cf526/cf5262156d7b7cddf95d94b9a535048d03ed6594" alt="Bot shows user an out of scope message" | ||
|
||
- ### Named Entity Recognition | ||
JokeBot can now identify entities in the user's messages! By adding this feature to our bot, we can enhance our bot's ability to respond to user messages | ||
by understanding what the user might want to ask the bot about. Since this feature is implicitly defined, we can't see it in the conversation directly, but here is a snippet of the shell | ||
that shows the entities extracted from a specific message: | ||
data:image/s3,"s3://crabby-images/f9e4e/f9e4ee85ad359eeeec7a013bd68b90aca2afe999" alt="NLU data shown extracted the entities of a message" | ||
We can see from the screenshot that the bot successfully extracted the entities `pizza` and `joke` from the user message | ||
- ### Synonym Recognition | ||
- ### Named Entity Recognition | ||
Our bot now has the ability to recognize synonyms for extracted entities from user messages. We even used this to implement some recognitions for spelling mistakes! | ||
(although this isn't the intended use). | ||
|
||
By adding this feature to our bot, we directly improve the flow of language to ensure that the bot doesn't break when the user enters a synonym for | ||
an entity that the bot would fail to pick up on if this feature wasn't implemented. Here is a snippet of a conversation showing this feature in action: | ||
data:image/s3,"s3://crabby-images/a903f/a903fc2fb19d8eabeaf2502e14db8a5c19e4ffe0" alt="Bot recognizes synonyms in user's message" | ||
|
||
Here the bot recognizes `the funny` as a synonym for `joke`, so it maps it to the correct entity and continues the conversation accordingly. | ||
- ### Sentiment Analysis | ||
JokeBot now uses NLTK's `sentiment` package to categorize user messages with sentiments like `pos, neg,` or `neu`. | ||
|
||
By adding this feature to our bot, we used it to handle the feedback the user gives to the bot's jokes and display other messages | ||
accordingly. This was achieved by creating a custom component for Sentiment Analysis alongside a custom action. Since we also implicitly built sentiment analysis into our bot, | ||
it cannot directly be seen in conversation, so here are a few snippets of the shell that shows the sentiment extracted from a few messages: | ||
- Positive Sentiment: | ||
data:image/s3,"s3://crabby-images/6a0eb/6a0eb8744e49ef3aa549ea48210bc63b70c32ee8" alt="Bot extracts a positive sentiment" | ||
- Neutral Sentiment: | ||
data:image/s3,"s3://crabby-images/516c5/516c53a8029dd800a67bcbdf153235974cf0b810" alt="Bot extracts a neutral sentiment" | ||
- Negative Sentiment: | ||
data:image/s3,"s3://crabby-images/341b7/341b7b52678081832e5d391a48339613e086b262" alt="Bot extracts a negative sentiment" | ||
|
||
Here the bot detects the correct sentiment from the user messages. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
Binary file not shown.
Binary file not shown.
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.