--- license: apache-2.0 datasets: - xingyaoww/code-act language: - en pipeline_tag: text-generation tags: - llm-agent ---
π» Code β’ π Paper β’ π€ Data (CodeActInstruct) β’ π€ Model (CodeActAgent-Mistral-7b-v0.1) β’ π€ Chat with CodeActAgent!
We propose to use executable Python **code** to consolidate LLM agentsβ **act**ions into a unified action space (**CodeAct**). Integrated with a Python interpreter, CodeAct can execute code actions and dynamically revise prior actions or emit new actions upon new observations (e.g., code execution results) through multi-turn interactions. data:image/s3,"s3://crabby-images/9d840/9d8409b952b1d4cef0ff93d240dff6a966be8ab8" alt="Overview" ## Why CodeAct? Our extensive analysis of 17 LLMs on API-Bank and a newly curated benchmark [M3ToolEval](docs/EVALUATION.md) shows that CodeAct outperforms widely used alternatives like Text and JSON (up to 20% higher success rate). Please check our paper for more detailed analysis! data:image/s3,"s3://crabby-images/3b4cc/3b4ccbe9e51c7749b47464e725f3e411a98a1fdc" alt="Comparison between CodeAct and Text/JSON" *Comparison between CodeAct and Text / JSON as action.* data:image/s3,"s3://crabby-images/36b13/36b1380cf6a68f0b4f6967fd21c1c81f32c3056d" alt="Comparison between CodeAct and Text/JSON" *Quantitative results comparing CodeAct and {Text, JSON} on M3ToolEval.* ## π CodeActInstruct We collect an instruction-tuning dataset CodeActInstruct that consists of 7k multi-turn interactions using CodeAct. Dataset is release at [huggingface dataset π€](https://huggingface.co/datasets/xingyaoww/code-act). Please refer to the paper and [this section](#-data-generation-optional) for details of data collection. data:image/s3,"s3://crabby-images/9fb1c/9fb1c2a483ef815e9f5f04e7fdeba733b4763392" alt="Data Statistics" *Dataset Statistics. Token statistics are computed using Llama-2 tokenizer.* ## πͺ CodeActAgent Trained on **CodeActInstruct** and general conversaions, **CodeActAgent** excels at out-of-domain agent tasks compared to open-source models of the same size, while not sacrificing generic performance (e.g., knowledge, dialog). We release two variants of CodeActAgent: - **CodeActAgent-Mistral-7b-v0.1** (recommended, [model link](https://huggingface.co/xingyaoww/CodeActAgent-Mistral-7b-v0.1)): using Mistral-7b-v0.1 as the base model with 32k context window. - **CodeActAgent-Llama-7b** ([model link](https://huggingface.co/xingyaoww/CodeActAgent-Llama-2-7b)): using Llama-2-7b as the base model with 4k context window. data:image/s3,"s3://crabby-images/6ab92/6ab921719b6e47cf6b829ccb51d8f545e0091c4d" alt="Model Performance" *Evaluation results for CodeActAgent. ID and OD stand for in-domain and out-of-domain evaluation correspondingly. Overall averaged performance normalizes the MT-Bench score to be consistent with other tasks and excludes in-domain tasks for fair comparison.* Please check out [our paper](TODO) and [code](https://github.com/xingyaoww/code-act) for more details about data collection, model training, and evaluation. ## π Citation ```bibtex @misc{wang2024executable, title={Executable Code Actions Elicit Better LLM Agents}, author={Xingyao Wang and Yangyi Chen and Lifan Yuan and Yizhe Zhang and Yunzhu Li and Hao Peng and Heng Ji}, year={2024}, eprint={2402.01030}, archivePrefix={arXiv}, primaryClass={cs.CL} } ```