From 641df9c8a178b93e3dc99c98a32977034441cda9 Mon Sep 17 00:00:00 2001 From: Peli de Halleux Date: Mon, 7 Oct 2024 03:17:43 +0000 Subject: [PATCH] Add LLM tools and agents to README, refine agent descriptions across docs and code. --- README.md | 29 +++++++++++++++++++ docs/src/components/BuiltinAgents.mdx | 10 +++---- .../content/docs/reference/scripts/agents.mdx | 10 +++---- .../content/docs/reference/scripts/system.mdx | 10 +++---- .../src/genaisrc/system.agent_fs.genai.mjs | 2 +- .../src/genaisrc/system.agent_git.genai.mjs | 2 +- .../genaisrc/system.agent_github.genai.mjs | 2 +- .../system.agent_interpreter.genai.mjs | 2 +- .../system.agent_user_input.genai.mjs | 2 +- packages/core/src/runpromptcontext.ts | 2 +- 10 files changed, 50 insertions(+), 21 deletions(-) diff --git a/README.md b/README.md index dbb913cadf..d824fd4d58 100644 --- a/README.md +++ b/README.md @@ -96,6 +96,35 @@ Grep or fuzz search [files](https://microsoft.github.io/genaiscript/reference/sc const { files } = await workspace.grep(/[a-z][a-z0-9]+/, "**/*.md") ``` +### LLM Tools + +Register JavaScript functions as **tools**. + +```js +defTool( + "weahter", + "query a weather web api", + { location: "string" }, + async (args) => + await fetch(`https://weather.api.api/?location=${args.location}`) +) +``` + +### LLM Agents + +Register JavaScript functions as **tools** and combine tools + prompt into agents. + +```js +defAgent( + "git", + "Query a repository using Git to accomplish tasks.", + `Your are a helpfull LLM agent that can use the git tools to query the current repository. + Answer the question in QUERY. + - The current repository is the same as github repository.`, + { model, system: ["system.github_info"], tools: ["git"] } +) +``` + ### 🔍 RAG Built-in [Vector search](https://microsoft.github.io/genaiscript/reference/scripts/vector-search/). diff --git a/docs/src/components/BuiltinAgents.mdx b/docs/src/components/BuiltinAgents.mdx index 23f7f9a693..6364956eac 100644 --- a/docs/src/components/BuiltinAgents.mdx +++ b/docs/src/components/BuiltinAgents.mdx @@ -6,8 +6,8 @@ import { LinkCard } from '@astrojs/starlight/components'; ### Builtin Agents - - - - - + + + + + diff --git a/docs/src/content/docs/reference/scripts/agents.mdx b/docs/src/content/docs/reference/scripts/agents.mdx index 04ba27e779..55ec92f050 100644 --- a/docs/src/content/docs/reference/scripts/agents.mdx +++ b/docs/src/content/docs/reference/scripts/agents.mdx @@ -11,6 +11,11 @@ GenAIScript defines an **agent** as a [tool](/genaiscript/reference/scripts/tool runs an [inline prompt](/genaiscript/reference/scripts/inline-prompts) to accomplish a task. The agent's LLM is typically augmented with additional tools. +## Agent orchestration + +**GenAIScript does _not_ implement any agentic workflow or decision.** +It relies entirely on [tools](/genaiscript/reference/scripts/tools) support built into the LLMs. + ```mermaid flowchart TD query["query"] --> |"why did the build fail?"| LLM @@ -32,11 +37,6 @@ flowchart TD LLM --> |"the change at line 50 is wrong"| response["response"] ``` -## Agent orchestration - -**GenAIScript does _not_ implement any agentic workflow or decision.** -It relies entirely on [tools](/genaiscript/reference/scripts/tools) support built into the LLMs. - ## defAgent The `defAgent` function is used to define an agent that can be called by the LLM. It takes a JSON schema to define the input and expects a string output. The LLM autonomously decides to call this agent. diff --git a/docs/src/content/docs/reference/scripts/system.mdx b/docs/src/content/docs/reference/scripts/system.mdx index 82c9b1616d..4502c8f94a 100644 --- a/docs/src/content/docs/reference/scripts/system.mdx +++ b/docs/src/content/docs/reference/scripts/system.mdx @@ -113,7 +113,7 @@ const model = env.vars.agentFsModel defAgent( "fs", - "Queries files to accomplish tasks", + "query files to accomplish tasks", `Your are a helpfull LLM agent that can query the file system. Answer the question in QUERY.`, { @@ -148,7 +148,7 @@ const model = env.vars.agentGitModel defAgent( "git", - "Agent that can query a repository using Git to accomplish tasks. Provide all the context information available to execute git queries.", + "query a repository using Git to accomplish tasks. Provide all the context information available to execute git queries.", `Your are a helpfull LLM agent that can use the git tools to query the current repository. Answer the question in QUERY. - The current repository is the same as github repository.`, @@ -175,7 +175,7 @@ const model = env.vars.agentGithubModel defAgent( "github", - "Agent that can query GitHub to accomplish tasks", + "query GitHub to accomplish tasks", `Your are a helpfull LLM agent that can query GitHub to accomplish tasks. Answer the question in QUERY. Prefer diffing job logs rather downloading entire logs which can be very large.`, { @@ -211,7 +211,7 @@ system({ const model = env.vars.agentInterpreterModel defAgent( "interpreter", - "Run code interpreters for Python, Math. Use this agent to ground computation questions.", + "run code interpreters for Python, Math. Use this agent to ground computation questions.", `You are an agent that can run code interpreters for Python, Math. Answer the question in QUERY. - Prefer math_eval for math expressions as it is much more efficient. - To use file data in python, prefer copying data files using python_code_interpreter_copy_files rather than inline data in code. @@ -247,7 +247,7 @@ system({ const model = env.vars.agentInterpreterModel defAgent( "user_input", - "Ask user for input to confirm, select or answer the question in the query. The message should be very clear and provide all the context.", + "ask user for input to confirm, select or answer the question in the query. The message should be very clear and provide all the context.", `Your task is to ask the question in QUERY to the user using the tools. - Use the best tool to interact with the user. - do NOT try to interpret the meaning of the question, let the user answer. diff --git a/packages/core/src/genaisrc/system.agent_fs.genai.mjs b/packages/core/src/genaisrc/system.agent_fs.genai.mjs index 220ee38b3a..105a7e0074 100644 --- a/packages/core/src/genaisrc/system.agent_fs.genai.mjs +++ b/packages/core/src/genaisrc/system.agent_fs.genai.mjs @@ -6,7 +6,7 @@ const model = env.vars.agentFsModel defAgent( "fs", - "Queries files to accomplish tasks", + "query files to accomplish tasks", `Your are a helpfull LLM agent that can query the file system. Answer the question in QUERY.`, { diff --git a/packages/core/src/genaisrc/system.agent_git.genai.mjs b/packages/core/src/genaisrc/system.agent_git.genai.mjs index cc6ffb002e..d3d53161c0 100644 --- a/packages/core/src/genaisrc/system.agent_git.genai.mjs +++ b/packages/core/src/genaisrc/system.agent_git.genai.mjs @@ -6,7 +6,7 @@ const model = env.vars.agentGitModel defAgent( "git", - "Agent that can query a repository using Git to accomplish tasks. Provide all the context information available to execute git queries.", + "query a repository using Git to accomplish tasks. Provide all the context information available to execute git queries.", `Your are a helpfull LLM agent that can use the git tools to query the current repository. Answer the question in QUERY. - The current repository is the same as github repository.`, diff --git a/packages/core/src/genaisrc/system.agent_github.genai.mjs b/packages/core/src/genaisrc/system.agent_github.genai.mjs index 414553c3f8..f5a1882367 100644 --- a/packages/core/src/genaisrc/system.agent_github.genai.mjs +++ b/packages/core/src/genaisrc/system.agent_github.genai.mjs @@ -6,7 +6,7 @@ const model = env.vars.agentGithubModel defAgent( "github", - "Agent that can query GitHub to accomplish tasks", + "query GitHub to accomplish tasks", `Your are a helpfull LLM agent that can query GitHub to accomplish tasks. Answer the question in QUERY. Prefer diffing job logs rather downloading entire logs which can be very large.`, { diff --git a/packages/core/src/genaisrc/system.agent_interpreter.genai.mjs b/packages/core/src/genaisrc/system.agent_interpreter.genai.mjs index 34aff6e176..30b3a09916 100644 --- a/packages/core/src/genaisrc/system.agent_interpreter.genai.mjs +++ b/packages/core/src/genaisrc/system.agent_interpreter.genai.mjs @@ -5,7 +5,7 @@ system({ const model = env.vars.agentInterpreterModel defAgent( "interpreter", - "Run code interpreters for Python, Math. Use this agent to ground computation questions.", + "run code interpreters for Python, Math. Use this agent to ground computation questions.", `You are an agent that can run code interpreters for Python, Math. Answer the question in QUERY. - Prefer math_eval for math expressions as it is much more efficient. - To use file data in python, prefer copying data files using python_code_interpreter_copy_files rather than inline data in code. diff --git a/packages/core/src/genaisrc/system.agent_user_input.genai.mjs b/packages/core/src/genaisrc/system.agent_user_input.genai.mjs index 7695580daa..1ef468b807 100644 --- a/packages/core/src/genaisrc/system.agent_user_input.genai.mjs +++ b/packages/core/src/genaisrc/system.agent_user_input.genai.mjs @@ -5,7 +5,7 @@ system({ const model = env.vars.agentInterpreterModel defAgent( "user_input", - "Ask user for input to confirm, select or answer the question in the query. The message should be very clear and provide all the context.", + "ask user for input to confirm, select or answer the question in the query. The message should be very clear and provide all the context.", `Your task is to ask the question in QUERY to the user using the tools. - Use the best tool to interact with the user. - do NOT try to interpret the meaning of the question, let the user answer. diff --git a/packages/core/src/runpromptcontext.ts b/packages/core/src/runpromptcontext.ts index 1865e41237..b0626c87fa 100644 --- a/packages/core/src/runpromptcontext.ts +++ b/packages/core/src/runpromptcontext.ts @@ -307,7 +307,7 @@ export function createChatGenerationContext( agentSystem, arrayify(tools) ) - const agentDescription = dedent`Agent uses LLM to ${description}. available tools: + const agentDescription = dedent`Agent that uses an LLM to ${description}.\nAvailable tools: ${agentTools.map((t) => `- ${t.description}`).join("\n")}` // DO NOT LEAK TOOL ID HERE defTool(