跳到主要内容

Snowflake Cortex

Snowflake Cortex 使您能够即时访问由 Mistral、Reka、Meta 和 Google 等公司的研究人员训练的行业领先的大型语言模型 (LLM),包括由 Snowflake 开发的开源企业级模型 Snowflake Arctic

此示例介绍如何使用 LangChain 与 Snowflake Cortex 进行交互。

安装和设置

我们首先使用以下命令安装 snowflake-snowpark-python 库。然后,我们将配置用于连接到 Snowflake 的凭据,可以使用环境变量或直接传递它们。

%pip install --upgrade --quiet snowflake-snowpark-python
import getpass
import os

# First step is to set up the environment variables, to connect to Snowflake,
# you can also pass these snowflake credentials while instantiating the model

if os.environ.get("SNOWFLAKE_ACCOUNT") is None:
os.environ["SNOWFLAKE_ACCOUNT"] = getpass.getpass("Account: ")

if os.environ.get("SNOWFLAKE_USERNAME") is None:
os.environ["SNOWFLAKE_USERNAME"] = getpass.getpass("Username: ")

if os.environ.get("SNOWFLAKE_PASSWORD") is None:
os.environ["SNOWFLAKE_PASSWORD"] = getpass.getpass("Password: ")

if os.environ.get("SNOWFLAKE_DATABASE") is None:
os.environ["SNOWFLAKE_DATABASE"] = getpass.getpass("Database: ")

if os.environ.get("SNOWFLAKE_SCHEMA") is None:
os.environ["SNOWFLAKE_SCHEMA"] = getpass.getpass("Schema: ")

if os.environ.get("SNOWFLAKE_WAREHOUSE") is None:
os.environ["SNOWFLAKE_WAREHOUSE"] = getpass.getpass("Warehouse: ")

if os.environ.get("SNOWFLAKE_ROLE") is None:
os.environ["SNOWFLAKE_ROLE"] = getpass.getpass("Role: ")
from langchain_community.chat_models import ChatSnowflakeCortex
from langchain_core.messages import HumanMessage, SystemMessage

# By default, we'll be using the cortex provided model: `mistral-large`, with function: `complete`
chat = ChatSnowflakeCortex()

上述单元格假设您的 Snowflake 凭据已在您的环境变量中设置。如果您更希望手动指定它们,请使用以下代码

chat = ChatSnowflakeCortex(
# Change the default cortex model and function
model="mistral-large",
cortex_function="complete",

# Change the default generation parameters
temperature=0,
max_tokens=10,
top_p=0.95,

# Specify your Snowflake Credentials
account="YOUR_SNOWFLAKE_ACCOUNT",
username="YOUR_SNOWFLAKE_USERNAME",
password="YOUR_SNOWFLAKE_PASSWORD",
database="YOUR_SNOWFLAKE_DATABASE",
schema="YOUR_SNOWFLAKE_SCHEMA",
role="YOUR_SNOWFLAKE_ROLE",
warehouse="YOUR_SNOWFLAKE_WAREHOUSE"
)

调用聊天模型

现在我们可以使用 invokestream 方法调用聊天模型。

messages = [ SystemMessage(content="你是一个友好的助手。"), HumanMessage(content="什么是大型语言模型?"), ] chat.invoke(messages)

流式传输

# Sample input prompt
messages = [
SystemMessage(content="You are a friendly assistant."),
HumanMessage(content="What are large language models?"),
]

# Invoke the stream method and print each chunk as it arrives
print("Stream Method Response:")
for chunk in chat._stream(messages):
print(chunk.message.content)

此页是否有帮助?