agsamantha/node_modules/langchain/dist/evaluation/base.js

264 lines
8.6 KiB
JavaScript
Raw Normal View History

2024-10-02 20:15:21 +00:00
import { BaseChain, LLMChain } from "../chains/index.js";
/**
* Compare two sets for equality
*
* @param xs
* @param ys
*/
export const eqSet = (xs, ys) => xs.size === ys.size && [...xs].every((x) => ys.has(x));
/**
* Base llm chain class for evaluators.
*/
export class LLMEvalChain extends LLMChain {
constructor() {
super(...arguments);
Object.defineProperty(this, "requiresInput", {
enumerable: true,
configurable: true,
writable: true,
value: false
});
Object.defineProperty(this, "requiresReference", {
enumerable: true,
configurable: true,
writable: true,
value: false
});
Object.defineProperty(this, "skipInputWarning", {
enumerable: true,
configurable: true,
writable: true,
value: `Ignoring input in ${this.constructor.name}, as it is not expected.`
});
Object.defineProperty(this, "skipReferenceWarning", {
enumerable: true,
configurable: true,
writable: true,
value: `Ignoring reference in ${this.constructor.name}, as it is not expected.`
});
}
/**
* Check if the evaluation arguments are valid.
* @param reference The reference label.
* @param input The input string.
* @throws {Error} If the evaluator requires an input string but none is provided, or if the evaluator requires a reference label but none is provided.
*/
checkEvaluationArgs(reference, input) {
if (this.requiresInput && input == null) {
throw new Error(`${this.constructor.name} requires an input string.`);
}
else if (input != null && !this.requiresInput) {
console.warn(this.skipInputWarning);
}
if (this.requiresReference && reference == null) {
throw new Error(`${this.constructor.name} requires a reference string.`);
}
else if (reference != null && !this.requiresReference) {
console.warn(this.skipReferenceWarning);
}
}
}
/**
* Base chain class for evaluators.
*/
export class EvalChain extends BaseChain {
constructor() {
super(...arguments);
Object.defineProperty(this, "requiresInput", {
enumerable: true,
configurable: true,
writable: true,
value: false
});
Object.defineProperty(this, "requiresReference", {
enumerable: true,
configurable: true,
writable: true,
value: false
});
Object.defineProperty(this, "skipInputWarning", {
enumerable: true,
configurable: true,
writable: true,
value: `Ignoring input in ${this.constructor.name}, as it is not expected.`
});
Object.defineProperty(this, "skipReferenceWarning", {
enumerable: true,
configurable: true,
writable: true,
value: `Ignoring reference in ${this.constructor.name}, as it is not expected.`
});
}
/**
* Check if the evaluation arguments are valid.
* @param reference The reference label.
* @param input The input string.
* @throws {Error} If the evaluator requires an input string but none is provided, or if the evaluator requires a reference label but none is provided.
*/
checkEvaluationArgs(reference, input) {
if (this.requiresInput && input == null) {
throw new Error(`${this.constructor.name} requires an input string.`);
}
else if (input != null && !this.requiresInput) {
console.warn(this.skipInputWarning);
}
if (this.requiresReference && reference == null) {
throw new Error(`${this.constructor.name} requires a reference string.`);
}
else if (reference != null && !this.requiresReference) {
console.warn(this.skipReferenceWarning);
}
}
}
/**
* Grade, tag, or otherwise evaluate predictions relative to their inputs
* and/or reference labels
*/
export class LLMStringEvaluator extends LLMEvalChain {
constructor() {
super(...arguments);
/**
* The name of the evaluation.
*/
Object.defineProperty(this, "evaluationName", {
enumerable: true,
configurable: true,
writable: true,
value: this.constructor.name
});
}
/**
* Evaluate Chain or LLM output, based on optional input and label.
* @returns The evaluation results containing the score or value. It is recommended that the dictionary contain the following keys:
* - score: the score of the evaluation, if applicable.
* - value: the string value of the evaluation, if applicable.
* - reasoning: the reasoning for the evaluation, if applicable.
* @param args
* @param callOptions
* @param config
*/
evaluateStrings(args, config) {
this.checkEvaluationArgs(args.reference, args.input);
return this._evaluateStrings(args, config);
}
}
/**
* Grade, tag, or otherwise evaluate predictions relative to their inputs
* and/or reference labels
*/
export class StringEvaluator extends EvalChain {
constructor() {
super(...arguments);
/**
* The name of the evaluation.
*/
Object.defineProperty(this, "evaluationName", {
enumerable: true,
configurable: true,
writable: true,
value: this.constructor.name
});
}
/**
* Evaluate Chain or LLM output, based on optional input and label.
* @returns The evaluation results containing the score or value. It is recommended that the dictionary contain the following keys:
* - score: the score of the evaluation, if applicable.
* - value: the string value of the evaluation, if applicable.
* - reasoning: the reasoning for the evaluation, if applicable.
* @param args
* @param config
*/
evaluateStrings(args, config) {
this.checkEvaluationArgs(args.reference, args.input);
return this._evaluateStrings(args, config);
}
}
/**
* Compare the output of two models (or two outputs of the same model).
*/
export class PairwiseStringEvaluator extends EvalChain {
constructor() {
super(...arguments);
/**
* The name of the evaluation.
*/
Object.defineProperty(this, "evaluationName", {
enumerable: true,
configurable: true,
writable: true,
value: this.constructor.name
});
}
/**
* Evaluate the output string pairs.
* @param args
* @param config
* @return A dictionary containing the preference, scores, and/or other information.
*/
evaluateStringPairs(args, config) {
return this._evaluateStringPairs(args, config);
}
}
/**
* Compare the output of two models (or two outputs of the same model).
*/
export class LLMPairwiseStringEvaluator extends LLMEvalChain {
constructor() {
super(...arguments);
/**
* The name of the evaluation.
*/
Object.defineProperty(this, "evaluationName", {
enumerable: true,
configurable: true,
writable: true,
value: this.constructor.name
});
}
/**
* Evaluate the output string pairs.
* @param args
* @param callOptions
* @param config
* @return A dictionary containing the preference, scores, and/or other information.
*/
evaluateStringPairs(args, callOptions, config) {
this.checkEvaluationArgs(args.reference, args.input);
return this._evaluateStringPairs(args, callOptions, config);
}
}
/**
* Interface for evaluating agent trajectories.
*/
export class AgentTrajectoryEvaluator extends LLMEvalChain {
constructor() {
super(...arguments);
Object.defineProperty(this, "requiresInput", {
enumerable: true,
configurable: true,
writable: true,
value: true
});
/**
* The name of the evaluation.
*/
Object.defineProperty(this, "evaluationName", {
enumerable: true,
configurable: true,
writable: true,
value: this.constructor.name
});
}
/**
* Evaluate a trajectory.
* @return The evaluation result.
* @param args
* @param callOptions
* @param config
*/
evaluateAgentTrajectory(args, callOptions, config) {
this.checkEvaluationArgs(args.reference, args.input);
return this._evaluateAgentTrajectory(args, callOptions, config);
}
}