{"cells": [{"cell_type": "markdown", "id": "9dced1fd-2db9-4b4e-88f5-bd65563ec1a6", "metadata": {}, "source": ["# Vertex AI\n", "## 安装 Vertex AI\n", "要安装 Vertex AI,您需要按照以下步骤进行操作:\n", "* 安装 Vertex Cloud SDK(https://googleapis.dev/python/aiplatform/latest/index.html)\n", "* 设置默认项目、凭据和区域\n", "# 服务账号的基本身份验证示例\n"]}, {"cell_type": "code", "execution_count": null, "id": "e25b1ac2", "metadata": {}, "outputs": [], "source": ["%pip install llama-index-llms-vertex"]}, {"cell_type": "code", "execution_count": null, "id": "3d42f4996210bdc7", "metadata": {}, "outputs": [], "source": ["from llama_index.llms.vertex import Vertex\n", "from google.oauth2 import service_account\n", "\n", "filename = \"vertex-407108-37495ce6c303.json\"\n", "credentials: service_account.Credentials = (\n", " service_account.Credentials.from_service_account_file(filename)\n", ")\n", "Vertex(\n", " model=\"text-bison\", project=credentials.project_id, credentials=credentials\n", ")"]}, {"cell_type": "markdown", "id": "119bbfb7d84a593d", "metadata": {}, "source": ["## 基本用法\n", "对text-bison模型的基本调用\n"]}, {"cell_type": "code", "execution_count": null, "id": "bf7deb10-28fe-41f2-abda-283162e9f35b", "metadata": {}, "outputs": [{"data": {"text/plain": ["' ```\\nHello this is a sample text\\n```'"]}, "execution_count": null, "metadata": {}, "output_type": "execute_result"}], "source": ["from llama_index.llms.vertex import Vertex\n", "from llama_index.core.llms import ChatMessage, MessageRole\n", "\n", "llm = Vertex(model=\"text-bison\", temperature=0, additional_kwargs={})\n", "llm.complete(\"Hello this is a sample text\").text"]}, {"cell_type": "markdown", "id": "c3afe813-a5cb-4175-bf9c-5484b2da0a9b", "metadata": {}, "source": ["## 异步用法\n", "### 异步\n"]}, {"cell_type": "code", "execution_count": null, "id": "7916602b-4f97-43bb-85a9-ac683bc962f3", "metadata": {}, "outputs": [{"data": {"text/plain": ["' Hello! How can I help you?'"]}, "execution_count": null, "metadata": {}, "output_type": "execute_result"}], "source": ["(await llm.acomplete(\"hello\")).text"]}, {"cell_type": "markdown", "id": "2cfd0b78-b779-4390-96f7-99ff60087786", "metadata": {}, "source": ["# 流式使用\n", "### 流式\n"]}, {"cell_type": "code", "execution_count": null, "id": "ef4765c5-ec6a-4109-8453-c9f76396d572", "metadata": {}, "outputs": [{"data": {"text/plain": ["' Hello! How can I help you?'"]}, "execution_count": null, "metadata": {}, "output_type": "execute_result"}], "source": ["list(llm.stream_complete(\"hello\"))[-1].text"]}, {"cell_type": "markdown", "id": "ce5d9453-6465-489e-b205-a25a3da37dde", "metadata": {}, "source": ["# 聊天使用\n", "### 聊天生成\n"]}, {"cell_type": "code", "execution_count": null, "id": "2b8861d4-a151-4a5d-8a6f-d24e284009c3", "metadata": {}, "outputs": [], "source": ["chat = Vertex(model=\"chat-bison\")\n", "messages = [\n", " ChatMessage(role=MessageRole.SYSTEM, content=\"Reply everything in french\"),\n", " ChatMessage(role=MessageRole.USER, content=\"Hello\"),\n", "]"]}, {"cell_type": "code", "execution_count": null, "id": "f2286016-9d58-468d-a9a2-571ad90066ad", "metadata": {}, "outputs": [{"data": {"text/plain": ["' Bonjour! Comment vas-tu?'"]}, "execution_count": null, "metadata": {}, "output_type": "execute_result"}], "source": ["chat.chat(messages=messages).message.content"]}, {"cell_type": "markdown", "id": "b830d59e-12f6-4ef7-b1ce-e71408ae3cbb", "metadata": {}, "source": ["# 异步聊天\n", "### 异步聊天响应\n"]}, {"cell_type": "code", "execution_count": null, "id": "2920968a-9566-4964-b468-9a5899f42e61", "metadata": {}, "outputs": [{"data": {"text/plain": ["' Bonjour! Comment vas-tu?'"]}, "execution_count": null, "metadata": {}, "output_type": "execute_result"}], "source": ["(await chat.achat(messages=messages)).message.content"]}, {"cell_type": "markdown", "id": "632585b4-f146-492c-bb16-30e8b64e2d52", "metadata": {}, "source": ["# 流式聊天\n", "### 流式聊天响应\n"]}, {"cell_type": "code", "execution_count": null, "id": "9ee22376-317a-4bda-a20e-5d54f88503f7", "metadata": {}, "outputs": [{"data": {"text/plain": ["' Bonjour! Comment vas-tu?'"]}, "execution_count": null, "metadata": {}, "output_type": "execute_result"}], "source": ["list(chat.stream_chat(messages=messages))[-1].message.content"]}, {"cell_type": "markdown", "id": "e24abcf3278f5ee6", "metadata": {}, "source": ["# Gemini模型\n", "完全支持使用Vertex AI调用Google Gemini模型。\n", "### Gemini Pro\n"]}, {"cell_type": "code", "execution_count": null, "id": "2b900308342b19be", "metadata": {}, "outputs": [], "source": ["llm = Vertex(\n", " model=\"gemini-pro\", project=credentials.project_id, credentials=credentials\n", ")\n", "llm.complete(\"Hello Gemini\").text"]}, {"cell_type": "markdown", "id": "b840065e0312fd46", "metadata": {}, "source": ["### Gemini Pro Vision\n"]}, {"cell_type": "code", "execution_count": null, "id": "1a9f12769bdeca6f", "metadata": {}, "outputs": [], "source": ["history = [\n", " ChatMessage(\n", " role=\"user\",\n", " content=[\n", " {\"type\": \"text\", \"text\": \"Explain what is in the image below:\"},\n", " {\n", " \"type\": \"image_url\",\n", " \"image_url\": \"\",\n", " },\n", " ],\n", " ),\n", "]\n", "llm = Vertex(\n", " model=\"gemini-pro-vision\",\n", " project=credentials.project_id,\n", " credentials=credentials,\n", ")\n", "llm.chat(history).message.content"]}], "metadata": {"kernelspec": {"display_name": "Python 3 (ipykernel)", "language": "python", "name": "python3"}, "language_info": {"codemirror_mode": {"name": "ipython", "version": 3}, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3"}}, "nbformat": 4, "nbformat_minor": 5}