Skip to content

quotient-ai/judges

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

41 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

judges ‍⚖️

  1. Overview
  2. Installation
  3. API
  4. Usage
  5. Appendix of Judges

Overview

judges is a small library to use and create LLM-as-a-Judge evaluators. The purpose of judges is to have a curated set of LLM evaluators in a low-friction format across a variety of use cases that are backed by research, and can be used off-the-shelf or serve as inspiration for building your own LLM evaluators.

Installation

pip install judges

API

Types of Judges

The library provides two types of judges:

  1. Classifiers: Return boolean values.

    • True indicates the inputs passed the evaluation.
    • False indicates the inputs did not pass the evaluation.
  2. Graders: Return scores on a numerical or Likert scale.

    • Numerical scale: 1 to 5
    • Likert scale: terrible, bad, average, good, excellent

Using Judges

All judges can be used by calling the .judge() method. This method accepts the following parameters:

  • input: The input to be evaluated.
  • output: The output to be evaluated.
  • expected (optional): The expected result for comparison.

The .judge() method returns a Judgment object with the following attributes:

  • reasoning: The reasoning behind the judgment.
  • score: The score assigned by the judge.

Classifier Judges

If the underlying prompt for a classifier judge outputs a Judgment similar to True or False (e.g., good or bad, yes or no, 0 or 1), the judges library automatically resolves the outputs so that a Judgment only has a boolean label.

Combining Judges

The library also provides an interface to combine multiple judges through the Jury object. The Jury object has a .vote() method that produces a Verdict.

Jury Object

  • .vote(): Combines the judgments of multiple judges and produces a Verdict.

Usage

Pick a model

  • OpenAI:
    • By default, judges uses the OpenAI client and models due to its widespread use. To get started, you'll need an OpenAI API key set as an environment variable OPENAI_API_KEY
  • LiteLLM:
    • If you would like to use models on other inference providers, judges also integrates with litellm as an extra dependency. Run pip install "judges[litellm]", and set the appropriate API keys based on the LiteLLM Docs.

Tip

If you choose to use litellm to use 3rd-party inference providers, and the model you want is not available via the function below, check the docs of the inference provider directly since litellm docs may not always be up to date.

Send data to an LLM

Next, if you'd like to use this package, you can follow the example.py below:

from openai import OpenAI

client = OpenAI()

question = "What is the name of the rabbit in the following story. Respond with 'I don't know' if you don't know."

story = """
Fig was a small, scruffy dog with a big personality. He lived in a quiet little town where everyone knew his name. Fig loved adventures, and every day he would roam the neighborhood, wagging his tail and sniffing out new things to explore.

One day, Fig discovered a mysterious trail of footprints leading into the woods. Curiosity got the best of him, and he followed them deep into the trees. As he trotted along, he heard rustling in the bushes and suddenly, out popped a rabbit! The rabbit looked at Fig with wide eyes and darted off.

But instead of chasing it, Fig barked in excitement, as if saying, “Nice to meet you!” The rabbit stopped, surprised, and came back. They sat together for a moment, sharing the calm of the woods.

From that day on, Fig had a new friend. Every afternoon, the two of them would meet in the same spot, enjoying the quiet companionship of an unlikely friendship. Fig's adventurous heart had found a little peace in the simple joy of being with his new friend.
"""

# set up the input prompt
input = f'{story}\n\nQuestion:{question}'

# write down what the model is expected to respond with
# NOTE: not all judges require an expected answer. refer to the implementations
expected = "I don't know"

# get the model output
output = client.chat.completions.create(
    model='gpt-4o-mini',
    messages=[
        {
            'role': 'user', 
            'content': input,
        },
    ],
).choices[0].message.content

Use a judges classifier LLM as an evaluator model

from judges.classifiers.correctness import PollMultihopCorrectness

# use the correctness classifier to determine if the first model
# answered correctly
correctness = PollMultihopCorrectness(model='gpt-4o-mini')

