-
Notifications
You must be signed in to change notification settings - Fork 765
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add colab notebook & update docs (#619)
# What does this PR do? - add notebooks - restructure docs ## Test Plan <img width="1201" alt="image" src="https://github.com/user-attachments/assets/3f9a09d9-b5ec-406c-b44b-e896e340d209" /> <img width="1202" alt="image" src="https://github.com/user-attachments/assets/fdc1173f-2417-4ad6-845e-4f265fc40a31" /> <img width="1201" alt="image" src="https://github.com/user-attachments/assets/b1e4e2a8-acf6-4ef2-a2fc-00d26cf32359" /> ## Sources Please link relevant resources if necessary. ## Before submitting - [ ] This PR fixes a typo or improves the docs (you can dismiss the other checks if that's the case). - [ ] Ran pre-commit to handle lint / formatting issues. - [ ] Read the [contributor guideline](https://github.com/meta-llama/llama-stack/blob/main/CONTRIBUTING.md), Pull Request section? - [ ] Updated relevant documentation. - [ ] Wrote necessary unit or integration tests.
- Loading branch information
Showing
14 changed files
with
9,724 additions
and
414 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
4,658 changes: 4,658 additions & 0 deletions
4,658
docs/notebooks/Llama_Stack_Building_AI_Applications.ipynb
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,167 @@ | ||
# Benchmark Evaluations | ||
|
||
[![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/10CHyykee9j2OigaIcRv47BKG9mrNm0tJ?usp=sharing) | ||
|
||
Llama Stack provides the building blocks needed to run benchmark and application evaluations. This guide will walk you through how to use these components to run open benchmark evaluations. Visit our [Evaluation Concepts](../concepts/evaluation_concepts.md) guide for more details on how evaluations work in Llama Stack, and our [Evaluation Reference](../references/evals_reference/index.md) guide for a comprehensive reference on the APIs. Check out our [Colab notebook](https://colab.research.google.com/drive/10CHyykee9j2OigaIcRv47BKG9mrNm0tJ?usp=sharing) on working examples on how you can use Llama Stack for running benchmark evaluations. | ||
|
||
### 1. Open Benchmark Model Evaluation | ||
|
||
This first example walks you through how to evaluate a model candidate served by Llama Stack on open benchmarks. We will use the following benchmark: | ||
- [MMMU](https://arxiv.org/abs/2311.16502) (A Massive Multi-discipline Multimodal Understanding and Reasoning Benchmark for Expert AGI): Benchmark designed to evaluate multimodal models. | ||
- [SimpleQA](https://openai.com/index/introducing-simpleqa/): Benchmark designed to access models to answer short, fact-seeking questions. | ||
|
||
#### 1.1 Running MMMU | ||
- We will use a pre-processed MMMU dataset from [llamastack/mmmu](https://huggingface.co/datasets/llamastack/mmmu). The preprocessing code is shown in in this [Github Gist](https://gist.github.com/yanxi0830/118e9c560227d27132a7fd10e2c92840). The dataset is obtained by transforming the original [MMMU/MMMU](https://huggingface.co/datasets/MMMU/MMMU) dataset into correct format by `inference/chat-completion` API. | ||
|
||
```python | ||
import datasets | ||
ds = datasets.load_dataset(path="llamastack/mmmu", name="Agriculture", split="dev") | ||
ds = ds.select_columns(["chat_completion_input", "input_query", "expected_answer"]) | ||
eval_rows = ds.to_pandas().to_dict(orient="records") | ||
``` | ||
|
||
- Next, we will run evaluation on an model candidate, we will need to: | ||
- Define a system prompt | ||
- Define an EvalCandidate | ||
- Run evaluate on the dataset | ||
|
||
```python | ||
SYSTEM_PROMPT_TEMPLATE = """ | ||
You are an expert in Agriculture whose job is to answer questions from the user using images. | ||
First, reason about the correct answer. | ||
Then write the answer in the following format where X is exactly one of A,B,C,D: | ||
Answer: X | ||
Make sure X is one of A,B,C,D. | ||
If you are uncertain of the correct answer, guess the most likely one. | ||
""" | ||
|
||
system_message = { | ||
"role": "system", | ||
"content": SYSTEM_PROMPT_TEMPLATE, | ||
} | ||
|
||
client.eval_tasks.register( | ||
eval_task_id="meta-reference::mmmu", | ||
dataset_id=f"mmmu-{subset}-{split}", | ||
scoring_functions=["basic::regex_parser_multiple_choice_answer"] | ||
) | ||
|
||
response = client.eval.evaluate_rows( | ||
task_id="meta-reference::mmmu", | ||
input_rows=eval_rows, | ||
scoring_functions=["basic::regex_parser_multiple_choice_answer"], | ||
task_config={ | ||
"type": "benchmark", | ||
"eval_candidate": { | ||
"type": "model", | ||
"model": "meta-llama/Llama-3.2-90B-Vision-Instruct", | ||
"sampling_params": { | ||
"temperature": 0.0, | ||
"max_tokens": 4096, | ||
"top_p": 0.9, | ||
"repeat_penalty": 1.0, | ||
}, | ||
"system_message": system_message | ||
} | ||
} | ||
) | ||
``` | ||
|
||
#### 1.2. Running SimpleQA | ||
- We will use a pre-processed SimpleQA dataset from [llamastack/evals](https://huggingface.co/datasets/llamastack/evals/viewer/evals__simpleqa) which is obtained by transforming the input query into correct format accepted by `inference/chat-completion` API. | ||
- Since we will be using this same dataset in our next example for Agentic evaluation, we will register it using the `/datasets` API, and interact with it through `/datasetio` API. | ||
|
||
```python | ||
simpleqa_dataset_id = "huggingface::simpleqa" | ||
|
||
_ = client.datasets.register( | ||
dataset_id=simpleqa_dataset_id, | ||
provider_id="huggingface", | ||
url={"uri": "https://huggingface.co/datasets/llamastack/evals"}, | ||
metadata={ | ||
"path": "llamastack/evals", | ||
"name": "evals__simpleqa", | ||
"split": "train", | ||
}, | ||
dataset_schema={ | ||
"input_query": {"type": "string"}, | ||
"expected_answer": {"type": "string"}, | ||
"chat_completion_input": {"type": "chat_completion_input"}, | ||
} | ||
) | ||
|
||
eval_rows = client.datasetio.get_rows_paginated( | ||
dataset_id=simpleqa_dataset_id, | ||
rows_in_page=5, | ||
) | ||
``` | ||
|
||
```python | ||
client.eval_tasks.register( | ||
eval_task_id="meta-reference::simpleqa", | ||
dataset_id=simpleqa_dataset_id, | ||
scoring_functions=["llm-as-judge::405b-simpleqa"] | ||
) | ||
|
||
response = client.eval.evaluate_rows( | ||
task_id="meta-reference::simpleqa", | ||
input_rows=eval_rows.rows, | ||
scoring_functions=["llm-as-judge::405b-simpleqa"], | ||
task_config={ | ||
"type": "benchmark", | ||
"eval_candidate": { | ||
"type": "model", | ||
"model": "meta-llama/Llama-3.2-90B-Vision-Instruct", | ||
"sampling_params": { | ||
"temperature": 0.0, | ||
"max_tokens": 4096, | ||
"top_p": 0.9, | ||
"repeat_penalty": 1.0, | ||
}, | ||
} | ||
} | ||
) | ||
``` | ||
|
||
|
||
### 2. Agentic Evaluation | ||
- In this example, we will demonstrate how to evaluate a agent candidate served by Llama Stack via `/agent` API. | ||
- We will continue to use the SimpleQA dataset we used in previous example. | ||
- Instead of running evaluation on model, we will run the evaluation on a Search Agent with access to search tool. We will define our agent evaluation candidate through `AgentConfig`. | ||
|
||
```python | ||
agent_config = { | ||
"model": "meta-llama/Llama-3.1-405B-Instruct", | ||
"instructions": "You are a helpful assistant", | ||
"sampling_params": { | ||
"strategy": "greedy", | ||
"temperature": 0.0, | ||
"top_p": 0.95, | ||
}, | ||
"tools": [ | ||
{ | ||
"type": "brave_search", | ||
"engine": "tavily", | ||
"api_key": userdata.get("TAVILY_SEARCH_API_KEY") | ||
} | ||
], | ||
"tool_choice": "auto", | ||
"tool_prompt_format": "json", | ||
"input_shields": [], | ||
"output_shields": [], | ||
"enable_session_persistence": False | ||
} | ||
|
||
response = client.eval.evaluate_rows( | ||
task_id="meta-reference::simpleqa", | ||
input_rows=eval_rows.rows, | ||
scoring_functions=["llm-as-judge::405b-simpleqa"], | ||
task_config={ | ||
"type": "benchmark", | ||
"eval_candidate": { | ||
"type": "agent", | ||
"config": agent_config, | ||
} | ||
} | ||
) | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
# Evaluation Concepts | ||
|
||
The Llama Stack Evaluation flow allows you to run evaluations on your GenAI application datasets or pre-registered benchmarks. | ||
|
||
We introduce a set of APIs in Llama Stack for supporting running evaluations of LLM applications. | ||
- `/datasetio` + `/datasets` API | ||
- `/scoring` + `/scoring_functions` API | ||
- `/eval` + `/eval_tasks` API | ||
|
||
This guide goes over the sets of APIs and developer experience flow of using Llama Stack to run evaluations for different use cases. Checkout our Colab notebook on working examples with evaluations [here](https://colab.research.google.com/drive/10CHyykee9j2OigaIcRv47BKG9mrNm0tJ?usp=sharing). | ||
|
||
|
||
## Evaluation Concepts | ||
|
||
The Evaluation APIs are associated with a set of Resources as shown in the following diagram. Please visit the Resources section in our [Core Concepts](../concepts/index.md) guide for better high-level understanding. | ||
|
||
![Eval Concepts](../references/evals_reference/resources/eval-concept.png) | ||
|
||
- **DatasetIO**: defines interface with datasets and data loaders. | ||
- Associated with `Dataset` resource. | ||
- **Scoring**: evaluate outputs of the system. | ||
- Associated with `ScoringFunction` resource. We provide a suite of out-of-the box scoring functions and also the ability for you to add custom evaluators. These scoring functions are the core part of defining an evaluation task to output evaluation metrics. | ||
- **Eval**: generate outputs (via Inference or Agents) and perform scoring. | ||
- Associated with `EvalTask` resource. | ||
|
||
|
||
Use the following decision tree to decide how to use LlamaStack Evaluation flow. | ||
![Eval Flow](../references/evals_reference/resources/eval-flow.png) | ||
|
||
|
||
```{admonition} Note on Benchmark v.s. Application Evaluation | ||
:class: tip | ||
- **Benchmark Evaluation** is a well-defined eval-task consisting of `dataset` and `scoring_function`. The generation (inference or agent) will be done as part of evaluation. | ||
- **Application Evaluation** assumes users already have app inputs & generated outputs. Evaluation will purely focus on scoring the generated outputs via scoring functions (e.g. LLM-as-judge). | ||
``` | ||
|
||
## What's Next? | ||
|
||
- Check out our Colab notebook on working examples with evaluations [here](https://colab.research.google.com/drive/10CHyykee9j2OigaIcRv47BKG9mrNm0tJ?usp=sharing). | ||
- Check out our [Evaluation Reference](../references/evals_reference/index.md) for more details on the APIs. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.