diff --git a/docs/basic_guides/automatic_evaluation.mdx b/docs/basic_guides/automatic_evaluation.mdx index 26ac847e5e..2af956f11a 100644 --- a/docs/basic_guides/automatic_evaluation.mdx +++ b/docs/basic_guides/automatic_evaluation.mdx @@ -1,5 +1,70 @@ --- -title: 'Automatic Evaluation' +title: 'Evaluating LLM Apps' +description: Systematically evaluate your LLM applications and compare their performance. --- - This page is under construction. Please reach out to us on [Slack](https://join.slack.com/t/agenta-hq/shared_invite/zt-1zsafop5i-Y7~ZySbhRZvKVPV5DO_7IA) **#support** channel, [Book a call](https://cal.com/mahmoud-mabrouk-ogzgey/demo), through [email](mailto:team@agenta.ai) if you need help with using automatic evaluation. \ No newline at end of file +The key to building production-ready LLM applications is to have a tight feedback loop of prompt engineering and evaluation. In this document, we will explain how to use agenta to quickly evaluate and compare the performance of your LLM applications. + +## Configuring Evaluators + +Agenta comes with a set of built-in evaluators that can be configured. + +By default, each project includes the following evaluators (which do not require configuration): +- Exact match: This evaluator checks if the generated answer is an exact match to the expected answer. The aggregated result is the percentage of correct answers. + +Additionally, the following configurable evaluators are available but need to be explicitly configured and added before use. + +To add an evaluator, go to the Evaluators tab and click on the "Add Evaluator" button. A modal will appear where you can select the evaluator you want to add and configure it. + + + + + + + +**Configurable evaluators** +- Regex match: This evaluator checks if the generated answer matches a regular expression pattern. You need to provide the regex expression and specify whether an answer is correct if it matches or does not match the regex. +- Webhook evaluator: This evaluator sends the generated answer and the correct_answer to a webhook and expects a response indicating the correctness of the answer. You need to provide the URL of the webhook. +- Similarity Match evaluator: This evaluator checks if the generated answer is similar to the expected answer. You need to provide the similarity threshold. It uses the Jaccard similarity to compare the answers. +- AI Critic evaluator: This evaluator sends the generated answer and the correct_answer to an LLM model and uses it to evaluate the correctness of the answer. You need to provide the evaluation prompt (or use the default prompt). +- Custom code evaluator: This evaluator allows you to write your own evaluator in Python. You need to provide the Python code for the evaluator. More details can be found here. + + +## Begin Evaluation +To start an evaluation, go to the Evaluations page and click on the "Begin Evaluation Now" button. A modal will appear where you can fine-tune the evaluation based on your specific requirements. + +In the modal, you need to specify the following parameters: + +- Testset: Choose the testset you want to use for the evaluation. +- Variants: Select one or more variants you wish to evaluate. +- Evaluators: Choose one or more evaluators for the assessment. + + + + +### Advanced Configuration +Additional configurations for batching and retrying LLM calls are available in the advanced configuration section. You can specify the following parameters: + +- Batch Size: Set the number of testsets to include in each batch (default is 10). +- Retry Delay: Define the delay before retrying a failed language model call (in seconds, default is 3). +- Max Retries: Specify the maximum number of retries for a failed language model call (default is 3). +- Delay Between Batches: Set the delay between running batches (in seconds, default is 5). + +In addition to the batching and retrying configurations, you can also specify the following parameters: +- Correct Answer Column: Specify the column in the test set containing the correct/expected answer (default is correct_answer). + + + + +## View Evaluation Result +To view the result of an evaluation, double-click on the evaluation row once you have clicked the "Create" button and the evaluation status is set to "completed". This will give you access to the detailed evaluation results. + + + + +## Compare Evaluations +When the evaluation status is set to "completed", you can select two or more evaluations from the same testset to compare. Click on the "Compare" button, and you will be taken to the Evaluation comparison view where you can compare the output of two or more evaluations. + + + + diff --git a/docs/basic_guides/custom_evaluator.mdx b/docs/basic_guides/custom_evaluator.mdx new file mode 100644 index 0000000000..b2ad3888c1 --- /dev/null +++ b/docs/basic_guides/custom_evaluator.mdx @@ -0,0 +1,57 @@ +--- +title: 'Writing Custom Evaluators' +description: 'Write the code for a custom evaluator on Agenta' +--- + +Sometimes, the default evaluators on Agenta may not be sufficient for your specific use case. In such cases, you can create a custom evaluator to suit your specific needs. Custom evaluators are written in Python. + +For the moment, there are limitation on the code that can be written in the custom evaluator. Our backend uses RestrictedPython to execute the code which limits the libraries that can be used. + + +## Accessing the Evaluator Page +To create a custom evaluator on Agenta, simply click on the Evaluations button in the sidebar menu, and then select the "Evaluators" tab within the Evaluations page. + + + +## Creating an Evaluator +On the Evaluators tab, click on the "New Evaluator" button at the top right corner of your screen which would open a modal prompting you to provide the following information: +1. Evaluator name: Enter a unique and descriptive name for your custom evaluator. +2. Evaluator Template: Choose a template for your custom evaluator. This could be based on the specific criteria or type of evaluation you want. + + +Click on the "Create" button within the modal to confirm and complete the creation of your custom evaluator. + +## Evaluation code + +Your code should include on function called evaluate with the following signature: +```python +from typing import Dict + +def evaluate( + app_params: Dict[str, str], + inputs: Dict[str, str], + output: str, + correct_answer: str +) -> float: +``` + +The function should return a float value which is the score of the evaluation. The score should be between 0 and 1. 0 means the evaluation failed and 1 means the evaluation passed. + +The parameters are as follows: +1. app_params: A dictionary containing the configuration of the app. This would include the prompt, model and all the other parameters specified in the playground with the same naming. +2. inputs: A dictionary containing the inputs of the app. +3. output: The generated output of the app. +4. correct_answer: The correct answer of the app. + +For instance, exact match would be implemented as follows: +```python +from typing import Dict + +def evaluate( + app_params: Dict[str, str], + inputs: Dict[str, str], + output: str, + correct_answer: str +) -> float: + return 1 if output == correct_answer else 0 +``` diff --git a/docs/basic_guides/human_evaluation.mdx b/docs/basic_guides/human_evaluation.mdx index 9545bcd8d0..8d0c21b7d0 100644 --- a/docs/basic_guides/human_evaluation.mdx +++ b/docs/basic_guides/human_evaluation.mdx @@ -2,4 +2,47 @@ title: 'Human Evaluation' --- - This page is under construction. Please reach out to us on [Slack](https://join.slack.com/t/agenta-hq/shared_invite/zt-1zsafop5i-Y7~ZySbhRZvKVPV5DO_7IA) **#support** channel, [Book a call](https://cal.com/mahmoud-mabrouk-ogzgey/demo), or through [email](mailto:team@agenta.ai) if you need help with using human evaluation. \ No newline at end of file +Sometimes, you may need to evaluate the performance of your models using human judgment. This is where the Human Evaluation feature comes in. It allows you to conduct A/B tests and single model tests to evaluate the performance of your models using human judgment. + +## Single Model Evaluation +Single model test allows you to score the performance of a single LLM app manually. + +To start a new evaluation with the single model test, you need to: +- Select a variant would you like to evaluate +- Select a testset you want to use for the evaluation + +To start a new evaluation with the single model test, follow these steps: + +1. Select the variant you would like to evaluate. +2. Choose the testset you want to use for the evaluation. + +Click on the "Start a new evaluation" button to begin the evaluation process. Once the evaluation is initiated, you will be directed to the Single Model Test Evaluation view. Here, you can perform the following actions: + +- Score: Enter a numerical score to evaluate the performance of the chosen variant. +- Additional Notes: Add any relevant notes or comments to provide context or details about the evaluation. +- Export Results: Use the "Export Results" functionality to save and export the evaluation results. + + + + +## A/B Test +A/B tests allow you to compare the performance of two different variants manually. For each data point you can select which variant is better, or if they are equally good or bad. + +To start a new evaluation with an A/B Test, follow these steps: + +1. Select two variants that you would like to evaluate. +2. Choose the testset you want to use for the evaluation. + +### Invite Collaborators + +In an A/B Test, you can invite members of your workspace to collaborate on the evaluation by sharing a link to the evaluation. For information on how to add members to your workspace, please refer to this guide. + +Click on the "Start a new evaluation" button to begin the evaluation process. Once the evaluation is initiated, you will be directed to the A/B Test Evaluation view. Here, you can perform the following actions: + +- Scoring between variants: Evaluate and score the performance of each variant for the expected output. +- Additional Notes: Add any relevant notes or comments to provide context or details about the evaluation. +- Export Results: Use the "Export Results" functionality to save and export the evaluation results. + + + + diff --git a/docs/images/basic_guides/15_accessing_evaluator_page_dark.png b/docs/images/basic_guides/15_accessing_evaluator_page_dark.png new file mode 100644 index 0000000000..0cdea59df5 Binary files /dev/null and b/docs/images/basic_guides/15_accessing_evaluator_page_dark.png differ diff --git a/docs/images/basic_guides/15_accessing_evaluator_page_light.png b/docs/images/basic_guides/15_accessing_evaluator_page_light.png new file mode 100644 index 0000000000..f98f5e4ea6 Binary files /dev/null and b/docs/images/basic_guides/15_accessing_evaluator_page_light.png differ diff --git a/docs/images/basic_guides/16_new_evaluator_modal_dark.png b/docs/images/basic_guides/16_new_evaluator_modal_dark.png new file mode 100644 index 0000000000..10f4dff8a1 Binary files /dev/null and b/docs/images/basic_guides/16_new_evaluator_modal_dark.png differ diff --git a/docs/images/basic_guides/16_new_evaluator_modal_light.png b/docs/images/basic_guides/16_new_evaluator_modal_light.png new file mode 100644 index 0000000000..2588848188 Binary files /dev/null and b/docs/images/basic_guides/16_new_evaluator_modal_light.png differ diff --git a/docs/images/basic_guides/17_begin_evaluation_modal_dark.png b/docs/images/basic_guides/17_begin_evaluation_modal_dark.png new file mode 100644 index 0000000000..e2cd3bf5d0 Binary files /dev/null and b/docs/images/basic_guides/17_begin_evaluation_modal_dark.png differ diff --git a/docs/images/basic_guides/17_begin_evaluation_modal_light.png b/docs/images/basic_guides/17_begin_evaluation_modal_light.png new file mode 100644 index 0000000000..f115d50e12 Binary files /dev/null and b/docs/images/basic_guides/17_begin_evaluation_modal_light.png differ diff --git a/docs/images/basic_guides/18_begin_evaluation_modal_advanced_config_dark.png b/docs/images/basic_guides/18_begin_evaluation_modal_advanced_config_dark.png new file mode 100644 index 0000000000..4ce85f6620 Binary files /dev/null and b/docs/images/basic_guides/18_begin_evaluation_modal_advanced_config_dark.png differ diff --git a/docs/images/basic_guides/18_begin_evaluation_modal_advanced_config_light.png b/docs/images/basic_guides/18_begin_evaluation_modal_advanced_config_light.png new file mode 100644 index 0000000000..6dddd5604a Binary files /dev/null and b/docs/images/basic_guides/18_begin_evaluation_modal_advanced_config_light.png differ diff --git a/docs/images/basic_guides/19_view_evaluation_result_dark.png b/docs/images/basic_guides/19_view_evaluation_result_dark.png new file mode 100644 index 0000000000..f749123877 Binary files /dev/null and b/docs/images/basic_guides/19_view_evaluation_result_dark.png differ diff --git a/docs/images/basic_guides/19_view_evaluation_result_light.png b/docs/images/basic_guides/19_view_evaluation_result_light.png new file mode 100644 index 0000000000..0470085d85 Binary files /dev/null and b/docs/images/basic_guides/19_view_evaluation_result_light.png differ diff --git a/docs/images/basic_guides/20_evaluation_comparison_view_dark.png b/docs/images/basic_guides/20_evaluation_comparison_view_dark.png new file mode 100644 index 0000000000..f9e5e2d497 Binary files /dev/null and b/docs/images/basic_guides/20_evaluation_comparison_view_dark.png differ diff --git a/docs/images/basic_guides/20_evaluation_comparison_view_light.png b/docs/images/basic_guides/20_evaluation_comparison_view_light.png new file mode 100644 index 0000000000..9de06368cb Binary files /dev/null and b/docs/images/basic_guides/20_evaluation_comparison_view_light.png differ diff --git a/docs/images/basic_guides/21_ab_test_view_dark.png b/docs/images/basic_guides/21_ab_test_view_dark.png new file mode 100644 index 0000000000..f80538d77b Binary files /dev/null and b/docs/images/basic_guides/21_ab_test_view_dark.png differ diff --git a/docs/images/basic_guides/21_ab_test_view_light.png b/docs/images/basic_guides/21_ab_test_view_light.png new file mode 100644 index 0000000000..6fef792e2d Binary files /dev/null and b/docs/images/basic_guides/21_ab_test_view_light.png differ diff --git a/docs/images/basic_guides/22_single_model_test_view_dark.png b/docs/images/basic_guides/22_single_model_test_view_dark.png new file mode 100644 index 0000000000..5b8f744e34 Binary files /dev/null and b/docs/images/basic_guides/22_single_model_test_view_dark.png differ diff --git a/docs/images/basic_guides/22_single_model_test_view_light.png b/docs/images/basic_guides/22_single_model_test_view_light.png new file mode 100644 index 0000000000..c2b2ca30f3 Binary files /dev/null and b/docs/images/basic_guides/22_single_model_test_view_light.png differ diff --git a/docs/mint.json b/docs/mint.json index dcc3a6eeb5..0375502888 100644 --- a/docs/mint.json +++ b/docs/mint.json @@ -85,6 +85,8 @@ "basic_guides/creating_an_app", "basic_guides/prompt_engineering", "basic_guides/test_sets", + "basic_guides/automatic_evaluation", + "basic_guides/human_evaluation", "basic_guides/deployment", "basic_guides/team_management" ] @@ -93,6 +95,7 @@ "group": "Advanced Guides", "pages": [ "advanced_guides/custom_applications", + "basic_guides/custom_evaluator", "advanced_guides/using_agenta_from_cli" ] }, @@ -121,9 +124,9 @@ { "group": "Tutorials", "pages": [ - "developer_guides/developer_guides/tutorials/first-app-with-langchain", - "developer_guides/developer_guides/tutorials/build-rag-application", - "developer_guides/developer_guides/tutorials/deploy-mistral-model" + "developer_guides/tutorials/first-app-with-langchain", + "developer_guides/tutorials/build-rag-application", + "developer_guides/tutorials/deploy-mistral-model" ] }, {