From bf2c1e6a79e14c40a5faa642d23e469f9137c468 Mon Sep 17 00:00:00 2001 From: Lucy Gao Date: Fri, 10 Nov 2023 17:00:18 -0800 Subject: [PATCH] docs: blogpost for code model evals (#705) * docs: blogpost for code model evals * docs: add research paper reviews * docs: revert irrelevant files --- .../2023-11-6-model-evaluation/cceval.png | 3 + .../human-eval-plus.png | 3 + .../blog/2023-11-6-model-evaluation/index.md | 115 ++++++++++++++++++ .../2023-11-6-model-evaluation/repobench.png | 3 + .../2023-11-6-model-evaluation/repocoder.png | 3 + 5 files changed, 127 insertions(+) create mode 100644 website/blog/2023-11-6-model-evaluation/cceval.png create mode 100644 website/blog/2023-11-6-model-evaluation/human-eval-plus.png create mode 100644 website/blog/2023-11-6-model-evaluation/index.md create mode 100644 website/blog/2023-11-6-model-evaluation/repobench.png create mode 100644 website/blog/2023-11-6-model-evaluation/repocoder.png diff --git a/website/blog/2023-11-6-model-evaluation/cceval.png b/website/blog/2023-11-6-model-evaluation/cceval.png new file mode 100644 index 000000000000..487d32371a5b --- /dev/null +++ b/website/blog/2023-11-6-model-evaluation/cceval.png @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:e7306bd77e34135d6a7bb8ae3b433836b9feac9f3972496321e4bb79f025409b +size 747981 diff --git a/website/blog/2023-11-6-model-evaluation/human-eval-plus.png b/website/blog/2023-11-6-model-evaluation/human-eval-plus.png new file mode 100644 index 000000000000..6f96bc290749 --- /dev/null +++ b/website/blog/2023-11-6-model-evaluation/human-eval-plus.png @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:d6ec700847f8b342df131d77241b1d2abb3a6fd32a439fcf20ec3030953a33b8 +size 105866 diff --git a/website/blog/2023-11-6-model-evaluation/index.md b/website/blog/2023-11-6-model-evaluation/index.md new file mode 100644 index 000000000000..dd0fc316faf0 --- /dev/null +++ b/website/blog/2023-11-6-model-evaluation/index.md @@ -0,0 +1,115 @@ +--- +authors: [ gyxlucy ] + +tags: [tech design] + +--- +# Cracking the Coding Evaluation + +Tabby offers an open-source alternative solution to GitHub Copilot with easy setup and self-host options. We embrace an open ecosystem to support major open source coding LLMs (e.g. StarCoder, CodeLlama, WizardCoder, etc.), and enables easy integration of proprietary models. In addition, Tabby performs [retrieval-augmented code completion](https://tabby.tabbyml.com/blog/2023/10/16/repository-context-for-code-completion) to suggest code from your private codebase. We firmly believe in the continuous advancement in open source coding LLMs, yet we need quantative measurements to guide the direction of product improvement, and help developers decide their model of choice. + +Evaluation coding LLMs has also been a hot topic in academics. Many different metrics targeting different coding tasks have been proposed over the past year. At Tabby, we prioritize on metrics that **best resembles real world development workflow**, and of course, the metrics should be constructed with non-biased data sources. In this blogpost, we will discuss our thoughts for desired code completion benchmarks, and also review latest academic progress in this area. + + +## Exisiting Paradigms +Existing coding LLM benchmark mostly focus on ***Pass@k*** metric - generating `k` code samples and measuring how often the results successfully pass given unit tests. OpenAI initially introduced this metric in [Evaluating Large Language Models Trained on Code](https://arxiv.org/pdf/2107.03374.pdf) in July 2021, along with the release of **HumanEval** bechmark dataset. + +### ๐Ÿค– HumanEval + +HumanEval is a hand-crafted dataset, consisting of 164 Python programming problems with unit tests. An example task looks like: + +```python +from typing import List + +def below_zero(operations: List[int]) -> bool: + + """ + You're given a list of deposit and withdrawal operations on a bank account that starts with zero balance. Your task is to detect if at any point the balance of account fallls below zero, and at that point function should return True. Otherwise it should return False. + + >>> below_zero([1, 2, 3]) False + + >>> below_zero([1, 2, -4, 5]) True + + """ +``` + +HumanEval was a pioneer research effort, but now suffers from some unfortunate drawbacks: + +1. ***Data is likely contaminated.*** HumanEval dataset has been around for over two years and it has been discussed and documented widely online. The latest coding LLMs are likely to have included its test data in training data crawling, which would make the evaluation no longer valid. + +2. ***Trivial coding questions that aren't mimicing real engineering setup.*** HumanEval inclues mostly LeetCode's interview-style questions, where they include a single function for LLMs to fill in the body. In a more realistic corporate setup, developers often add code in multiple files in a single PR, and constantly refer to functions implemented in other files. These are indeed more interesting yet challenging tasks for LLMs to perform, but are critical scenarios for AI coding assitants to land in enterprises. + +3. ***Unit tests are too weak.*** Researchers noticed that test cases in HumanEval tasks (on average 7.7 tests per problem) aren't enough to guarantee the correctness of the generated code (e.g. a wrong implementation could still pass all existing tests), and thus augmented test cases in HumanEval benchmark by 80x in [***HumanEvalPlus***](https://github.com/evalplus/evalplus). + +![human-eval-plus](./human-eval-plus.png) + +4. ***Limited coverage in programming languages.*** This one is obvious as HumanEval only includes Python code. We โค๏ธ all programming languages! + +### ๐Ÿงฉ Mostly Basic Programming Problems (MBPP) + +**MBPP** is another popular benchmark for code generation. Researchers from Google introduced it in the paper [**Program Synthesis with Large Language Models**](https://arxiv.org/pdf/2108.07732.pdf) in August 2021, one month after the release of HumanEval. It contains 974 entry-level Python (as the name clearly suggests) programming tasks. An example looks like: + +```python + """ + Write a python function to remove first and last occurrence of a given character from the string. + + "assert remove_Occ(\"hello\",\"l\") == \"heo\"" + "assert remove_Occ(\"abcda\",\"a\") == \"bcd\"" + "assert remove_Occ(\"PHP\",\"P\") == \"H\"" + + """ +``` + +Unlike HumanEval, MBPP targets basic tasks commonly encountered by engineers, such as string manipulation, simple arithmetic, and basic data structure operations. However it still faces similar drawbacks as HumanEval mentioned above. + + +## What we are looking for in coding LLM evaluations? + +### ๐Ÿ”ฌ Scientific and Relevant Setup +The top thing in our mind is **metric setup**. Like mentioned above, most existing coding LLM evaluations focus on function-level code generation - given a docstring or a function signature at most, the LLM is expected to generate the entire function body. + +Here are what we think a trustworthy evaluation setup should cover: + +1. ***Non-trivial code.*** Definitely no more Leetcode-style coding questions! The ideal evaluation should target projects with substantial engineering complexity. Evidences like lines of code, number of files, or number of contributors could serve as good indicators to estimate the code complexity. + +2. ***Cross-file references.*** This is a key factor to differentiate a more reliable and practical evaluation from something that only scratches the surface of the coding world. Engineers do not code in silo, but are greatly encouraged to reuse a function or API implemented in the exising codebase. + +3. ***Code completion.*** Code completion is the most widely adopted LLM-powered feature in developer tools. Millions of developers worldwide have employed AI code completions in their daily workflow. Tabby provide a low-barrier solution in code completion, and is commited to continue improve the end-to-end product quality. + + +### โš–๏ธ Ease and Low-Cost to Run +The ease and cost to run evaluations is directly correlated to the number of models we can evaluate, and the frequency we can afford to update the results (in the case of refreshed evaluation date, for example). There are efforts to leverage crowdsourcing to rate the quality of LLM responses (e.g. [Glaive arena](https://arena.glaive.ai/)) which excels at receiving high-quality human feedbacks and provides valuable insights to understand user behaviors. However it's harder to scale crowdsourcing ratings and takes longer to receive results. We are iterating quickly on Tabby, and decided that scalability and ease are critical to us now. + +### ๐Ÿ” Data Quality and Inclusion +The data quality is critical to maintain the legitimacy of such evaluation. Here's what's important for evaluation data: + +1. ***Train/Eval Data Split***. It's one of the most important concepts in your *Machine Learning 101* course. Yet often times it gets so basic that folks neglect the challenges to ensure it in real-world applications over time. For example, HumanEval started as a manually drafted dataset to firmly ensure the data separation. Nevertheless over time, it still faces data contamination issue. + +2. ***Evaluation Quality***. [***HumanEvalPlus***](https://github.com/evalplus/evalplus) mentioned above is a great example for this. Understanding the quality of the evaluation is important for developing a fair sense of the true model performance. We also encourage continuous efforts in improving evaluation quality!๐Ÿ’ช๐Ÿป + +3. ***Data Inclusion / Coverage***. In the case of coding, inclusion includes efforts like increasing the support of different programming languages. In practice, choosing the reasonable ratio of each programming language is also tricky yet important. + + +## Highlights of recent research innovations +In this section, we showcase a few recent research work of from the academics toward building reliable and sound evaluations for coding LLMs. Following these papers, we observe a growing emphasize in evaluating coding LLMs with repository-level context, which indeed aligns with what we have been looking for. + +### ๐Ÿ—‚๏ธ [CrossCodeEval: A Diverse and Multilingual Benchmark for Cross-File Code Completion](https://crosscodeeval.github.io/) + +**CrossCodeEval** benchmark specially targets to address the gap that "existing code completion datasets such as HumanEval and MBPP mostly focus on single-file tasks, neglecting the real-world complexity of multi-file software projects". To achieve this goal, CrossCodeEval uses a static-analysis-based method to strictly require cross-file context for accurate code completion. Experiments show that cross-file context improves end-to-end system performance (LLM + code retriever), yet there's still a lot of room to improve. + +![cceval](./cceval.png) + + +### ๐Ÿงช [RepoBench: Benchmarking Repository-Level Code Auto-Completion Systems](https://github.com/Leolty/repobench) + +**RepoBech** also recognizes that current benchmarks primarily focus on single-file tasks, which creates a gap in assessing these systems in more complex, real-world, multi-file programming scenarios. Therefore, RepoBench introduces three interconnected evaluation tasks: RepoBench-R (Retrieval), RepoBench-C (Code Completion), and RepoBench-P (Pipeline) to measure the quality of each module and also the end-to-end system. + +![repobench](./repobench.png) + + +### ๐Ÿ’พ [RepoCoder: Repository-Level Code Completion Through Iterative Retrieval and Generation](https://arxiv.org/abs/2303.12570) + +**RepoCoder** presents an innovative approach of combining similarity-based retriever and LLM prediction into an ***iterative** retrieval-generation pipeline*. +To demostrate the effectiveness of this method, authors also introduced ***RepoEval***, covering scenarios like line, API invocation, and function body completion from high quality real-world repositories. + +![repocoder](./repocoder.png) diff --git a/website/blog/2023-11-6-model-evaluation/repobench.png b/website/blog/2023-11-6-model-evaluation/repobench.png new file mode 100644 index 000000000000..33210ea5e82b --- /dev/null +++ b/website/blog/2023-11-6-model-evaluation/repobench.png @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:5135725cf366ca5f25674ed97bf455d57e35d376d2cb747b2cee3ac69e8ee63c +size 342050 diff --git a/website/blog/2023-11-6-model-evaluation/repocoder.png b/website/blog/2023-11-6-model-evaluation/repocoder.png new file mode 100644 index 000000000000..caaa371155df --- /dev/null +++ b/website/blog/2023-11-6-model-evaluation/repocoder.png @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:d1e5e280f492b5360e90ed907410cbfa9d4094e51c81b5ab4b1714dad2d5bd7c +size 93348