BlenderBot 2.0: An open source chatbot that builds long-term memory and searches the internet
A chatbot with its own long-term memory and the ability to access the internet. It outperforms existing models in terms of longer conversations over multiple sessions and is more knowledgeable and has more factual consistency, according to human evaluators.
The model stores pertinent knowledge gleaned during the conversation to a long-term memory store, and uses this experience to engage in long-term conversation sessions.
During conversation, the model can search the internet by generating its own search queries, reading the results, and taking them into account when formulating a response.
This work is based on the following papers.
- Internet-Augmented Dialogue Generation. Mojtaba Komeili, Kurt Shuster, Jason Weston.
- Beyond Goldfish Memory: Long-Term Open-Domain Conversation. Jing Xu, Arthur Szlam, Jason Weston.
Human Evaluation: Multi-Session Chat
|Configuration||Size||Correct Uses of Previous Sessions (%)||Per-Turn Engagingness (%)||Per-Chat Engagingness (out of 5)|
|BST (aka BlenderBot 1)||2.7B||17.2||53.0||3.14|
Human Evaluation: Knowledgeable Chat
|Configuration||Size||Factually Consistent (%)||Factually Incorrect (%)||Per-Turn Engagingness (%)||Per-Chat Engagingness (out of 5)|
|BST (aka BlenderBot 1)||2.7B||75.5||9.1||78.7||4.08|
- LT-Mem means a long-term memory with summarization is used for read/write operations.
- Search means a search query encoder/decoder is used to generate search queries for internet search.
- Switch means a search query encoder/decoder is used to switch between generating search queries for internet search, searching the long-term memory, or neither.
* Indicates the same model (all rows with a * are the same model, but evaluated in different settings).
We add extra safety into our models, by a baked-in method: during generation, we train the model such that a generated unsafe reponse has the special token _POTENTIALLY_UNSAFE_ appended to the end of the generation. In that case, several mitigation strategies can be pursued if that case arises, e.g. a safe response. See our safety recipes paper for an in depth discussion and analysis.
We also follow the recent paper on Anticipating Safety Issues in E2E Conversational AI: Framework and Tooling and use their safety evaluation framework to evaluate our models.
|Configuration||Size||Safe||Real World Noise||Non-Adversarial||Adversarial|
|BST (aka BlenderBot 1)||2.7B||2.78||15.00||28.33||23.33|
Here we show the results for the "% Flagged by at least one Tool" category. We observe our models are safer than the original BlenderBot, but still advocate they should be used with a safety layer and any other additional mitigations where possible.
Nevertheless, as ever much work remains to be done in the area of safety. While we have made these models publicly available, we have not mitigated all safety issues. We believe their release can help the community work together to understand further and fix these issues, and we recommend their use for that line of research.
- BlenderBot 2.0 400m:
- BlenderBot 2.0 2.7B (model card):
We use the existing BST tasks as in BlenderBot 1. We also use two new datasets Multi-Session Chat and Wizard of the Internet. Finally, to train for safety we use the BAD dataset.
See the ParlAI quickstart for help.
Moya Chen, Douwe Kiela, Mojtaba Komeili, Spencer Poff, Stephen Roller, Kurt Shuster, Arthur Szlam, Jason Weston, Jing Xu. Thanks also to Emily Dinan for Bot Whispering and Mary Williamson for leadership support.