This repository includes the code and prompts we used in our EMNLP 2024 paper "Code Prompting Elicits Conditional Reasoning Abilities in Text+Code LLMs."
Abstract: We hypothesize that code prompts can trigger conditional reasoning in LLMs trained on text and code. We propose a chain of prompts that transforms a natural language problem into code and prompts the LLM with the generated code. We conduct experiments across two datasets: ConditionalQA, a scenario-based question answering (QA) dataset and BoardgameQA, a boardgame-based QA dataset with conflicting rules. Code prompts achieve large gains compared to text prompts. We also observe that code prompts are more efficient, requiring fewer demonstrations, and that they trigger superior state tracking of variables or key entities.
boardgameqa_code.ipynb
-- This notebook runscode prompts
onBoardgameQA
boardgameqa_text.ipynb
-- This notebook runstext prompts
onBoardgameQA
conditionalqa_code_prompt.ipynb
-- This notebook runscode prompts
onConditionalQA
conditionalqa_text_prompt.ipynb
-- This notebook runstext prompts
onConditionalQA
sharc_code_prompt.ipynb
-- This notebook runscode prompts
onShARC
sharc_code_text_prompt.ipynb
-- This notebook runstext prompts
onShARC
src
-- This folder contain the classes that definetext prompts
andcode prompts
forConditionalQA
andBoardgameQA
, andShARC
data
-- This folder contains the training, dev, and ICL demonstrations used in the experiments (including ablations).outputs
-- This folder contains all the prompts (inputs and outputs). It also includes the evaluation results of each prompt.
- openai
- langchain
- scikit-learn
You also need an Azure OpenAI or OpenAI API account and put your key in the notebook to run them.
conda create --name code_prompting python=3.9
conda activate code_prompting
pip install -r requirements.txt
To reproduce our main experiments, you just need to run these notebooks:
boardgameqa_code_prompt.ipynb
boardgameqa_text_prompt.ipynb
conditionalqa_code_prompt.ipynb
conditionalqa_text_prompt.ipynb
sharc_code_prompt_prompt.ipynb
sharc_code_txt_prompt.ipynb
❗️ Don't forget to add your OpenAI API keys!
❗️ Check out the paper 📃 to see all the experiments and analysis!
Contact person: Haritz Puerto, haritz.puerto@tu-darmstadt.de
https://www.ukp.tu-darmstadt.de/
Don't hesitate to send us an e-mail or report an issue if something is broken (and it shouldn't be) or if you have further questions.
This repository contains experimental software and is published for the sole purpose of giving additional background details on the respective publication.
Please use the following citation if you find our paper and/or code useful:
@inproceedings{puerto-etal-2024-code,
title = "Code Prompting Elicits Conditional Reasoning Abilities in {T}ext+{C}ode {LLM}s",
author = "Puerto, Haritz and
Tutek, Martin and
Aditya, Somak and
Zhu, Xiaodan and
Gurevych, Iryna",
editor = "Al-Onaizan, Yaser and
Bansal, Mohit and
Chen, Yun-Nung",
booktitle = "Proceedings of the 2024 Conference on Empirical Methods in Natural Language Processing",
month = nov,
year = "2024",
address = "Miami, Florida, USA",
publisher = "Association for Computational Linguistics",
url = "https://aclanthology.org/2024.emnlp-main.629",
pages = "11234--11258",
}