From ef581596242211214d84f7a4a9b1a9aeeb8a04e7 Mon Sep 17 00:00:00 2001 From: Rajiv Shah Date: Mon, 30 Sep 2024 13:43:18 -0500 Subject: [PATCH] Quick start for Llama 3.2 Vision Models on Snowflake Notebooks / Container Runtimes (#1612) * added notebook llama32v * removed image --- site/package-lock.json | 24 +-- site/package.json | 2 +- .../notebook-llama32v/notebook-llama32v.md | 159 ++++++++++++++++++ 3 files changed, 172 insertions(+), 13 deletions(-) create mode 100644 site/sfguides/src/notebook-llama32v/notebook-llama32v.md diff --git a/site/package-lock.json b/site/package-lock.json index cff1b5d59..3bf4c483f 100644 --- a/site/package-lock.json +++ b/site/package-lock.json @@ -44,7 +44,7 @@ "jshint-stylish": "^2.2.1", "merge-stream": "^1.0.1", "path": "^0.12.7", - "postcss": "^8.4.38", + "postcss": "^8.4.47", "postcss-syntax": "^0.34.0", "sass": "^1.49.11", "swig-templates": "^2.0.3", @@ -11540,9 +11540,9 @@ "optional": true }, "node_modules/picocolors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", - "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.0.tgz", + "integrity": "sha512-TQ92mBOW0l3LeMeyLV6mzy/kWr8lkd/hp3mTg7wYK7zJhuBStmGMBG0BdeDZS/dZx1IukaX6Bk11zcln25o1Aw==", "dev": true }, "node_modules/picomatch": { @@ -11651,9 +11651,9 @@ } }, "node_modules/postcss": { - "version": "8.4.38", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", - "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", + "version": "8.4.47", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.47.tgz", + "integrity": "sha512-56rxCq7G/XfB4EkXq9Egn5GCqugWvDFjafDOThIdMBsI15iqPqR5r15TfSr1YPYeEI19YeaXMCbY6u88Y76GLQ==", "dev": true, "funding": [ { @@ -11671,8 +11671,8 @@ ], "dependencies": { "nanoid": "^3.3.7", - "picocolors": "^1.0.0", - "source-map-js": "^1.2.0" + "picocolors": "^1.1.0", + "source-map-js": "^1.2.1" }, "engines": { "node": "^10 || ^12 || >=14" @@ -13853,9 +13853,9 @@ } }, "node_modules/source-map-js": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz", - "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==", + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz", + "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==", "dev": true, "engines": { "node": ">=0.10.0" diff --git a/site/package.json b/site/package.json index c9f59b8e3..4e64b6243 100644 --- a/site/package.json +++ b/site/package.json @@ -42,7 +42,7 @@ "jshint-stylish": "^2.2.1", "merge-stream": "^1.0.1", "path": "^0.12.7", - "postcss": "^8.4.38", + "postcss": "^8.4.47", "postcss-syntax": "^0.34.0", "sass": "^1.49.11", "swig-templates": "^2.0.3", diff --git a/site/sfguides/src/notebook-llama32v/notebook-llama32v.md b/site/sfguides/src/notebook-llama32v/notebook-llama32v.md new file mode 100644 index 000000000..2f45c67ba --- /dev/null +++ b/site/sfguides/src/notebook-llama32v/notebook-llama32v.md @@ -0,0 +1,159 @@ +author: Rajiv Shah +id: notebook-llama32v +summary: This guide will walk show you how to use LLama 3.2 Vision Models on Snowflake Notebooks with Container Runtime with Transformers +categories: Getting-Started +environments: web +status: Published +feedback link: https://github.com/Snowflake-Labs/sfguides/issues +tags: Getting Started, Data Science + +# Getting Started with Llama 3.2 Vision Models on Snowflake Notebooks + +## Overview +Duration: 1 + +Leverage the LLama 3.2 Vision models with Snowflake Notebooks on Snowpark Container Services through Container Runtime. This quickstart will show you how you can: + +- Turn an image into text +- Turn an image of a table into a JSON representation. +- Understand an invoice document + +This is possible by combining the latest vision language models with Snowpark Container Services, which gives you a flexible container infrastructure for supporting AI/ML workloads. + +This Quickstart will guide you through the steps of running Snowflake Notebooks with Container Runtime. Once you have a GPU enabled runtime, you can then use the attached notebook to start using the Llama 3.2 Vision model using Transformers. Additionally, once you setup your container environment, this notebook will support using other Transformers models with some slight modifications. + +### Prerequisites +- Access to a Snowflake account with Accountadmin. +- Access to run Notebooks in Snowflake +- Foundational knowledge of Data Science workflows +- Requested access to the Meta models at Hugging Face +- Running the 11b version of the model requires > 30GB of GPU memory + +### What You Will Learn +- The key features of Snowflake Notebooks with Container Runtime +- Using models with Hugging Face Transformers + +### What You’ll Need +- A [Snowflake](https://app.snowflake.com/) Account +- A [Hugging Face](https://huggingface.co/) Account + +### What You’ll Build +- A Snowflake Notebook that runs on Snowpark Container Services +- Perform inference or predictions to convert text/images to text using the Llama 3.2 Vision model + + +## Setup Your Account +Duration: 2 + +Complete the following steps to setup your account: +- Navigate to Worksheets, click "+" in the top-right corner to create a new Worksheet, and choose "SQL Worksheet". +- Paste the following SQL in the worksheet +- Adjust to your user +- Run all commands to create Snowflake objects +- Part of this is creating the external integration for installing libraries and downloading models + +```sql +USE ROLE accountadmin; +CREATE OR REPLACE DATABASE container_runtime_lab; +CREATE SCHEMA notebooks; + +CREATE OR REPLACE ROLE container_runtime_lab_user; +GRANT ROLE container_runtime_lab_user to USER ; + +GRANT USAGE ON DATABASE container_runtime_lab TO ROLE container_runtime_lab_user; +GRANT ALL ON SCHEMA container_runtime_lab.notebooks TO ROLE container_runtime_lab_user; +GRANT CREATE STAGE ON SCHEMA container_runtime_lab.notebooks TO ROLE container_runtime_lab_user; +GRANT CREATE NOTEBOOK ON SCHEMA container_runtime_lab.notebooks TO ROLE container_runtime_lab_user; +GRANT CREATE SERVICE ON SCHEMA container_runtime_lab.notebooks TO ROLE container_runtime_lab_user; + +CREATE OR REPLACE WAREHOUSE CONTAINER_RUNTIME_WH AUTO_SUSPEND = 60; +GRANT ALL ON WAREHOUSE CONTAINER_RUNTIME_WH TO ROLE container_runtime_lab_user; + +-- Create and grant access to compute pools +CREATE COMPUTE POOL IF NOT EXISTS gpu_nv_m_nodes + MIN_NODES = 1 + MAX_NODES = 5 + INSTANCE_FAMILY = GPU_NV_M; + +CREATE COMPUTE POOL IF NOT EXISTS gpu_nv_l_nodes + MIN_NODES = 1 + MAX_NODES = 5 + INSTANCE_FAMILY = GPU_NV_L; + +GRANT USAGE ON COMPUTE POOL gpu_nv_m_nodes TO ROLE container_runtime_lab_user; +GRANT USAGE ON COMPUTE POOL gpu_nv_l_nodes TO ROLE container_runtime_lab_user; + +-- Create and grant access to EAIs +-- Substep #1: create network rules (these are schema-level objects; end users do not need direct access to the network rules) + +create network rule allow_all_rule + TYPE = 'HOST_PORT' + MODE= 'EGRESS' + VALUE_LIST = ('0.0.0.0:443','0.0.0.0:80'); + +-- Substep #2: create external access integration (these are account-level objects; end users need access to this to access the public internet with endpoints defined in network rules) + +CREATE OR REPLACE EXTERNAL ACCESS INTEGRATION allow_all_integration + ALLOWED_NETWORK_RULES = (allow_all_rule) + ENABLED = true; + +CREATE OR REPLACE NETWORK RULE pypi_network_rule + MODE = EGRESS + TYPE = HOST_PORT + VALUE_LIST = ('pypi.org', 'pypi.python.org', 'pythonhosted.org', 'files.pythonhosted.org'); + +CREATE OR REPLACE EXTERNAL ACCESS INTEGRATION pypi_access_integration + ALLOWED_NETWORK_RULES = (pypi_network_rule) + ENABLED = true; + +CREATE OR REPLACE NETWORK RULE HF_NETWORK_RULE + MODE = EGRESS + TYPE = HOST_PORT + VALUE_LIST = ('huggingface.co', 'cdn-lfs.huggingface.co','cdn-lfs-us-1.huggingface.co', 'cdn-lfs-us-1.hf.co'); + +CREATE EXTERNAL ACCESS INTEGRATION hf_access_integration + ALLOWED_NETWORK_RULES = (HF_NETWORK_RULE) + ENABLED = true; + +GRANT USAGE ON INTEGRATION allow_all_integration TO ROLE container_runtime_lab_user; +GRANT USAGE ON INTEGRATION pypi_access_integration TO ROLE container_runtime_lab_user; +GRANT USAGE ON INTEGRATION hf_access_integration TO ROLE container_runtime_lab_user; + +``` + +## Run the Notebook +Duration: 15 + +### Get the Notebook into Snowflake +- Download the notebook from [https://github.com/rajshah4/snowflake-notebooks/blob/main/Models/Llama3_2_Vision.ipynb](https://github.com/rajshah4/snowflake-notebooks/blob/main/Models/Llama3_2_Vision.ipynb) +- Change role to CONTAINER_RUNTIME_LAB_USER +- Navigate to Projects > Notebooks in Snowsight +- Click Import .ipynb from the + Notebook dropdown +- Create a new notebok with the following settings + - Notebook Location: CONTAINER_RUNTIME_LAB, NOTEBOOKS + - Run On Container + - Snowflake ML Runtime GPU 1.0 + - Select Compute Pool with GPUs: gpu_nv_m_nodes + +### Enable External Integrations +- Click the three dots in the top right > Notebook Settings +- Enable the PYPI_ACCESS_INTEGRATION +- Enable the HF_ACCESS_INTEGRATION + +### Run the Notebook +- Run cells in the notebook! + + +## Conclusion And Resources +Duration: 1 +You have successfully run a Snowflake Notebook on Snowpark Container Services through Container Runtime. You have also used the Llama 3.2 Vision model with Transformers. Feel free to explore other models available on Hugging Face and run them in your Snowflake Notebook. + +### What You Learned +- The key features of Snowflake Notebooks with Container Runtime +- Using models with Hugging Face Transformers +- Capabilities of Meta's Llama 3.2 Vision model + +### Related Resources +- [Documentation](https://docs.snowflake.com/LIMITEDACCESS/snowsight-notebooks/ui-snowsight-notebooks-runtime) +- [Meta 3.2 11B Vision Model](https://huggingface.co/meta-llama/Llama-3.2-11B-Vision-Instruct) +- [Using Container Notebook](https://quickstarts.snowflake.com/guide/notebook-container-runtime/) \ No newline at end of file