@llumiverse/drivers
Version:
LLM driver implementations. Currently supported are: openai, huggingface, bedrock, replicate.
31 lines (27 loc) • 1.63 kB
text/typescript
import { AIModel, Completion, PromptOptions, PromptSegment, ExecutionOptions, CompletionChunk } from "@llumiverse/core";
import { VertexAIDriver , trimModelName} from "./index.js";
import { GeminiModelDefinition } from "./models/gemini.js";
import { ClaudeModelDefinition } from "./models/claude.js";
import { LLamaModelDefinition } from "./models/llama.js";
export interface ModelDefinition<PromptT = any> {
model: AIModel;
versions?: string[]; // the versions of the model that are available. ex: ['001', '002']
createPrompt: (driver: VertexAIDriver, segments: PromptSegment[], options: PromptOptions) => Promise<PromptT>;
requestTextCompletion: (driver: VertexAIDriver, prompt: PromptT, options: ExecutionOptions) => Promise<Completion>;
requestTextCompletionStream: (driver: VertexAIDriver, prompt: PromptT, options: ExecutionOptions) => Promise<AsyncIterable<CompletionChunk>>;
preValidationProcessing?(result: Completion, options: ExecutionOptions): { result: Completion, options: ExecutionOptions };
}
export function getModelDefinition(model: string): ModelDefinition {
const splits = model.split("/");
const publisher = splits[1];
const modelName = trimModelName(splits[splits.length - 1]);
if (publisher?.includes("anthropic")) {
return new ClaudeModelDefinition(modelName);
} else if (publisher?.includes("google")) {
return new GeminiModelDefinition(modelName);
} else if (publisher?.includes("meta")) {
return new LLamaModelDefinition(modelName);
}
//Fallback, assume it is Gemini.
return new GeminiModelDefinition(modelName);
}