judgment = correctness.judge(
    input=input,
    output=output,
    expected=expected,
)
print(judgment.reasoning)
# The 'Answer' provided ('I don't know') matches the 'Reference' text which also states 'I don't know'. Therefore, the 'Answer' correctly corresponds with the information given in the 'Reference'.

print(judgment.score)
# True

Use a Jury for averaging and diversification

A jury of LLMs can enable more diverse results and enable you to combine the judgments of multiple LLMs.

from judges import Jury
from judges.classifiers.correctness import PollMultihopCorrectness, RAFTCorrectness

poll = PollMultihopCorrectness(model='gpt-4o')
raft = RAFTCorrectness(model='gpt-4o-mini')

jury = Jury(judges=[poll, raft], voting_method="average")

verdict = jury.vote(
    input=input,
    output=completion,
    expected=expected,
)
print(verdict.score)

Use AutoJudge to create a custom LLM judge

autojudge is an extension to the judges library that builds on our previous work aligning judges to human feedback -- given a labeled dataset with feedback and a natural language description of an evaluation task, autojudge creates custom, task-specific LLM judges.

Install it using:

pip install "judges[auto]"

Step 1 - Prepare your dataset: Your dataset can be either a list of dictionaries or path to a csv file with the following fields:

  • input: The input provided to your model
  • output: The model's response
  • label: 1 for correct, 0 for incorrect
  • feedback: Feedback explaining why the response is correct or incorrect

Example:

input output label feedback
What's the best time to visit Paris? The best time to visit Paris is during the spring or fall. 1 Provides accurate and detailed advice.
Can I ride a dragon in Scotland? Yes, dragons are commonly seen in the highlands and can be ridden with proper training 0 Dragons are mythical creatures; the information is fictional.

Step 2 - Initialize your autojudge: Provide a labeled dataset and describe the evaluation task.

from judges.classifiers.auto import AutoJudge

dataset = [
    {
        "input": "Can I ride a dragon in Scotland?",
        "output": "Yes, dragons are commonly seen in the highlands and can be ridden with proper training.",
        "label": 0,
        "feedback": "Dragons are mythical creatures; the information is fictional.",
    },
    {
        "input": "Can you recommend a good hotel in Tokyo?",
        "output": "Certainly! Hotel Sunroute Plaza Shinjuku is highly rated for its location and amenities. It offers comfortable rooms and excellent service.",
        "label": 1,
        "feedback": "Offers a specific and helpful recommendation.",
    },
    {
        "input": "Can I drink tap water in London?",
        "output": "Yes, tap water in London is safe to drink and meets high quality standards.",
        "label": 1,
        "feedback": "Gives clear and reassuring information.",
    },
    {
        "input": "What's the boiling point of water on the moon?",
        "output": "The boiling point of water on the moon is 100°C, the same as on Earth.",
        "label": 0,
        "feedback": "Boiling point varies with pressure; the moon's vacuum affects it.",
    }
]


# Task description
task = "Evaluate responses for accuracy, clarity, and helpfulness."

# Initialize autojudge
autojudge = AutoJudge.from_dataset(
    dataset=dataset,
    task=task,
    model="gpt-4-turbo-2024-04-09",
    # increase workers for speed ⚡
    # max_workers=2,
    # generated prompts are automatically saved to disk
    # save_to_disk=False,
)

Step 3 - Use your judge to evaluate new input-output pairs: You can use autojudge to evaluate a single input-output pair using the .judge() method.

# Input-output pair to evaluate
input_ = "What are the top attractions in New York City?"
output = "Some top attractions in NYC include the Statue of Liberty and Central Park."

# Get the judgment
judgment = autojudge.judge(input=input_, output=output)

# Print the judgment
print(judgment.reasoning)
# The response accurately lists popular attractions like the Statue of Liberty and Central Park, which are well-known and relevant to the user's query.
print(judgment.score)
# True (correct)

Appendix

Classifiers

