Skip to content

Latest commit

 

History

History
84 lines (59 loc) · 9.23 KB

File metadata and controls

84 lines (59 loc) · 9.23 KB

Metabench

Paper

Title: metabench -- A Sparse Benchmark to Measure General Ability in Large Language Models

Abstract: https://arxiv.org/abs/2407.12844

Large Language Models (LLMs) vary in their abilities on a range of tasks. Initiatives such as the 𝙾𝚙𝚎𝚗 𝙻𝙻𝙼 𝙻𝚎𝚊𝚍𝚎𝚛𝚋𝚘𝚊𝚛𝚍 aim to quantify these differences with several large benchmarks (sets of test items to which an LLM can respond either correctly or incorrectly). However, high correlations within and between benchmark scores suggest that (1) there exists a small set of common underlying abilities that these benchmarks measure, and (2) items tap into redundant information and the benchmarks may thus be considerably compressed. We use data from $n> 5000$ LLMs to identify the most informative items of six benchmarks, ARC, GSM8K, HellaSwag, MMLU, TruthfulQA and WinoGrande (with d=28,632 items in total). From them we distill a sparse benchmark, metabench, that has less than $3%$ of the original size of all six benchmarks combined. This new sparse benchmark goes beyond point scores by yielding estimators of the underlying benchmark-specific abilities. We show that these estimators (1) can be used to reconstruct each original individual benchmark score with, on average, $1.5%$ root mean square error (RMSE), (2) reconstruct the original total score with $0.8%$ RMSE, and (3) have a single underlying common factor whose Spearman correlation with the total score is $r=0.93$.

Homepage: https://github.com/adkipnis/metabench

Citation

@article{metabench,
  author  = {Alex Kipnis and Konstantinos Voudouris and Luca M. Schulze Buschoff and Eric Schulz},
  title   = {metabench - A Sparse Benchmark to Measure General Ability in Large Language Models},
  journal = {arXiv preprint arXiv:2407.12844},
  year    = {2024},
}

Groups and Tasks

Groups

There are four groups.

  • metabench -- combines the six tasks covering the six reduced benchmarks, using the original data and transformations from the respective benchmarks, and produces an aggregated mean score. It contains a total of 858 items.
  • metabench_permute -- combines five tasks covering five of the reduced benchmarks, permuting the multiple choice ordering, and produces an aggregated mean score. It contains a total of 858 items. For more details, see immediately below.
  • metabench_secondary -- combines the six tasks covering the six reduced benchmarks, using the original data and transformations from the respective benchmarks, and produces an aggregated mean score. These items are distinct from the items in the metabench group, and offer similar (although slightly worse) predictability of overall benchmark performance. We include it as a secondary evaluation resource. It contains a total of 751 items.
  • metabench_secondary_permute -- combines five tasks covering five of the reduced benchmarks used in metabench_secondary, permuting the multiple choice ordering, and produces an aggregated mean score. It contains a total of 751 items. For more details, see immediately below.

Tasks

We offer four sets of tasks. The first uses the original benchmark items straight out of the box.

  • metabench_arc -- a subset of the ARC benchmark containing the 145 most informative items.
  • metabench_gsm8k -- a subset of the GSM8K benchmark containing the 237 most informative items.
  • metabench_hellaswag -- a subset of the HellaSwag benchmark containing the 93 most informative items.
  • metabench_mmlu -- a subset of the MMLU benchmark containing the 96 most informative items (strictly, a subset of hails/mmmlu_no_train).
  • metabench_truthfulqa -- a subset of the TruthfulQA benchmark containing the 154 most informative items.
  • metabench_winogrande -- a subset of the Winogrande benchmark containing the 133 most informative items.

Since the original benchmarks are open-source, there is a risk of contamination. To mitigate this risk, we also provide tasks in which the answers are shuffled. Since GSM8K is not a multiple-choice benchmark, it is excluded from this set.

  • metabench_arc_permute -- a subset of the ARC benchmark containing the 145 most informative items. The answers are randomly permuted such that the answer key is different to the original benchmark.
  • metabench_hellaswag_permute -- a subset of the HellaSwag benchmark containing the 93 most informative items. The answers are randomly permuted such that the answer key is different to the original benchmark.
  • metabench_mmlu_permute -- a subset of the MMLU benchmark containing the 96 most informative items (strictly, a subset of hails/mmmlu_no_train). The answers are randomly permuted such that the answer key is different to the original benchmark.
  • metabench_truthfulqa_permute -- a subset of the TruthfulQA benchmark containing the 154 most informative items. The answers are randomly permuted such that the answer key is different to the original benchmark.
  • metabench_winogrande_permute -- a subset of the Winogrande benchmark containing the 133 most informative items. The answers are randomly permuted such that the answer key is different to the original benchmark.

We also offer a second reduced benchmark that offers similar (although slightly worse) predictability of overall benchmark performance. We include it as a secondary evaluation resource. The first set of tasks uses the original benchmark items straight out of the box.

  • metabench_arc_secondary -- a subset of the ARC benchmark containing the 100 most informative items.
  • metabench_gsm8k_secondary -- a subset of the GSM8K benchmark containing the 249 most informative items.
  • metabench_hellaswag_secondary -- a subset of the HellaSwag benchmark containing the 58 most informative items.
  • metabench_mmlu_secondary -- a subset of the MMLU benchmark containing the 102 most informative items (strictly, a subset of hails/mmmlu_no_train).
  • metabench_truthfulqa_secondary -- a subset of the TruthfulQA benchmark containing the 136 most informative items.
  • metabench_winogrande_secondary -- a subset of the Winogrande benchmark containing the 106 most informative items.

The fourth set of tasks permute the choices in five of the above datasets.

  • metabench_arc_secondary_permute -- a subset of the ARC benchmark containing the 100 most informative items. The answers are randomly permuted such that the answer key is different to the original benchmark.
  • metabench_hellaswag_secondary_permute -- a subset of the HellaSwag benchmark containing the 58 most informative items. The answers are randomly permuted such that the answer key is different to the original benchmark.
  • metabench_mmlu_secondary_permute -- a subset of the MMLU benchmark containing the 102 most informative items (strictly, a subset of hails/mmmlu_no_train). The answers are randomly permuted such that the answer key is different to the original benchmark.
  • metabench_truthfulqa_secondary_permute -- a subset of the TruthfulQA benchmark containing the 136 most informative items. The answers are randomly permuted such that the answer key is different to the original benchmark.
  • metabench_winogrande_secondary_permute -- a subset of the Winogrande benchmark containing the 106 most informative items. The answers are randomly permuted such that the answer key is different to the original benchmark.

Checklist

For adding novel benchmarks/datasets to the library:

  • Is the task an existing benchmark in the literature?
    • Have you referenced the original paper that introduced the task?
    • If yes, does the original paper provide a reference implementation? If so, have you checked against the reference implementation and documented how to run such a test?

If other tasks on this dataset are already supported:

  • Is the "Main" variant of this task clearly denoted?
  • Have you provided a short sentence in a README on what each new variant adds / evaluates?
  • Have you noted which, if any, published evaluation setups are matched by this variant?