Skip to content

iamsamkhan/AWS-Bedrock-And-Langchain

Repository files navigation

AWS-Bedrock-And-Langchain.

shamshad ahmed

Connect with me on social media: shamshad ahmed.

LinkedIn GitHub Medium Twitter Discord Shamshad ahmed

Lab 4 - Conversational Interfaces (Chatbots)

Overview

Conversational interfaces such as chatbots and virtual assistants can be used to enhance the user experience for your customers.Chatbots uses natural language processing (NLP) and machine learning algorithms to understand and respond to user queries. Chatbots can be used in a variety of applications, such as customer service, sales, and e-commerce, to provide quick and efficient responses to users. They can be accessed through various channels such as websites, social media platforms, and messaging apps.

Chatbot using Amazon Bedrock

Amazon Bedrock - Conversational Interface

Use Cases

  1. Chatbot (Basic) - Zero Shot chatbot with a FM model
  2. Chatbot using prompt - template(Langchain) - Chatbot with some context provided in the prompt template
  3. Chatbot with persona - Chatbot with defined roles. i.e. Career Coach and Human interactions
  4. Contextual-aware chatbot - Passing in context through an external file by generating embeddings.

Langchain framework for building Chatbot with Amazon Bedrock

In Conversational interfaces such as chatbots, it is highly important to remember previous interactions, both at a short term but also at a long term level.

LangChain provides memory components in two forms. First, LangChain provides helper utilities for managing and manipulating previous chat messages. These are designed to be modular and useful regardless of how they are used. Secondly, LangChain provides easy ways to incorporate these utilities into chains. It allows us to easily define and interact with different types of abstractions, which make it easy to build powerful chatbots.

Building Chatbot with Context - Key Elements

The first process in a building a contextual-aware chatbot is to generate embeddings for the context. Typically, you will have an ingestion process which will run through your embedding model and generate the embeddings which will be stored in a sort of a vector store. In this example we are using a GPT-J embeddings model for this

Embeddings

Second process is the user request orchestration , interaction, invoking and returing the results

Chatbot

Architecture [Context Aware Chatbot]

4

In this architecture:

  1. The question asked to the LLM, is run through the embeddings model
  2. The context documents are embedded using the Amazon Titan Embeddings Model and stored in the vector database.
  3. The embedded text is then input to the FM for contextual search and including the chat history
  4. The FM model then gives you the results based on the context.

Setup

Before running any of the labs in this section ensure you've run the [Bedrock boto3 setup notebook](../AWS_Bedrock\AWS Bedrock And Langchain\main.py#Prerequisites).

Notebooks

This module provides you notebooks for the same pattern. You can experience conversation with Anthropic Claude as well as Amazon Titan Text Large to experience each the conversational power of model.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published