Judge Type Category Description Reference Paper Python Import
classifier Factual Correctness Evaluates the factual correctness of a generated response against a reference answer using few-shot learning. It compares the provided answer with the reference answer to determine its accuracy. Replacing Judges with Juries: Evaluating LLM Generations with a Panel of Diverse Models from judges.classifiers.correctness import PollMultihopCorrectness
classifier Factual Correctness Assesses the factual accuracy of an AI assistant's response against a reference answer without relying on example-based (few-shot) learning. It determines whether the provided answer aligns with the reference answer based on factual information. Replacing Judges with Juries: Evaluating LLM Generations with a Panel of Diverse Models from judges.classifiers.correctness import PollZeroShotCorrectness
classifier Factual Correctness Evaluates the factual correctness of responses based on the KILT (Knowledge Intensive Language Tasks) version of Natural Questions. It uses few-shot learning to compare the AI assistant's response with the reference answer to assess accuracy. Replacing Judges with Juries: Evaluating LLM Generations with a Panel of Diverse Models from judges.classifiers.correctness import PollKiltNQCorrectness
classifier Factual Correctness Assesses the factual correctness of responses based on the KILT version of HotpotQA. It utilizes few-shot learning to determine whether the AI assistant's response aligns with the reference answer, ensuring accuracy and consistency. Replacing Judges with Juries: Evaluating LLM Generations with a Panel of Diverse Models from judges.classifiers.correctness import PollKiltHotpotCorrectness
classifier Factual Correctness Evaluates the factual correctness of responses using LLAMA-based methods as part of the RAFT (Adapting Language Model to Domain Specific RAG) framework. It determines the accuracy of the AI assistant's response by comparing it with the reference answer based on predefined criteria. RAFT: Adapting Language Model to Domain Specific RAG from judges.classifiers.correctness import RAFTCorrectness
classifier Hallucination Evaluation Determines whether a provided answer contains non-factual or hallucinated information based on predefined hallucination types and world knowledge. It evaluates the factual integrity of the AI assistant's response to ensure accuracy and reliability. HaluEval: A Large-Scale Hallucination Evaluation Benchmark for Large Language Models from judges.classifiers.hallucination import HaluEvalAnswerNonFactual
classifier Hallucination Evaluation Evaluates whether a dialogue response contains non-factual or hallucinated information by analyzing the response against predefined hallucination types and world knowledge. It ensures that the AI assistant's responses are factually accurate within the context of the dialogue. HaluEval: A Large-Scale Hallucination Evaluation Benchmark for Large Language Models from judges.classifiers.hallucination import HaluEvalDialogueResponseNonFactual
classifier Hallucination Evaluation Assesses whether a document summary contains non-factual or hallucinated information by comparing it against the source document. It ensures the summary accurately reflects the content without introducing incorrect or fabricated details. HaluEval: A Large-Scale Hallucination Evaluation Benchmark for Large Language Models from judges.classifiers.hallucination import HaluEvalDocumentSummaryNonFactual
classifier Harmfulness Evaluation Evaluates whether an AI assistant's response contains harmful content, including harmful, dangerous, unethical, illegal, or hostile information. It assesses the response for alignment with trustworthy language model guidelines to ensure the safety and reliability of the output. Trustworthy LLMs: a Survey and Guideline for Evaluating Large Language Models' Alignment from judges.classifiers.harmfulness import TrustworthyLLMHarmfulness
classifier Query Quality Evaluation Evaluates the quality of a query based on clarity, specificity, and relevance. It assesses whether the query is well-structured and aligned with the desired information retrieval objectives, ensuring that the queries facilitate accurate and relevant responses from the AI assistant. FactAlign: Long-form Factuality Alignment of Large Language Models from judges.classifiers.query_quality import FactAlignQueryQuality
classifier Refusal Evaluation Evaluates whether an AI assistant's response refuses to complete a given task. It determines if the response is a refusal based on predefined criteria, ensuring that the AI adheres to ethical guidelines and alignment policies when declining to assist with certain requests. Trustworthy LLMs: a Survey and Guideline for Evaluating Large Language Models' Alignment from judges.classifiers.refusal import TrustworthyLLMRefusal

