Notes from the Wired

REACT : SYNERGIZING REASONING AND ACTING IN LANGUAGE MODELS

April 4, 2024 | 700 words | 4min read

Paper Title: ReAct: Synergizing Reasoning and Acting in Language Models
Link to Paper: https://arxiv.org/abs/2210.03629
Date: 6. October 2022
Paper Type: LLM, LLM-Agent
Short Abstract:
They introduce the technique ReAct which allows LLMs to generate both reasoning and task-specific actions, by combining actions with language.

1. Introduction

One thing that makes out human intelligence is the ability of combining task-related action with verbal language reasoning. For example we might use language to keep track of our current progress. This forms a tight connection between “reasoning” and “acting”.

CoT is one example in which the authors tried to combine reasoning with actions, the problem with this approach is that it is a black-box, it uses its own internal state to generate thoughts and it is not grounded in the real world.

ReAct prompts LLMs to generate both verbal reasoning and action regarding a specific task, while incoperating external tools. They test this method on various datasets and find positive results.

Info

This approach is similar to the Toolformer paper, they differ in that ReAct uses a few-shot setting meaning examples in the prompt to teach LLM on how to use the tools(in this paper called actions), while toolformer trains the LLM supervised on how to use tools.

2. ReAct: Synergizing Reasoning + Acting

We have a general Agent setup:

The Idea of ReAct is now the following: we expand the agents action space \( A' = A \cup L \), where \(L\) is the space of language. We will call an action in \(a_{t}' \in L\) a thought, this does not effect the external environment. This thought consists of useful reasoning based on the current context \(c_t\) and is used to update the context \( c_{t+1} = (c_t, a_{t}') \). In Figure 1 we can see various thoughts e.g. (2b, Act1, Thought 1), (1d, Thought2, 4).

The language space \(L\) is unlimited they use the LLM PaLM with few-shot in context to generate actions and thoughts. For reasoning task, they alternate between generating thoughts and actions. For decision tasks, the LLM decides itself if to do an action or thought.

Example Snippet for ReAct:

Question Musician and satirist Allie Goertz wrote a song about the “The Simpsons” character Milhouse, who Matt Groening named after who?
Thought 1 The question simplifies to “The Simpsons” character Milhouse is named after who. I only need to search Milhouse and find who it is named after.
Action 1 Search[Milhouse]
Observation 1 Milhouse Mussolini Van Houten is a recurring character in the Fox animated television series The Simpsons voiced by Pamela Hayden and created by Matt Groening.
Thought 2 The paragraph does not tell who Milhouse is named after, maybe I can look up “named after”.
Action 2 Lookup[named after] Observation 2 (Result 1 / 1) Milhouse was named after U.S. president Richard Nixon, whose middle name was Milhous.
Thought 3 Milhouse was named after U.S. president Richard Nixon, so the answer is Richard Nixon.
Action 3 Finish[Richard Nixon

3. Knowledge Intensive Tasks

They consider two tasks:

The Action space consists of the following actions:

For ReAct prompting they select 3 to 6 random examples from the training set annotate them with thoughts, actions and transform them into the ReAct format

As baseline they compare:

They observe that CoT suffers more from hallucination than ReAct.

4. Decision Making Tasks

They considered two tasks

5. Conclusion

The authors proposed ReAct a framework which combines verbal reasoning with actions and achieves good results on tested benchmarks.