-
Notifications
You must be signed in to change notification settings - Fork 94
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #41 from dgallitelli/main
Adding No-Code Generative AI Lab with SageMaker Canvas
- Loading branch information
Showing
21 changed files
with
240 additions
and
0 deletions.
There are no files selected for viewing
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.
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.
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.
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 |
---|---|---|
@@ -0,0 +1,157 @@ | ||
# Lab 1 - SageMaker Canvas for Generative AI | ||
|
||
In this lab, we will see how to use Amazon SageMaker Canvas to explore and use state-of-the-art Foundation Models from Amazon Bedrock and Amazon SageMaker JumpStart, without writing a single line of code. | ||
|
||
## Agenda | ||
|
||
1. [What is Amazon SageMaker Canvas?](#what-is-amazon-sagemaker-canvas) | ||
2. [SageMaker Canvas Chat Experience](#sagemaker-canvas-chat-experience) | ||
3. [Use case: Contact Center Intelligence](#use-case-contact-center-intelligence) | ||
|
||
## What is Amazon SageMaker Canvas? | ||
|
||
Amazon SageMaker Canvas is a no-code Machine Learning (ML) service that allows everyone to use and create machine learning models without requiring machine learning expertise or coding skills. You can use SageMaker Canvas to: | ||
|
||
- access state-of-the-art Generative AI models in a chatbot-like UX (powered by Amazon Bedrock and Amazon SageMaker JumpStart) | ||
- use ready-to-use ML models to solve common tasks across Computer Vision, Natural Language Processing and Document Intelligence | ||
- prepare your datasets for Machine Learning with repeatable data flows | ||
- build your own ML models and collaborate with data scientists | ||
- generate accurate predictions on your ML models or models that have been shared with you, either manually or on a schedule | ||
|
||
## SageMaker Canvas Chat Experience | ||
|
||
data:image/s3,"s3://crabby-images/8ec1a/8ec1a4e2e751d5d547213ca55b34fb7966b67903" alt="" | ||
|
||
SageMaker Canvas chatbot experience allows users to leverage foundation models from Amazon Bedrock and Amazon SageMaker JumpStart in a chatbot UX, without the need to know about Generative AI, APIs, endpoints, tokens, parameters, chat interfaces, etc. The chat interface is pre-built in the SageMaker Canvas app users are already familiar with, in the ready-to-use models tab. | ||
|
||
Once launched SageMaker Canvas chatbot experience, users can start interacting with foundation models with the chat interface, asking questions and providing prompts. Users can choose which model they want to interact with, from either Amazon Bedrock (Amazon and partners' models) or Amazon SageMaker JumpStart (open-source models). Users can also compare multiple models at once, to select whichever fits better the style of answers they're looking for. | ||
|
||
### Access Amazon SageMaker Canvas | ||
|
||
In order to access the Amazon SageMaker Canvas chatbot experience, start by accessing Amazon SageMaker Canvas. You can do so by clicking on this [link to the AWS Management Console](https://catalog.workshops.aws/canvas-immersion-day/en-US/3-genai/1-canvas-chat-features/console.aws.amazon.com/sagemaker/home/canvas-landing/) and click on Open Canvas after having selected the right domain and user profile. | ||
|
||
data:image/s3,"s3://crabby-images/ccf4f/ccf4f4c820d19eff8be906ef52640d4708a777ba" alt="" | ||
|
||
If the application wasn't running before, you will see a loading screen like the following: | ||
|
||
data:image/s3,"s3://crabby-images/a48fe/a48fe15d4fe1e5fb55c3c6c03baedf68a5af7fe5" alt="" | ||
|
||
You can also access SageMaker Canvas directly from SageMaker Studio: | ||
|
||
data:image/s3,"s3://crabby-images/a37f8/a37f8c4fd8d765d7627f68e76f82d8805555a281" alt="" | ||
|
||
Once you're in the SageMaker Canvas app, you will see a purple banner if this is your first time on Amazon SageMaker Canvas. From there, you can click the "Get started now" button. If the banner is not available in your SageMaker Canvas app, you can access Canvas chatbot experience from the list of ready-to-use models under "**Generate, extract and summarize content**". | ||
|
||
### Overview of the Canvas chat experience | ||
|
||
data:image/s3,"s3://crabby-images/3b3f1/3b3f1dea61273a32cb9e5e29a67ee597a575c1bc" alt="" | ||
|
||
SageMaker Canvas chatbot experiencehas four main components in the main app: | ||
|
||
1. the model selector | ||
1. the chat context | ||
1. the user input | ||
1. the index selector and "Query documents" toggle | ||
|
||
As a user, you can provide a question in the input box, and SageMaker Canvas will take care of formatting it in the right way to interact with the model chosen in the model selector. The context of the conversation is kept in the UI and it is used throughout the conversation - meaning that Canvas will be able to refer to previous portions of the conversation to reply to your questions and therefore answer contextually. | ||
|
||
SageMaker Canvas also provides some example prompts which can be useful to see how you can use the chat experience. For this demo, we'll click on the first suggested prompt and send it to the default model, Anthropic Claude V2 running on Amazon Bedrock. | ||
|
||
### Available Models | ||
|
||
SageMaker Canvas supports 9 foundation models from Amazon Bedrock and 13 open-source models from Amazon SageMaker JumpStart: | ||
|
||
data:image/s3,"s3://crabby-images/30eac/30eacecffaa8255a1f92772f429980d159c48ea9" alt="Bedrock models" | ||
|
||
With respect to pricing, Amazon SageMaker Canvas **does not charge any extra** on top of the services being queried behind the scenes, and the hourly pricing for the Canvas app itself. It is important to note that Amazon Bedrock models are priced by the token, and do not require deployment on an endpoint. SageMaker Canvas open-source models are powered by Amazon SageMaker JumpStart - this means that, in order to use models, you will have to deploy them to an Amazon SageMaker endpoint. Amazon SageMaker Canvas takes care of automatically shutting down the endpoints after two hours of inactivity, however this requires the SageMaker Canvas app to be running. | ||
|
||
For the rest of this lab, we will be using the **Anthropic Claude 2** model. It should be selected by default in the model selector. However, all of the labs can be run with any of the models available, but results may vary. | ||
|
||
data:image/s3,"s3://crabby-images/9863d/9863d0d69adce496f14f27b9ccce5dd2cb5fdade" alt="" | ||
|
||
### Your first chat | ||
|
||
data:image/s3,"s3://crabby-images/855b1/855b11b393fa2820c1d01c4ac79d94362fea068d" alt="" | ||
|
||
Chatting with SageMaker Canvas and the models behind the scenes is as easy as typing your question in the input box at the bottom of the screen, and send it! Canvas will forward the query to the Foundation Model and stream back the answer in the UI. | ||
|
||
SageMaker Canvas also allows you to control LLM inference parameters like temperature, top k or top P. To do so, just click on the setting icon right next to the model selector. | ||
|
||
data:image/s3,"s3://crabby-images/1c285/1c285a25dbefcfbdee61a56c65f1b767736eddbc" alt="Alt text" | ||
|
||
### Comparing Models | ||
|
||
One of the most powerful capabilities of SageMaker Canvas is the capability to compare multiple models at once, so that a user can choose the model that works best for their use case. To do so, it is sufficient to select the "**+ Compare**" button at the top right of the screen, select a new model to compare against, and ask the question. SageMaker Canvas will take care of generating the right prompt for each model, and return the answer from each of those, side by side for easy comparison. Currently, you can compare up to three different models at once. | ||
|
||
1. Start a **New Chat** by clicking on the button at the top left of the screen | ||
1. Then, click the **Compare** button at the top right of the screen | ||
1. From this view, you will see a new **model selector**, where you can choose the model to compare against. Choose **Llama-2-70b-Chat**. | ||
1. Send your query, and see the results in parallel! | ||
|
||
Each of the answers can be re-generated or copied individually of course. | ||
|
||
data:image/s3,"s3://crabby-images/6603c/6603c3943fc07acee4404244157bc9c14669a83a" alt="" | ||
|
||
## Use case: Contact Center Intelligence | ||
|
||
Let's take a look at how Amazon Sagemaker Canvas chatbot experience powered by Generative AI can help a contact center agent in reviewing existing interactions to bring insights that are hard to get from traditional tools. To do so, we have come up with a simulated conversation between an AWS customer and AWS Support. The AWS customers asks questions about SageMaker Canvas, and then reacts positively to the comments of AWS Support. The conversation is the following: | ||
|
||
``` | ||
Customer: Hi there! I'm interested in using SageMaker Canvas and was wondering if it supports any generative AI capabilities? | ||
Support: Hello! Yes, SageMaker Canvas does support generative AI models like text generation through its chatbot-like interface. | ||
Customer: Oh great, that's awesome to hear! What kind of interface does Canvas provide for working with generative AI? | ||
Support: The interface is chatbot-like, so you can have natural conversations with the generative AI models to get generated text responses. It makes it very intuitive to work with models like text generation. | ||
Customer: Amazing! I'm really excited to try this out on Canvas. I can't wait to start building with generative AI. | ||
Support: Glad to hear it! Please feel free to try out SageMaker Canvas and its generative AI capabilities by following our SageMaker Canvas Immersion Day workshop. It's a great way to get hands-on experience with Canvas. | ||
Customer: Thank you, I really appreciate the guidance! I'll be sure to check out that workshop. | ||
Support: You're very welcome! Let me know if you have any other questions. | ||
``` | ||
|
||
### Basic information about prompt engineering | ||
|
||
In order to use models at their fullest, it is a good practice to learn how to write good prompts that the model can interpret correctly and understand how to extract information. This is called prompt engineering. Usually a prompt is composed of a combination of any of these parts: | ||
|
||
- Instruction - a specific task or instruction you want the model to perform | ||
- Context - external information or additional context that can steer the model to better responses | ||
- Input Data - the input or question that we are interested to find a response for | ||
- Output Indicator - the type or format of the output. | ||
|
||
In our case, we want the bot to help us make sense of the Support conversation. So, we instruct the model to know that we are requiring it to make sense of a customer conversation, we provide the conversation as context, and finally we give our question and goal as input. Additionally, we delimit the context with tags to simplify the task of identifying the conversation for the bot - this is not strictly required but it is a good practice. The final prompt will look like the following: | ||
|
||
``` | ||
Here is a conversation between an AWS Support Engineer and an AWS customer. You understand the conversation delimited by <context> tags and you provide answers based on this context. | ||
<context> | ||
Customer: Hi there! I'm interested in using SageMaker Canvas and was wondering if it supports any generative AI capabilities? | ||
Support: Hello! Yes, SageMaker Canvas does support generative AI models like text generation through its chatbot-like interface. | ||
Customer: Oh great, that's awesome to hear! What kind of interface does Canvas provide for working with generative AI? | ||
Support: The interface is chatbot-like, so you can have natural conversations with the generative AI models to get generated text responses. It makes it very intuitive to work with models like text generation. | ||
Customer: Amazing! I'm really excited to try this out on Canvas. I can't wait to start building with generative AI. | ||
Support: Glad to hear it! Please feel free to try out SageMaker Canvas and its generative AI capabilities by following our SageMaker Canvas Immersion Day workshop. It's a great way to get hands-on experience with Canvas. | ||
Customer: Thank you, I really appreciate the guidance! I'll be sure to check out that workshop. | ||
Support: You're very welcome! Let me know if you have any other questions. | ||
</context> | ||
Please summarize the context and provide informations about the sentiment of the customer. | ||
``` | ||
|
||
### Sending the prompt to the model | ||
|
||
Copy the text above and send it to the model of your choice. You should now get an answer similar to the following one: | ||
|
||
data:image/s3,"s3://crabby-images/dc8a6/dc8a6886ffbf0e34202123b657734346df276544" alt="Alt text" | ||
|
||
The model correctly detects that the customer asked about SageMaker Canvas Generative AI capabilities, and is happy about the answers provided. Let's try to ask if the AWS Support has any actions to take after the session: | ||
|
||
data:image/s3,"s3://crabby-images/35d8d/35d8d9b2b5ed3292c34a74651916c2b3296d3916" alt="Alt text" | ||
|
||
As you can see, no actions are required from the AWS Support Engineer at the end of this conversation. Note that we didn't have to reformulate the context and instruction again, since this is kept in the "memory" buffer of the SageMaker Canvas app. Try to ask additional questions to the bot based on this context. For example: | ||
|
||
1. Write a follow-up email that the AWS Support should send to the customer to recap the conversation | ||
2. Write a one-line report about the conversation | ||
3. What are the AWS Support recommendation to the customer in order to get started? | ||
4. What is Amazon SageMaker Canvas? | ||
|
||
You can try and send the initial prompts and the follow-up questions to multiple models at once, to see how they behave. SageMaker Canvas allows the capability to compare multiple models, by simply clicking the Compare button on the top right of your screen. | ||
|
||
data:image/s3,"s3://crabby-images/173a9/173a9df6177e7c6f80e35250cfd0b72614952ada" alt="Alt text" |
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 |
---|---|---|
@@ -0,0 +1,83 @@ | ||
# Lab 2 - No-Code Enterprise Search (Retrieval Augmented Generation) with Amazon SageMaker Canvas | ||
|
||
SageMaker Canvas lets users ask questions or have conversations and get responses that are grounded in their enterprise’s data. Ensuring the results they get back are specific to their context and not some generic replies. This release makes it possible to connect Canvas directly to your existing knowledge-bases or upload new knowledge as/when required and be able to perform conversation-AI in a friction-less manner. A cloud administrator can configure [Amazon Kendra](https://aws.amazon.com/kendra/) indexes as data sources for SageMaker Canvas users, while SageMaker Canvas takes care of building the connection to Amazon Kendra, providing intuitive controls over chat experiences and without a single line of code. Canvas users can ideate, research and explore knowing that the output will always be backed by their sources-of-truth. | ||
|
||
data:image/s3,"s3://crabby-images/2837e/2837e32a591ead9c779eaf37e31a6bd6bb004d2b" alt="" | ||
|
||
As part of this lab, we will wear the shoes of an operator of a large oil & gas company. We'll be searching through a large set of instruction and maintenance manuals for actuators, which are highly-precise components used to control valve pressures and remotely open and close valves in pipelines. These technical manuals serve as a good example of querying and gathering insights from specialized enterprise data and documents. | ||
|
||
**Note:** to run this lab, you will need to create an Amazon Kendra index. Make sure to have all the right permissions to do so, then review and understand [Amazon Kendra pricing](https://aws.amazon.com/kendra/pricing) before proceeding. Running this lab is free for the first month, leading in additional charges after it. The sync operation will cost less than $1 in total. | ||
|
||
## Creating the Amazon Kendra Index | ||
|
||
1. Download the dataset from [here](https://static.us-east-1.prod.workshops.aws/public/b74dd72c-ad18-450e-bbbf-ae673a9e6c58/assets/datasets/industrial-documents.zip) and unzip it in your PC | ||
1. Upload all PDFs to an **Amazon S3** bucket of your choice. If possible, create a new Amazon S3 bucket, and upload all the files in a single folder | ||
1. Create the Amazon Kendra index. To do so, search for Amazon Kendra in the AWS Management Console, then click **Create index** | ||
1. Provide an index name `canvas-immday`, then create a new IAM role, then click **Next**; | ||
1. Leave the settings to default for Access Control Settings (No) and User-group expansion (None), then click **Next**; | ||
1. For provisioning editions, select **Developer edition** (covered by Free Tier), then click **Next**; | ||
1. Proceed to **Create**; | ||
1. Creating the index can take up to 30 minutes. | ||
1. Once the index is created, **add a data source**, selecting the bucket where you uploaded the dataset previously. If you've selected an existing bucket, provide the path where your data is stored | ||
1. Once you've configured the data source, click on the button **Sync now** at the top right of your screen. This will start the indexing process of your data. | ||
|
||
|
||
## Configuring SageMaker Canvas | ||
|
||
In order to give SageMaker Canvas access to the Kendra index we have just created, we need to update some configuration parameters. | ||
|
||
1. Search **Amazon SageMaker** in the AWS Management Console, then select **Domains** on the left, then select the domain you want to use | ||
1. In the user profile list, select your user, then click **Edit** at the bottom right of the screen | ||
1. On the left-hand menu, click on **Step 4 - Canvas settings**, then scroll down to **Canvas Ready-to-use models configuration** | ||
1. Here, make sure that **Enable document query using Amazon Kendra** is enabled, then in the dropdown below select `canvas-immday` as index, or select the name you chose previously | ||
1. Scroll down and click on **Submit** | ||
|
||
data:image/s3,"s3://crabby-images/c4b5f/c4b5f9d98e65f2680e40be4ca4b6b5423d07815a" alt="" | ||
|
||
To make sure the changes are propagated, click on **Delete app** before opening again SageMaker Canvas. | ||
|
||
data:image/s3,"s3://crabby-images/57810/578102f0b91565dc7549b9462f398a279cb5c0c3" alt="Alt text" | ||
|
||
## Querying your documents | ||
|
||
First of all, access the chatbot experience from the SageMaker Canvas ready-to-use models tab. | ||
|
||
data:image/s3,"s3://crabby-images/8ec1a/8ec1a4e2e751d5d547213ca55b34fb7966b67903" alt="" | ||
|
||
Once there, select the model(s) that you want to use for this experiment. We will start with **Anthropic Claude 2**. To query your Amazon Kendra index, make sure that the **toggle "Query documents" is activated**, and select the index among the list of available indices. | ||
|
||
Once the index is selected, you can go ahead and start asking questions. Here is an example query: | ||
|
||
> What do I do if my L Series type C double acting actuator is leaking? | ||
For the questions asked, the chat will show the answer generated by the foundation model, along with the source documents that contributed to generating the answer. When clicking any of the source documents, SageMaker Canvas opens a preview of the document, highlighting the excerpt used by the foundation model. | ||
|
||
data:image/s3,"s3://crabby-images/36f69/36f69750e3eef3ca1f72a91132e25cb778958735" alt="Alt text" | ||
|
||
Of course, it is possible to compare the answers generated by different models against the same query. Each of them will provide answers generated by the model, and the sources associated to the answer generated: | ||
|
||
data:image/s3,"s3://crabby-images/b9fc1/b9fc18e96933657665e6724f4e3c7a0c188e9364" alt="Alt text" | ||
|
||
Here is a list of other questions you can try with the "Query documents" toggle on. We also suggest giving a try and asking the same questions without the toggle enabled, to see how the hallucinated/confabulated answer differs from the factual answer generated from the knowledge base. Copy them one by one and test them against one or more models. | ||
|
||
``` | ||
What continuous immersion ratings are F2-Series actuators capable of achieving? | ||
What is the maximum torque resistance that the F2 actuator Size 2200 can overcome without experiencing increased wear and early failure? | ||
Where do I find the travel adjustment for Q-Series and F-series quarter turn actuators? | ||
Summarize the piston and end cap seal replacement for the Q-Series And F-Series Quarter Turn Actuators? | ||
What are the key steps in installing the APCI.056 retainer plate for a Q2 series actuator? | ||
How do I replace the yoke seal and bushing for a D Series Double Acting Actuator? | ||
``` | ||
|
||
## (Optional) What if I wanted to use my own documents? | ||
|
||
Now that you have tested querying the documents provided above (pre-deployed in event environments provided by AWS, AKA Workshop Studio), maybe you want to be able to upload your own documents and query them. In order to do so, you will have to go through the following steps: | ||
|
||
1. Go to Amazon S3, identify the bucket used by Amazon Kendra, and upload your PDFs | ||
1. Go to Amazon Kendra, then: | ||
1. Identify the index you want to use, in our case CanvasImmersionDayIndex | ||
1. Go to the Data Sources and find the one already set-up, and click on the Sync button | ||
1. Wait for the sync to be complete | ||
1. Go back to Amazon SageMaker Canvas, and start querying your new documents | ||
|
||
data:image/s3,"s3://crabby-images/2f40f/2f40f9e4ddb06d9c8611c1ae4030807b5fee1657" alt="" |