Graders

Judge Type Category Description Reference Paper Python Import
grader Factual Correctness Evaluates the correctness of a response in an Absolute Grading setting, according to a scoring rubric. Prometheus: Inducing Fine-grained Evaluation Capability in Language Models from judges.graders.correctness import PrometheusAbsoluteCoarseCorrectness
grader Empathy Evaluation Evaluates the response of a model based on its ability to recognize implicit emotions in a statement, using a 3-point scale. EmotionQueen: A Benchmark for Evaluating Empathy of Large Language Models from judges.graders.empathy import EmotionQueenImplicitEmotionRecognition
grader Empathy Evaluation Evaluates the response of a model based on its ability to recognize the hidden intention in a statement, using a 3-point scale. EmotionQueen: A Benchmark for Evaluating Empathy of Large Language Models from judges.graders.empathy import EmotionQueenIntentionRecognition
grader Empathy Evaluation Evaluates the response of a model based on its ability to recognize the key event in a statement, using a 3-point scale. EmotionQueen: A Benchmark for Evaluating Empathy of Large Language Models from judges.graders.empathy import EmotionQueenKeyEventRecognition
grader Empathy Evaluation Evaluates the response of a model based on its ability to recognize both the significant and trivial events in a statement, using a 3-point scale. EmotionQueen: A Benchmark for Evaluating Empathy of Large Language Models from judges.graders.empathy import EmotionQueenMixedEventRecognition
grader Information Coverage Evaluation Determines whether a specific reference insight is fully, partially, or not covered within a provided list of bullet points, ensuring comprehensive coverage of key information. Summary of a Haystack: A Challenge to Long-Context LLMs and RAG Systems from judges.graders.information_coverage import HaystackBulletPointCoverageCorrectness
grader Content Moderation Categorizes user input texts into predefined categories such as hate, self-harm, sexual content, etc., determining the appropriate category based on the content's nature and intent. OR-Bench: An Over-Refusal Benchmark for Large Language Models from judges.graders.moderator import ORBenchUserInputModeration
grader Content Moderation Classifies model output texts into one of eleven predefined categories related to content sensitivity and appropriateness, ensuring responses adhere to ethical and safety guidelines. OR-Bench: An Over-Refusal Benchmark for Large Language Models from judges.graders.moderator import ORBenchUserOutputModeration
grader Query Quality Evaluation Assesses the quality of user queries based on clarity, specificity, and coherence, ensuring that queries are well-structured to facilitate accurate and relevant responses. Magpie: Alignment Data Synthesis from Scratch by Prompting Aligned LLMs with Nothing from judges.graders.query_quality import MagpieQueryQuality
grader Refusal Evaluation Classifies AI assistant responses into direct_answer, direct_refusal, or indirect_refusal, evaluating whether the assistant appropriately refuses to answer certain prompts based on ethical guidelines. Judging LLM-as-a-Judge with MT-Bench and Chatbot Arena from judges.graders.refusal_detection import ORBenchRefusalDetection
grader Relevance Evaluation Evaluates the relevance of a passage to a query based on a four-point scale: Irrelevant, Related, Highly relevant, Perfectly relevant. Ensures that the passage adequately addresses the query with varying degrees of relevance. Reliable Confidence Intervals for Information Retrieval Evaluation Using Generative A.I. from judges.graders.relevance import ReliableCIRelevance
grader Response Quality Evaluation Evaluates the quality of the AI assistant's response based on helpfulness, relevance, accuracy, depth, creativity, and level of detail, assigning a numerical grade. Judging LLM-as-a-Judge with MT-Bench and Chatbot Arena from judges.graders.response_quality import MTBenchChatBotResponseQuality