Vertex AI¶
Installing Vertex AI¶
To Install Vertex AI you need to follow the following steps
- Install Vertex Cloud SDK (https://googleapis.dev/python/aiplatform/latest/index.html)
- Setup your Default Project, credentials, region
Basic auth example for service account¶
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
)
Basic Usage¶
Basic call to the text-bison model
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 Pro Vision¶
In [ ]:
Copied!
history = [
ChatMessage(
role="user",
content=[
{"type": "text", "text": "Explain what is in the image below:"},
{
"type": "image_url",
"image_url": "",
},
],
),
]
llm = Vertex(
model="gemini-pro-vision",
project=credentials.project_id,
credentials=credentials,
context_window=100000,
)
llm.chat(history).message.content
history = [
ChatMessage(
role="user",
content=[
{"type": "text", "text": "Explain what is in the image below:"},
{
"type": "image_url",
"image_url": "",
},
],
),
]
llm = Vertex(
model="gemini-pro-vision",
project=credentials.project_id,
credentials=credentials,
context_window=100000,
)
llm.chat(history).message.content