Vertex AI¶
注意: Vertex 已被 Google GenAI 大部分取代,后者使用 google-genai
包支持与 Vertex 相同的功能。请访问 Google GenAI 页面查看最新的示例和文档。
安装 Vertex AI¶
要安装 Vertex AI,您需要按照以下步骤操作:
- 安装 Vertex Cloud SDK (https://googleapis.dev/python/aiplatform/latest/index.html)
- 设置您的默认项目、凭据、区域
服务帐户的基本认证示例¶
In [ ]
Copied!
%pip install llama-index-llms-vertex
%pip install llama-index-llms-vertex
In [ ]
Copied!
from llama_index.llms.vertex import Vertex
from google.oauth2 import service_account
filename = "vertex-407108-37495ce6c303.json"
credentials: service_account.Credentials = (
service_account.Credentials.from_service_account_file(filename)
)
Vertex(
model="text-bison", project=credentials.project_id, credentials=credentials
)
from llama_index.llms.vertex import Vertex from google.oauth2 import service_account filename = "vertex-407108-37495ce6c303.json" credentials: service_account.Credentials = ( service_account.Credentials.from_service_account_file(filename) ) Vertex( model="text-bison", project=credentials.project_id, credentials=credentials )
基本用法¶
对 text-bison 模型的简单调用
In [ ]
Copied!
from llama_index.llms.vertex import Vertex
from llama_index.core.llms import ChatMessage, MessageRole
llm = Vertex(model="text-bison", temperature=0, additional_kwargs={})
llm.complete("Hello this is a sample text").text
from llama_index.llms.vertex import Vertex from llama_index.core.llms import ChatMessage, MessageRole llm = Vertex(model="text-bison", temperature=0, additional_kwargs={}) llm.complete("Hello this is a sample text").text
Out[ ]
' ```\nHello this is a sample text\n```'
In [ ]
Copied!
(await llm.acomplete("hello")).text
(await llm.acomplete("hello")).text
Out[ ]
' Hello! How can I help you?'
In [ ]
Copied!
list(llm.stream_complete("hello"))[-1].text
list(llm.stream_complete("hello"))[-1].text
Out[ ]
' Hello! How can I help you?'
In [ ]
Copied!
chat = Vertex(model="chat-bison")
messages = [
ChatMessage(role=MessageRole.SYSTEM, content="Reply everything in french"),
ChatMessage(role=MessageRole.USER, content="Hello"),
]
chat = Vertex(model="chat-bison") messages = [ ChatMessage(role=MessageRole.SYSTEM, content="Reply everything in french"), ChatMessage(role=MessageRole.USER, content="Hello"), ]
In [ ]
Copied!
chat.chat(messages=messages).message.content
chat.chat(messages=messages).message.content
Out[ ]
' Bonjour! Comment vas-tu?'
In [ ]
Copied!
(await chat.achat(messages=messages)).message.content
(await chat.achat(messages=messages)).message.content
Out[ ]
' Bonjour! Comment vas-tu?'
In [ ]
Copied!
list(chat.stream_chat(messages=messages))[-1].message.content
list(chat.stream_chat(messages=messages))[-1].message.content
Out[ ]
' Bonjour! Comment vas-tu?'
In [ ]
Copied!
llm = Vertex(
model="gemini-pro",
project=credentials.project_id,
credentials=credentials,
context_window=100000,
)
llm.complete("Hello Gemini").text
llm = Vertex( model="gemini-pro", project=credentials.project_id, credentials=credentials, context_window=100000, ) llm.complete("Hello Gemini").text
Gemini 视觉模型¶
支持 Gemini 视觉功能的模型现在支持 TextBlock
和 ImageBlock
用于结构化多模态输入,取代了旧的基于字典的 content
格式。使用 blocks
通过文件路径或 URL 包含文本和图像。
使用图像路径的示例
In [ ]
Copied!
from llama_index.llms.vertex import Vertex
from llama_index.core.llms import ChatMessage, TextBlock, ImageBlock
history = [
ChatMessage(
role="user",
blocks=[
ImageBlock(path="sample.jpg"),
TextBlock(text="What is in this image?"),
],
),
]
llm = Vertex(
model="gemini-1.5-flash",
project=credentials.project_id,
credentials=credentials,
context_window=100000,
)
print(llm.chat(history).message.content)
from llama_index.llms.vertex import Vertex from llama_index.core.llms import ChatMessage, TextBlock, ImageBlock history = [ ChatMessage( role="user", blocks=[ ImageBlock(path="sample.jpg"), TextBlock(text="What is in this image?"), ], ), ] llm = Vertex( model="gemini-1.5-flash", project=credentials.project_id, credentials=credentials, context_window=100000, ) print(llm.chat(history).message.content)
The image shows a man in handcuffs being escorted by police officers. The man is wearing a black jacket and a black hooded sweatshirt. He is being escorted by two police officers who are wearing black balaclavas and bulletproof vests. The officers are from the Romanian Gendarmerie. The image is likely from a news report or a documentary about a crime.
使用图像 URL 的示例
In [ ]
Copied!
from llama_index.llms.vertex import Vertex
from llama_index.core.llms import ChatMessage, TextBlock, ImageBlock
history = [
ChatMessage(
role="user",
blocks=[
ImageBlock(
url="https://upload.wikimedia.org/wikipedia/commons/7/71/Sibirischer_tiger_de_edit02.jpg"
),
TextBlock(text="What is in this image?"),
],
),
]
llm = Vertex(
model="gemini-1.5-flash",
project=credentials.project_id,
credentials=credentials,
context_window=100000,
)
print(llm.chat(history).message.content)
from llama_index.llms.vertex import Vertex from llama_index.core.llms import ChatMessage, TextBlock, ImageBlock history = [ ChatMessage( role="user", blocks=[ ImageBlock( url="https://upload.wikimedia.org/wikipedia/commons/7/71/Sibirischer_tiger_de_edit02.jpg" ), TextBlock(text="What is in this image?"), ], ), ] llm = Vertex( model="gemini-1.5-flash", project=credentials.project_id, credentials=credentials, context_window=100000, ) print(llm.chat(history).message.content)
A close-up of a tiger's face. The tiger is looking directly at the camera with a serious expression. The fur is a mix of orange, black, and white. The background is blurred, making the tiger the main focus of the image.