LLM 和嵌入程序

此页提供了用于将 LLM 和嵌入程序插入到 Oracle 代理内存中的抽象接口。

LLM 接口

class oracleagentmemory.apis.llms.ILlm

基础:ABC

LLM 调用的抽象接口。

method generate(抽象)

同步从 LLM 生成响应。

method generate_async(抽象、异步)

从 LLM 异步生成响应。

LLM 响应

class oracleagentmemory.apis.llms.LlmResponse

基准:object

ILlm 返回的小型规范化响应。

文本

生成的主要文本内容。

嵌入器界面

class oracleagentmemory.apis.IEmbedder

基础:ABC

文本嵌入程序的抽象界面。

method embed(抽象)

将一批文本嵌入 2D float32 NumPy 数组中。

method embed_async(抽象、异步)

将一批文本嵌入 2D float32 NumPy 数组中。

LiteLLM 适配器

class oracleagentmemory.core.llms.LlmApiType

基础:strEnum

Llm 支持与 OpenAI 兼容的 API 系列。

CHAT_COMPLETIONS *= 'CHAT_COMPLETIONS'*

RESPONSES *= ‘响应’ *

class oracleagentmemory.core.llms.Llm

基础:ILlm

用于生成模型响应的适配器。

创建 LLM 适配器。

示例

OCI Generative AI 模型使用 LiteLLM 的 "oci/..." 模型标识符。一种常见的设置是将 OCI API 密钥验证详细信息从标准 OCI 配置文件传递到特定于 LiteLLM 的关键字参数。此程序包未安装 OCI Python SDK;已经依赖它的应用程序也可以传递 oci_signer 对象。

import configparser
from pathlib import Path
parser = configparser.RawConfigParser()
parser.read(Path("~/.oci/config").expanduser())
cfg = parser["DEFAULT"]
key_file = Path(cfg["key_file"]).expanduser()
oci_llm = Llm(
    model="oci/openai.gpt-oss-120b",
    oci_compartment_id="ocid1.compartment.oc1..example",
    oci_region=cfg.get("region", "us-chicago-1"),
    oci_user=cfg["user"],
    oci_fingerprint=cfg["fingerprint"],
    oci_tenancy=cfg["tenancy"],
    oci_key_file=str(key_file),
)
oci_llm.generate("Reply with OK.")

OpenAI 托管的模型使用 LiteLLM 模型标识符,例如 "openai/gpt-5.1" 和 OpenAI API 密钥。聊天完成是默认 API 系列。

openai_llm = Llm(
    model="openai/gpt-5.1",
    api_key="sk-example",
    temperature=0,
    max_tokens=128,
)
openai_llm.model
'openai/gpt-5.1'
openai_llm.generate("Reply with OK.")

当应通过 OpenAI 响应 API(而不是聊天完成)调用目标模型时,请使用 api_type=LlmApiType.RESPONSES

responses_llm = Llm(
    model="openai/gpt-5.4",
    api_key="sk-example",
    api_type=LlmApiType.RESPONSES,
    reasoning_effort="high",
    stream=True,
)
responses_llm.model
'openai/gpt-5.4'

与 OpenAI 兼容的自托管服务器(包括 vLLM)通过 "openai/..." 模型标识符和服务器的 /v1 基本 URL 来调用。当端点不强制验证时,传递名义 api_key,例如 "none"

vllm_llm = Llm(
    model="openai/openai/gpt-oss-120b",
    api_base="http://localhost:8000/v1",
    api_key="none",
    stream=True,
)
vllm_llm.model
'openai/openai/gpt-oss-120b'
vllm_llm.generate("Reply with OK.")

method generate

生成回应。

method generate_async(异步)

异步生成响应。

class oracleagentmemory.core.embedders.Embedder

基础:IEmbedder

提供商支持的嵌入程序。

创建提供程序支持的嵌入程序。

示例

OCI Generative AI 嵌入模型使用 "oci/..." 模型标识符。常见的设置是将 OCI API 密钥验证详细信息从标准 OCI 配置文件传递到特定于 LiteLLM 的关键字参数。此程序包未安装 OCI Python SDK;已经依赖它的应用程序也可以传递 oci_signer 对象。

import configparser
from pathlib import Path
parser = configparser.RawConfigParser()
parser.read(Path("~/.oci/config").expanduser())
cfg = parser["DEFAULT"]
key_file = Path(cfg["key_file"]).expanduser()
oci_embedder = Embedder(
    model="oci/cohere.embed-english-v3.0",
    oci_compartment_id="ocid1.compartment.oc1..example",
    oci_region=cfg.get("region", "us-chicago-1"),
    oci_user=cfg["user"],
    oci_fingerprint=cfg["fingerprint"],
    oci_tenancy=cfg["tenancy"],
    oci_key_file=str(key_file),
)
oci_embedder.embed(["hello world"])

OpenAI 托管的嵌入模型使用标识符,例如带有 OpenAI API 密钥的 "openai/text-embedding-3-small"

openai_embedder = Embedder(
    model="openai/text-embedding-3-small",
    api_key="sk-example",
    truncate_prompt_tokens=8192,
)
openai_embedder.model
'openai/text-embedding-3-small'
openai_embedder.embed(["hello world"])

与 OpenAI 兼容的自托管嵌入式服务器(包括 vLLM)使用服务器 /v1 基本 URL 的 "hosted_vllm/..." 提供程序前缀。

vllm_embedder = Embedder(
    model="hosted_vllm/sentence-transformers/all-MiniLM-L6-v2",
    api_base="http://localhost:8000/v1",
)
vllm_embedder.model
'hosted_vllm/sentence-transformers/all-MiniLM-L6-v2'
vllm_embedder.embed(["hello world"])

method embed

使用配置的提供程序嵌入一批文本。

method embed_async(异步)

使用配置的提供程序异步嵌入一批文本。