-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Initial commit for CodeGraph project
- Loading branch information
0 parents
commit a772f5e
Showing
26 changed files
with
5,077 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
# CodeGraph: Enhancing Graph Reasoning of LLMs with Code | ||
|
||
> [Qiaolong Cai](https://www.linkedin.com/in/qiaolong-cai-281018263/)*, [Zhaowei Wang](https://zhaowei-wang-nlp.github.io)\*, [Shizhe Diao](https://shizhediao.github.io), [James Kwok](https://www.cse.ust.hk/~jamesk/), [Yangqiu Song](https://www.cse.ust.hk/~yqsong/) | ||
\* Equal contribution | ||
|
||
## News | ||
- **[2024/12/22]** Initial code released. | ||
- **[2024/08/25]** Paper released on [arXiv](https://www.arxiv.org/abs/2408.13863). | ||
|
||
## Introduction | ||
This is the code repository for the paper: [CodeGraph: Enhancing Graph Reasoning of LLMs with Code](https://www.arxiv.org/abs/2408.13863). | ||
|
||
We introduce CodeGraph, a method for reasoning about **basic graph problems** by encoding **graph problem solutions** as **code**. This method solves new graph problems by learning from exemplars, generating programs, and executing them via a program interpreter. | ||
|
||
data:image/s3,"s3://crabby-images/e716d/e716d2599b6d4e51f69d526960897e73c79cdb6e" alt="Introduction Figure" | ||
|
||
In the upper example, the limitation of LLMs in handling arithmetic within the graph task is highlighted, while our method addresses this issue through code and external execution. In the lower-left example, LLM performance is shown to be sensitive | ||
to prompt templates that convert graph structures into natural language. The lower-right example demonstrates that the LLM’s | ||
performance is significantly influenced by the graph structure. | ||
|
||
|
||
|
||
## Getting Started | ||
|
||
Follow the steps below to set up and start using **CodeGraph**: | ||
|
||
### 1. Installation | ||
|
||
Set up the required environment and APIs by following the instructions in the [Installation Guide](docs/installation.md). | ||
|
||
|
||
### 2. Prepare the GraphQA Dataset | ||
|
||
Generate graphs and prepare the dataset needed for evaluation by referring to the [Dataset Preparation Guide](docs/prepare_data.md). | ||
|
||
|
||
### 3. Configure Prompts | ||
|
||
Learn how to create prompts for **CodeGraph** and other prompt-based baseline methods by following the [Prompt Preparation Guide](docs/prepare_prompts.md). | ||
|
||
### 4. Run Evaluation | ||
|
||
Reproduce the evaluation experiments presented in the paper. Detailed steps are available in the [Evaluation Guide](docs/evaluation.md). | ||
|
||
|
||
|
||
|
||
## Related Projects | ||
|
||
Our work is inspired by these excellent open-sourced repos: [PaL: Program-Aided Language Model](https://github.com/reasoning-machines/pal), [Program-of-Thoughts](https://github.com/TIGER-AI-Lab/Program-of-Thoughts). | ||
|
||
Our code builds upon [Talk like a Graph](https://github.com/google-research/google-research/tree/bfa1a6eaaac2bbde8ab6a376de6974233b7456c1/graphqa). Many thanks to the them! | ||
|
||
|
||
## Citation | ||
|
||
If you find this project helpful, please consider citing the following paper: | ||
|
||
```bibtex | ||
@misc{cai2024codegraphenhancinggraphreasoning, | ||
title={CodeGraph: Enhancing Graph Reasoning of LLMs with Code}, | ||
author={Qiaolong Cai and Zhaowei Wang and Shizhe Diao and James Kwok and Yangqiu Song}, | ||
year={2024}, | ||
eprint={2408.13863}, | ||
archivePrefix={arXiv}, | ||
primaryClass={cs.CL}, | ||
url={https://arxiv.org/abs/2408.13863}, | ||
} | ||
``` | ||
|
||
|
||
## License | ||
|
||
This project is licensed under the Apache License 2.0. It incorporates code from [Talk like a Graph](https://github.com/google-research/google-research/tree/bfa1a6eaaac2bbde8ab6a376de6974233b7456c1/graphqa), also licensed under the Apache License 2.0. | ||
|
||
|
||
## Contact | ||
|
||
For questions or comments about the implementation, please contact: [[email protected]](mailto:[email protected]) |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.