Skip to content

geometor/_LLM_debate_on_ARC

 
 

Repository files navigation

Foundation Model Debate on ARC Dataset

The LLM-Debate paper showed that having LLMs engage in debate can significantly enhance their mathematical and strategic reasoning skills. Can this debate approach improve LLMs performance on the ARC dataset?


Examples of ARC dataset, taken from this X thread.

Contents

Results Summary

Click to expand

This study explores two approaches for eliciting outputs from Large Language Models (LLMs) in tasks that can be represented through input and output matrices: (1) Direct, where the LLM is requested to directly produce the solution matrix, and (2) Code, where the LLM is tasked with generating the code that, when executed, will generate the solution matrix. In a given task, the pattern extracted from the demonstrations is consistent with that required for the test case. Hence, code generation provides more interpretable evidence of the LLM's comprehension of the underlying patterns.

Given the difficulty of tasks in the ARC dataset, this study adopts a nuanced approach for evaluating responses. Rather than categorizing answers strictly as correct or incorrect, we assess them based on the percentage of elements (numbers) in the response (the output matrix) that align with the correct solution. This method allows for a more granular understanding of performance, potentially providing better insights into the effectiveness of the debate mechanism in enhancing reasoning capabilities.

We evaluate on two LLM settings: (1) GPT-4, a stronger but closed sourced model by OpenAI, and (2) Gemma, an open-source model by Google Deepmind accessible through Hugging Face. Since Gemma does not have a system prompt component and has a shorter context window, system prompts are provided to GPT-4 only. The same user prompts are used for both GPT-4 and Gemma (Appendix A). For computation efficiency, we only evaluate on 10 data points from the ARC dataset.

Number of Agents. First, we analyze how the number of agents affect the performance. We increase the number of agents used in the debate (from one to three), while fixing the number of debate rounds to be two. There is no clear trend that increasing the number of debate rounds will definitely lead to higher performance. Having more agents only increased the performance in the Direct-Gemma setting.

diffagents Average score achieved against the number of agents participating in the debate, with the number of debate rounds fixed to two.

Rounds of Debate. Next, we analyze how the number of debate rounds affect the performance. We increase the number of debate rounds (from one to three), while fixing the number of agents to be two. There is no clear trend that increasing the number of debate rounds will definitely lead to higher performance. Having more debate rounds only increased the performance in the Code-Gemma setting. In the Code-GPT-4 and Direct-Gemma settings, having more debate rounds actually decreased performance.

diffrounds Average score achieved against the number of debate rounds, with the number of agents fixed to two.

Repo Walkthrough

Click to expand

Download ARC dataset

Setup

python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt
pip install accelerate

Run debate

python gen_arc.py  --agents N --rounds N --n-data N --direct --soft-eval --model gemma
  • --agents how many agents debating with each other
  • --rounds how many rounds the agents will debate with each other
  • --n-data number of datapoints to evaluate on (default: -1 is all)
  • --direct ask the FM to directly output the solution instead of writing code
  • --soft-eval the score is not just 0 or 1, but the percentage of how many numbers match
  • --model [openai, gemma] which FM to use

bash script to run all experiments

bash ./run_gemma.sh
bash ./run_openai.sh

Make plots

python plot_arc.py --agents N --rounds N
  • make plots with fixed number of agents N
  • make plots with fixed number of rounds N

Possible extensions

  • Using vision-language models instead of LLMs
  • Evaluate more data samples
  • Increasing the number of agents and debate rounds

About

LLM Debate on ARC dataset

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 86.5%
  • Shell 13.5%