4.1 KiB
Blenderbot Small
Note that [BlenderbotSmallModel
] and
[BlenderbotSmallForConditionalGeneration
] are only used in combination with the checkpoint
facebook/blenderbot-90M. Larger Blenderbot checkpoints should
instead be used with [BlenderbotModel
] and
[BlenderbotForConditionalGeneration
]
Overview
The Blender chatbot model was proposed in Recipes for building an open-domain chatbot Stephen Roller, Emily Dinan, Naman Goyal, Da Ju, Mary Williamson, Yinhan Liu, Jing Xu, Myle Ott, Kurt Shuster, Eric M. Smith, Y-Lan Boureau, Jason Weston on 30 Apr 2020.
The abstract of the paper is the following:
Building open-domain chatbots is a challenging area for machine learning research. While prior work has shown that scaling neural models in the number of parameters and the size of the data they are trained on gives improved results, we show that other ingredients are important for a high-performing chatbot. Good conversation requires a number of skills that an expert conversationalist blends in a seamless way: providing engaging talking points and listening to their partners, and displaying knowledge, empathy and personality appropriately, while maintaining a consistent persona. We show that large scale models can learn these skills when given appropriate training data and choice of generation strategy. We build variants of these recipes with 90M, 2.7B and 9.4B parameter models, and make our models and code publicly available. Human evaluations show our best models are superior to existing approaches in multi-turn dialogue in terms of engagingness and humanness measurements. We then discuss the limitations of this work by analyzing failure cases of our models.
This model was contributed by patrickvonplaten. The authors' code can be found here.
Usage tips
Blenderbot Small is a model with absolute position embeddings so it's usually advised to pad the inputs on the right rather than the left.
Resources
BlenderbotSmallConfig
autodoc BlenderbotSmallConfig
BlenderbotSmallTokenizer
autodoc BlenderbotSmallTokenizer - build_inputs_with_special_tokens - get_special_tokens_mask - create_token_type_ids_from_sequences - save_vocabulary
BlenderbotSmallTokenizerFast
autodoc BlenderbotSmallTokenizerFast
BlenderbotSmallModel
autodoc BlenderbotSmallModel - forward
BlenderbotSmallForConditionalGeneration
autodoc BlenderbotSmallForConditionalGeneration - forward
BlenderbotSmallForCausalLM
autodoc BlenderbotSmallForCausalLM - forward
TFBlenderbotSmallModel
autodoc TFBlenderbotSmallModel - call
TFBlenderbotSmallForConditionalGeneration
autodoc TFBlenderbotSmallForConditionalGeneration - call
FlaxBlenderbotSmallModel
autodoc FlaxBlenderbotSmallModel - call - encode - decode
FlaxBlenderbotForConditionalGeneration
autodoc FlaxBlenderbotSmallForConditionalGeneration - call - encode - decode