实验性功能。仅用于实验目的。尚不兼容
VectorStores
。VertexAI 多模态 API 强制执行以下限制。
对于纯文本嵌入用例,我们建议改用 Vertex AI 文本嵌入模型。
先决条件
- 安装适用于您操作系统的 gcloud CLI。
- 通过运行以下命令进行身份验证。
将
PROJECT_ID
替换为您的 Google Cloud 项目 ID,并将ACCOUNT
替换为您的 Google Cloud 用户名。
添加存储库和 BOM
Spring AI 工件发布在 Maven Central 和 Spring Snapshot 存储库中。 请参阅工件存储库部分,将这些存储库添加到您的构建系统中。 为了帮助进行依赖管理,Spring AI 提供了一个 BOM (物料清单) 以确保在整个项目中使用一致版本的 Spring AI。请参阅依赖管理部分,将 Spring AI BOM 添加到您的构建系统中。自动配置
Spring AI 自动配置和启动器模块的工件名称已发生重大更改。
有关更多信息,请参阅升级说明。
pom.xml
文件中:
build.gradle
构建文件中。
请参阅依赖管理部分,将 Spring AI BOM 添加到您的构建文件中。
Embedding 属性
前缀spring.ai.vertex.ai.embedding
用作属性前缀,可让您连接到 VertexAI Embedding API。
属性 | 描述 | 默认值 |
---|---|---|
spring.ai.vertex.ai.embedding.project-id | Google Cloud Platform 项目 ID | - |
spring.ai.vertex.ai.embedding.location | 区域 | - |
spring.ai.vertex.ai.embedding.apiEndpoint | Vertex AI Embedding API 端点。 | - |
嵌入自动配置的启用和禁用现在通过前缀为
spring.ai.model.embedding
的顶级属性进行配置。要启用,请设置 spring.ai.model.embedding.multimodal=vertexai (默认情况下启用)要禁用,请设置 spring.ai.model.embedding.multimodal=none (或任何与 vertexai 不匹配的值)此更改是为了允许配置多个模型。spring.ai.vertex.ai.embedding.multimodal
是配置 VertexAI 多模态嵌入的嵌入模型实现的属性前缀。
属性 | 描述 | 默认值 |
---|---|---|
spring.ai.vertex.ai.embedding.multimodal.enabled (已删除且不再有效) | 启用 Vertex AI Embedding API 模型。 | true |
spring.ai.model.embedding.multimodal=vertexai | 启用 Vertex AI Embedding API 模型。 | vertexai |
spring.ai.vertex.ai.embedding.multimodal.options.model | 您可以使用以下模型获取多模态嵌入: | multimodalembedding@001 |
spring.ai.vertex.ai.embedding.multimodal.options.dimensions | 指定较低维度的嵌入。默认情况下,嵌入请求为数据类型返回一个 1408 浮点向量。您还可以为文本和图像数据指定较低维度的嵌入(128、256 或 512 浮点向量)。 | 1408 |
spring.ai.vertex.ai.embedding.multimodal.options.video-start-offset-sec | 视频片段的开始偏移量(以秒为单位)。如果未指定,则计算为 max(0, endOffsetSec - 120)。 | - |
spring.ai.vertex.ai.embedding.multimodal.options.video-end-offset-sec | 视频片段的结束偏移量(以秒为单位)。如果未指定,则计算为 min(video length, startOffSec + 120)。如果同时指定了 startOffSec 和 endOffSec,则将 endOffsetSec 调整为 min(startOffsetSec+120, endOffsetSec)。 | - |
spring.ai.vertex.ai.embedding.multimodal.options.video-interval-sec | 将生成嵌入的视频间隔。interval_sec 的最小值为 4。如果间隔小于 4,则返回 InvalidArgumentError。间隔的最大值没有限制。但是,如果间隔大于 min(video length, 120s),则会影响生成的嵌入的质量。默认值:16。 | - |
手动配置
VertexAiMultimodalEmbeddingModel 实现了DocumentEmbeddingModel
。
将 spring-ai-vertex-ai-embedding
依赖项添加到项目的 Maven pom.xml
文件中:
build.gradle
构建文件中。
请参阅依赖管理部分,将 Spring AI BOM 添加到您的构建文件中。
VertexAiMultimodalEmbeddingModel
并将其用于嵌入生成:
文档有误?请协助编辑
发现文档问题?点击此处直接在 GitHub 上编辑并提交 PR,帮助我们改进文档!