goreact

package module
v0.0.0-...-227ee70 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 13, 2024 License: GPL-2.0 Imports: 5 Imported by: 0

README

ReAct for Go

This is an implementation of ReAct for Go for fun. It combines Go functions with LLMs to let the LLM drive any Go code. The OpenAI provider connects it to OpenAI's GPT.

How it works

There is an initial question followed by an automatic thought, action and oberservation loop which runs until the LLM concludes that it has an answer.

The original paper "REACT: SYNERGIZING REASONING AND ACTING IN LANGUAGE MODELS" describing the idea is here.

Here is a great blog post about the implementation in Python.

How to use goreact?

First you need an instance of the LLM provider (OpenAI). Get the API key from the OpenAI account and set the OPENAI_API_KEY env variable.

	openaiProvider, err := goreact.NewOpenAIProvider(os.Getenv("OPENAI_API_KEY"))
	if err != nil {
		fmt.Printf("Failed to create OpenAIProvider: %v\n", err)
		os.Exit(1)
	}

Then you need to register your actions which the LLM can work with. It requires a function name, argument name, a description about how to use the function. The description should be written in a way that the LLM understands what it is doing and how to call it.

Finally you need to declare the function which has a string as input and output. The description, name, and argument of the function is automatically injected in the prompt to tell the LLM about its existence. There can be many functions.

	commands := map[string]goreact.Command{
		"wikisearch": {
			Name:        "wikisearch",
			Argument:    "topic",
			Description: "wikisearch searches Wikipedia for a topic",
			Func: func(topic string) (string, error) {
				page, err := gowiki.GetPage(topic, -1, false, true)
				if err != nil {
					return "Topic " + topic + "not found in Wikipedia", err
				}
				content, err := page.GetContent()
				if err != nil {
					return err.Error(), err
				}
				return content, nil
			},
		},
	}

Then the agent can be used:

	reactor, err := goreact.NewReact(openaiProvider, commands)
	if err != nil {
		fmt.Printf("Failed to create Reactor: %v\n", err)
		os.Exit(1)
	}

	answer, err := reactor.Question("What is the question for which the answer is 42?")
	if err != nil {
		fmt.Printf("Failed to get answer: %v\n", err)
		os.Exit(1)
	}
	fmt.Printf("CONCLUSION: %s\n", answer)

Examples

Examples from the examples directory.

Calculator

Steering a calculator function.

QUESTION: What is the square root of 10? What is PI? What is the sum of both numbers?
THOUGHT: I need to calculate the square root of 10 and find the value of PI.
ACTION: { "command": "calculate", "args": "sqrt(10)" }
OBSERVATION: 3.162278
THOUGHT: I have the square root of 10, now I need to find the value of PI.
ACTION: { "command": "calculate", "args": "pi" }
OBSERVATION: 3.141593
THOUGHT: I have the value of PI, now I need to calculate the sum of both numbers.
ACTION: { "command": "calculate", "args": "3.162278+3.141593" }
OBSERVATION: 6.303871
Answer: I have the sum of the square root of 10 and PI.
ANSWER: The sum of the square root of 10 and PI is 6.303871.
Rooms

Not even a robot - maybe a camera looking in different directions.

QUESTION: How many coins are in the rooms?
THOUGHT: I need to check all the rooms to count the coins.
ACTION: { "command": "look", "args": "north" } 
EXECUTING COMMAND: look north
OBSERVATION:  There is nothing north in bedroom
EXECUTING COMMAND: look east
OBSERVATION:  There is nothing east in bathroom
EXECUTING COMMAND: look south
OBSERVATION:  You found a coin in living room
EXECUTING COMMAND: look west
OBSERVATION:  There is nothing west in kitchen
Answer: I have checked all the rooms and found the coins.
ANSWER: There is 1 coin in the rooms.

Wikisearch

Let the LLM work with wikipedia for finding the answer. Since the articles are too long to fit into the context, it automatically summarizes the articles.

QUESTION: What is the fastest supercomputer today?
THOUGHT: I need to find out the fastest supercomputer today.
ACTION: { "command": "wikisearch", "args": "fastest supercomputer" }
...
OBSERVATION: Nothing interesting found
THOUGHT: I need more information to find the fastest supercomputer.
ACTION: { "command": "wikisearch", "args": "fastest supercomputer in the world" }
...
OBSERVATION: Fugaku was the fastest supercomputer in the world in June 2020, but was superseded by Frontier in May 2022.Fugaku is the fastest supercomputer today, with a performance of 442 petaFLOPS on the TOP500 FP64 high-performance LINPACK benchmark after its November 2020 upgrade. It also leads in other rankings, including Graph500, HPL-AI, and HPCG benchmark.
THOUGHT: Answer: I have found the answer to the question.
ANSWER: The fastest supercomputer today is Frontier, which superseded Fugaku in May 2022.

