Este documento descreve como criar um embedding de texto usando a API Text embeddings da Vertex AI.
A API Text embeddings da Vertex AI usa representações vetoriais densas: gemini-embedding-001, por exemplo, usa vetores de 3.072 dimensões. Os modelos de embedding de vetores densos usam métodos de aprendizado profundo semelhantes aos usados por modelos de linguagem grandes. Ao contrário dos vetores esparsos, que tendem a mapear diretamente as palavras para números, os vetores densos são projetados para representar melhor o significado de um texto. O benefício de usar embeddings de vetores densos na IA generativa é que, em vez de pesquisar correspondências de palavra direta ou sintaxe, é possível pesquisar melhor trechos que se alinhem ao significado da consulta, mesmo que os trechos não usam o mesmo idioma.
Os vetores são normalizados, então você pode usar a similaridade do cosseno, o produto escalar ou a distância euclidiana para fornecer as mesmas classificações de similaridade.
- Para saber mais sobre embeddings, consulte Visão geral das APIs de embeddings.
- Para saber mais sobre os modelos de embedding de texto, consulte Embeddings de texto.
- Para saber quais idiomas são aceitos em cada modelo de embeddings, consulte Idiomas de texto compatíveis.
Antes de começar
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator
(
roles/resourcemanager.projectCreator
), which contains theresourcemanager.projects.create
permission. Learn how to grant roles.
-
Enable the Vertex AI API.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin
), which contains theserviceusage.services.enable
permission. Learn how to grant roles. -
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator
(
roles/resourcemanager.projectCreator
), which contains theresourcemanager.projects.create
permission. Learn how to grant roles.
-
Enable the Vertex AI API.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin
), which contains theserviceusage.services.enable
permission. Learn how to grant roles. - Escolha um tipo de tarefa para o job de embeddings.
- Para saber mais sobre os limites de taxa, consulte Limites de taxa da IA generativa na Vertex AI.
- Para receber previsões em lote para embeddings, consulte Receber previsões de embeddings de texto em lote.
- Para saber mais sobre embeddings multimodais, consulte Ver embeddings multimodais.
- Para ajustar um embedding, consulte Ajustar embeddings de texto.
- Para saber mais sobre a pesquisa relacionada a
text-embedding-005
etext-multilingual-embedding-002
, consulte o artigo de pesquisa Gecko: embeddings de texto versáteis extraídos de modelos de linguagem grandes.
Modelos compatíveis
Você pode obter embeddings de texto usando os seguintes modelos:
Nome do modelo | Descrição | Dimensões de saída | Comprimento máximo da sequência | Idiomas de texto compatíveis |
---|---|---|---|---|
gemini-embedding-001 |
Desempenho de ponta em tarefas de inglês, multilíngues e de código. Ele unifica os modelos especializados anteriores, como text-embedding-005 e text-multilingual-embedding-002 , e alcança um desempenho melhor nos respectivos domínios. Leia nosso relatório técnico para mais detalhes. |
até 3072 | 2.048 tokens | Idiomas de texto compatíveis |
text-embedding-005 |
Especializado em tarefas de inglês e programação. | até 768 | 2.048 tokens | Inglês |
text-multilingual-embedding-002 |
Especializado em tarefas multilíngues. | até 768 | 2.048 tokens | Idiomas de texto compatíveis |
Para uma qualidade de incorporação superior, o gemini-embedding-001
é nosso modelo grande projetado para oferecer a melhor performance.
Obter embeddings de texto para um snippet de texto
É possível receber embeddings de texto para um snippet de texto usando a API Vertex AI ou o SDK da Vertex AI para Python.
Limites da API
Há um limite de 250 textos de entrada em cada solicitação.
A API tem um limite máximo de 20 mil tokens de entrada.
Entradas que excedem esse limite resultam em um erro 400. Cada texto de entrada individual
é limitado a 2.048 tokens. Qualquer excesso é truncado silenciosamente. Também é possível desativar o truncamento silencioso definindo autoTruncate
como false
.
Para mais informações, consulte Limites de embeddings de texto.
Escolher uma dimensão de embedding
Todos os modelos produzem um vetor de embedding de comprimento total por padrão. Para gemini-embedding-001
, esse vetor tem 3.072 dimensões, e outros modelos produzem vetores de 768 dimensões. No entanto, usando o parâmetro output_dimensionality
, os usuários podem controlar o tamanho do vetor de incorporação de saída.
Selecionar uma dimensionalidade de saída menor pode economizar espaço de armazenamento e aumentar a eficiência computacional para aplicativos downstream, sacrificando pouco em termos de qualidade.
Os exemplos a seguir usam o modelo gemini-embedding-001
.
Python
Instalar
pip install --upgrade google-genai
Para saber mais, consulte a documentação de referência do SDK.
Defina variáveis de ambiente para usar o SDK de IA generativa com a Vertex AI:
# Replace the `GOOGLE_CLOUD_PROJECT` and `GOOGLE_CLOUD_LOCATION` values # with appropriate values for your project. export GOOGLE_CLOUD_PROJECT=GOOGLE_CLOUD_PROJECT export GOOGLE_CLOUD_LOCATION=global export GOOGLE_GENAI_USE_VERTEXAI=True
Go
Saiba como instalar ou atualizar o Go.
Para saber mais, consulte a documentação de referência do SDK.
Defina variáveis de ambiente para usar o SDK de IA generativa com a Vertex AI:
# Replace the `GOOGLE_CLOUD_PROJECT` and `GOOGLE_CLOUD_LOCATION` values # with appropriate values for your project. export GOOGLE_CLOUD_PROJECT=GOOGLE_CLOUD_PROJECT export GOOGLE_CLOUD_LOCATION=global export GOOGLE_GENAI_USE_VERTEXAI=True
Adicionar um embedding a um banco de dados de vetores
Depois de gerar o embedding, é possível adicioná-lo a um banco de dados vetorial, como o Vector Search. Isso permite a recuperação de baixa latência e é essencial à medida que o tamanho dos dados aumenta.
Para saber mais sobre a pesquisa de vetor, consulte Visão geral da pesquisa de vetor.