Prompt Evaluation Quickstart

no

Original Documentation

The prompt_evals template evaluates and compares different prompt variations with sentiment analysis.

Create the Project#

ragas quickstart prompt_evals
cd prompt_evals

Install Dependencies#

uv sync

Set Your API Key#

export OPENAI_API_KEY="your-openai-key"

Run the Evaluation#

uv run python evals.py

Project Structure#

prompt_evals/
├── README.md              # Project documentation
├── pyproject.toml         # Project configuration
├── prompt.py              # Prompt implementation
├── evals.py               # Evaluation workflow
├── __init__.py            # Python package marker
└── evals/
    ├── datasets/          # Test datasets
    ├── experiments/       # Evaluation results
    └── logs/              # Execution logs

What It Evaluates#

The template evaluates prompt effectiveness for sentiment classification:

  • Task: Sentiment analysis (positive/negative)
  • Test Cases: Movie reviews with expected sentiment labels
  • Metric: Binary accuracy (pass/fail)

Understanding the Code#

The Prompt (prompt.py)#

Implements the sentiment analysis prompt:

from prompt import run_prompt

sentiment = run_prompt("I loved the movie! It was fantastic.")
# Returns: "positive" or "negative"

The Evaluation (evals.py)#

Tests prompt accuracy:

@discrete_metric(name="accuracy", allowed_values=["pass", "fail"])
def my_metric(prediction: str, actual: str):
    return (
        MetricResult(value="pass", reason="")
        if prediction == actual
        else MetricResult(value="fail", reason="")
    )

Test Data#

The dataset includes movie reviews:

dataset_dict = [
    {"text": "I loved the movie! It was fantastic.", "label": "positive"},
    {"text": "The movie was terrible and boring.", "label": "negative"},
    # More examples...
]

Customization#

Test Different Prompts#

Modify prompt.py to test variations:

# Version 1: Simple
prompt = f"Is this positive or negative: {text}"

# Version 2: With examples
prompt = f"""Classify sentiment:
Examples:
- "Great movie" -> positive
- "Boring film" -> negative

Text: {text}
Sentiment:"""

# Compare results across versions

Add More Metrics#

Evaluate additional aspects:

from ragas.metrics import NumericalMetric

confidence = NumericalMetric(
    name="confidence",
    prompt="Rate confidence 1-5 in this classification: {prediction}",
    allowed_values=(1, 5),
)

Next Steps#

Link last verified June 7, 2026. View original ↗
Source: RAGAS Docs
Link last verified: 2026-03-04