Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Autobuild] Introducing Captain Agent #21

Closed
wants to merge 28 commits into from
Closed

[Autobuild] Introducing Captain Agent #21

wants to merge 28 commits into from

Conversation

LeoLjl
Copy link
Collaborator

@LeoLjl LeoLjl commented Nov 15, 2024

This PR introduces CaptainAgent.

CaptainAgent is an agent that can break down tasks and dynamically call AutoBuild as a tool to solve the subtasks. In one tool call, the CaptainAgent will provide the building task, execution task and group name. The building task is used to assemble group of experts, the execution task is what the experts need to solve.

We propose a RAG-like pipeline for expert group generation. Given a building task, we perform similarity search in agent library and find topk candidates, then let LLM to select the best fit. If no expert is suitable for the task, new experts will be generated. Tools will be retrieved and binded to the experts.

Below is the roadmap for merging it.

  • Add full content of tool library.
  • Add test for captain agent.
  • Revise the notebook that introduces MetaAgent. The current one only involves tool library.
  • Finish blog post.

Why are these changes needed?

Related issue number

Checks

  • I've included any doc changes needed for https://ag2ai.github.io/ag2
  • I've added tests (if relevant) corresponding to the changes introduced in this PR.
  • I've made sure all auto checks have passed.

Copy link
Collaborator

@Hk669 Hk669 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

i just wanted to clarify, why are we using seperate py file for every math function. @LeoLjl
Thanks!

@LeoLjl LeoLjl requested a review from AaronWard November 16, 2024 01:43
@sonichi
Copy link
Collaborator

sonichi commented Nov 16, 2024

@LeoLjl could you please check the failing docs/checks CI? @qingyun-wu could you please set up the openai CI?

Copy link
Collaborator

@sonichi sonichi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

My suggestion of breaking down the PRs:

  1. doc + blogpost + test. Out-of-the-box usage of CaptainAgent. Shortest code example. No customization.
  2. Working code for the documented functionality in (1) which passes the test.
  3. Add configurable options in doc + blogpost + test.
  4. Working code for the documented functionality in (3) which passes the test.

We can keep this PR as a draft for having an overall understanding. Then create new PRs following (1)-(4). (1) and (2) are minimal requirements for initial release. We'll need focused discussion for each PR, and each PR will depend on previous ones.

What do you think?

website/blog/2024-11-01-CaptainAgent/index.mdx Outdated Show resolved Hide resolved
We provide an agent library and a tool library for Captain Agent to choose from when building the team. In the following section, we demonstrate how to use the libraries.

# Using Agent Library
To use captain agent, we need to instantiate a CaptainAgent and the corresponding CaptainUserProxy, then initiate a chat. To we just need to add a line of configuration to the settings.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's not clear why we need to use two special agent classes here. CaptainAgent is easy to understand. Why is a special CaptainUserProxy is needed? A user is supposed to use CaptainAgent together with any other agents, in my understanding.

# Using Agent Library
To use captain agent, we need to instantiate a CaptainAgent and the corresponding CaptainUserProxy, then initiate a chat. To we just need to add a line of configuration to the settings.

```python
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The sample code is too long. Let's think about a shortest example possible. We'd like a user to simply import CaptainAgent and use it as a stronger alternative of AssistantAgent out of the box, without any extra configuration. They can customize some options, but let's use different examples: one example for out-of-the-box use, and another example to explain customization options.

"name": "WebServing_Expert",
"description": "A helpful assistant with access to a web browser. Ask them to perform web searches, open pages, navigate to Wikipedia, answer questions from pages, and or generate summaries.",
"system_message": "",
"model_path": "autogen/agentchat/contrib/web_surfer/WebSurferAgent",
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

"model_path" is the field name but the value is the path for an agent class.

@@ -0,0 +1,73 @@
# Details of all the available configurations
Captain Agent requires `nested_mode_config` for configuration. Below is an example, we will break it down and provide a detailed explanation.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we stage the PRs? In the first PR, don't expose any tunable configuration. In the next PR, we can carefully discuss what configuration makes sense to be tunable. The reason is that once a config is added to user-facing API, removing it is a technical dept. Unless we are sure a config is good to keep, we can add it later.

## ``autobuild_init_config``
This section is used to configure the initial setup of autobuild.

### ``config_file_or_env``
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is an example of config that I don't think should appear. We can review them in a separate PR if we stage the PRs.

@LeoLjl
Copy link
Collaborator Author

LeoLjl commented Nov 16, 2024

My suggestion of breaking down the PRs:

  1. doc + blogpost + test. Out-of-the-box usage of CaptainAgent. Shortest code example. No customization.
  2. Working code for the documented functionality in (1) which passes the test.
  3. Add configurable options in doc + blogpost + test.
  4. Working code for the documented functionality in (3) which passes the test.

We can keep this PR as a draft for having an overall understanding. Then create new PRs following (1)-(4). (1) and (2) are minimal requirements for initial release. We'll need focused discussion for each PR, and each PR will depend on previous ones.

What do you think?

Of course. However, I am not sure if we can get it delivered on time given the tight scedule if we break it down and merge separately.

@qingyun-wu
Copy link
Collaborator

@LeoLjl for the interface, let's just do sth like this

captain_agent = CaptainAgent(
    name="captain_agent",
    llm_config=llm_config,
    agent_lib="xxxx",
    tool_lib="xxxx",
    code_execution_config={"use_docker": False, "work_dir": "groupchat"},
)

@LeoLjl LeoLjl closed this Nov 22, 2024
davorrunje pushed a commit that referenced this pull request Dec 19, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants