Skip to main content
Glama

@arizeai/phoenix-mcp

Official
by Arize-ai
createDocumentRelevancyEvaluator.ts2.74 kB
import { CreateClassificationEvaluatorArgs, Evaluator } from "../types/evals"; import { DOCUMENT_RELEVANCY_TEMPLATE, DOCUMENT_RELEVANCY_CHOICES, } from "../default_templates/DOCUMENT_RELEVANCY_TEMPLATE"; import { createClassificationEvaluator } from "./createClassificationEvaluator"; export interface DocumentRelevancyEvaluatorArgs extends Omit< CreateClassificationEvaluatorArgs, "promptTemplate" | "choices" | "optimizationDirection" | "name" > { optimizationDirection?: CreateClassificationEvaluatorArgs["optimizationDirection"]; name?: CreateClassificationEvaluatorArgs["name"]; choices?: CreateClassificationEvaluatorArgs["choices"]; promptTemplate?: CreateClassificationEvaluatorArgs["promptTemplate"]; } /** * A record to be evaluated by the document relevancy evaluator. */ export interface DocumentRelevancyEvaluationRecord { input: string; documentText: string; [key: string]: unknown; } /** * Creates a document relevancy evaluator function. * * This function returns an evaluator that determines whether a given document text * is relevant to a provided input question. The evaluator uses a classification model * and a prompt template to make its determination. * * @param args - The arguments for creating the document relevancy evaluator. * @param args.model - The model to use for classification. * @param args.choices - The possible classification choices (defaults to DOCUMENT_RELEVANCY_CHOICES). * @param args.promptTemplate - The prompt template to use (defaults to DOCUMENT_RELEVANCY_TEMPLATE). * @param args.telemetry - The telemetry to use for the evaluator. * * @returns An evaluator function that takes a {@link DocumentRelevancyExample} and returns a classification result * indicating whether the document is relevant to the input question. * * @example * ```ts * const evaluator = createDocumentRelevancyEvaluator({ model: openai("gpt-4o-mini") }); * const result = await evaluator.evaluate({ * input: "What is the capital of France?", * documentText: "Paris is the capital and most populous city of France.", * }); * console.log(result.label); // "relevant" or "unrelated" * ``` */ export function createDocumentRelevancyEvaluator< RecordType extends Record< string, unknown > = DocumentRelevancyEvaluationRecord, >(args: DocumentRelevancyEvaluatorArgs): Evaluator<RecordType> { const { choices = DOCUMENT_RELEVANCY_CHOICES, promptTemplate = DOCUMENT_RELEVANCY_TEMPLATE, optimizationDirection = "MAXIMIZE", name = "document_relevancy", ...rest } = args; return createClassificationEvaluator<RecordType>({ ...args, promptTemplate, choices, optimizationDirection, name, ...rest, }); }

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/Arize-ai/phoenix'

If you have feedback or need assistance with the MCP directory API, please join our Discord server