Another try:

QUESTION: What is the question for which the answer is 42?
THOUGHT: I need to search in Wikipedia for the question related to the number 42. 
ACTION:  { "command": "wikisearch", "args": "42 number significance" } 
OBSERVATION:  Nothing interesting found
ACTION: wikisearch { "command": "wikisearch", "args": "answer 42 question" }
Summarize observation
Summarize observation
OBSERVATION:  The specific question for which the answer is 42 is never found in the text. It is mentioned as the Answer to the Ultimate Question of Life, The Universe, and Everything. The text also explains that author Douglas Adams chose the number 42 as a joke, and it is an "ordinary number" with no hidden meaning.
Answer: I have found the reference to the answer 42 in a text by Douglas Adams.
ANSWER: The question for which the answer is 42 is known as the "Ultimate Question of Life, The Universe, and Everything" according to the book "The Hitchhiker's Guide to the Galaxy" by Douglas Adams. The specific question is never mentioned, and the number 42 is chosen as a joke with no hidden meaning.

Web

Web has 3 commands to work with:

  • Google search
  • Web scraping
  • Asking the user if something is not clear
QUESTION: What is the answer to life, the universe and everything?
THOUGHT: This seems like a philosophical question. I'm not sure what the answer is, but I'll try to search for it.
ACTION: { "command": "search", "args": "answer to life universe everything" } 
{ "command": "search", "args": "answer to life universe everything" } 
EXECUTING COMMAND: search answer to life universe everything
Search result: [{1 https://news.mit.edu/2019/answer-life-universe-and-everything-sum-three-cubes-mathematics-0910 The answer to life, the universe, and everything | MIT News 10 Sept 2019 —} {2 https://en.wikipedia.org/wiki/Phrases_from_The_Hitchhiker%27s_Guide_to_the_Galaxy Phrases from The Hitchhiker's Guide to the Galaxy42 (number) - Wikipedia This leaves the symbolic meaning that the answer to life, the universe, and everything is anything you, the user, would like it to be. 42 PuzzleEdit. The 42 ...The number 42 is, in The Hitchhiker's Guide to the Galaxy by Douglas Adams, the "Answer to the Ultimate Question of Life, the Universe, and Everything," ...} {3 https://www.scientificamerican.com/article/for-math-fans-a-hitchhikers-guide-to-the-number-42/ For Math Fans: A Hitchhiker's Guide to the Number 42 21 Sept 2020 —}]
OBSERVATION:  The answer to the question "What is the answer to life, the universe and everything?" according to Douglas Adams' book "The Hitchhiker's Guide to the Galaxy" is the number 42. This answer is meant to be symbolic and open to interpretation. In mathematics, there is a puzzle called the "42 Puzzle". However, there is no real answer to the question in a literal sense.
THOUGHT: According to my search, there is no literal answer to the question. However, the number 42 appears to hold some significance. Should I ask the user if they are satisfied with this information or if they want me to look for something else? 
EXECUTING COMMAND: ask Are you satisfied with this information or would you like me to look for something else?
Please answer the question: Are you satisfied with this information or would you like me to look for something else?
It is ok.
OBSERVATION:  It is ok.

CONCLUSION: Since the user responded with "It is ok", I can conclude that they are satisfied with the information. Thus, I can provide the answer to them based on my observation.
ANSWER: According to Douglas Adams' book "The Hitchhiker's Guide to the Galaxy", the answer to the question "What is the answer to life, the universe and everything?" is the number 42 which is meant to be symbolic and open to interpretation. However, there is no real answer to the question in a literal sense.

Documentation

Index

Constants

This section is empty.

Variables

View Source
var BasicReActPrompt string = `` /* 2292-byte string literal not displayed */
View Source
var PromptSummarize string = `` /* 382-byte string literal not displayed */

Functions

This section is empty.

Types

type Command

type Command struct {
	Name        string
	Argument    string
	Description string
	Func        func(string) (string, error)
}

type LLMProvider

type LLMProvider interface {
	Request(system, prompt string) (string, error)
}

type OpenAIProvider

type OpenAIProvider struct {
	// contains filtered or unexported fields
}

func NewOpenAIProvider

func NewOpenAIProvider(openaikey string) (*OpenAIProvider, error)

func (*OpenAIProvider) Request

func (o *OpenAIProvider) Request(system, prompt string) (string, error)

func (*OpenAIProvider) WithModel

func (o *OpenAIProvider) WithModel(model string) *OpenAIProvider

type React

type React struct {
	// contains filtered or unexported fields
}

func NewReact

func NewReact(llmProvider LLMProvider, commands map[string]Command) (*React, error)

func (*React) Question

func (r *React) Question(question string) (string, error)

func (*React) WithMainPrompt

func (r *React) WithMainPrompt(prompt string) *React

Directories

Path Synopsis
examples
web

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL