Skip to content

Commit

Permalink
Merge pull request #289 from PrefectHQ/concepts
Browse files Browse the repository at this point in the history
Consolidate concept docs
  • Loading branch information
jlowin authored Sep 7, 2024
2 parents 7f5bed0 + 471fcf7 commit 1493135
Show file tree
Hide file tree
Showing 16 changed files with 422 additions and 382 deletions.
Original file line number Diff line number Diff line change
@@ -1,17 +1,89 @@
---
title: Assigning Agents to Tasks
sidebarTitle: Assigning to Tasks
title: Agents
description: The intelligent workers in your AI workflows.
icon: robot
---

Agents must be assigned to tasks in order to work on them.
Agents are the intelligent, autonomous entities that power your AI workflows in ControlFlow. They represent AI models capable of understanding instructions, making decisions, and completing tasks.

Use the `agents` parameter when creating a task to assign agents. Each task requires at least one assigned agent, and will use a default agent if none are provided. Agents can be assigned to multiple tasks, and tasks can have multiple agents.
```python
import controlflow as cf

agent = cf.Agent("Marvin")
```
## What are agents?
Agents in ControlFlow are configurable AI entities, each with its own identity, capabilities, and even personality. They act as the "workers" in your AI workflows, responsible for executing tasks and making decisions based on their assigned objectives and available tools.

You can think of each agent as a portable LLM configuration. When you assign one or more agents to a task, they will collaborate to complete the task according to the instructions and tools you provide.


## Creating agents

To create an agent, use the `Agent` class.

```python
import controlflow as cf

agent = cf.Agent(name="Marvin")
```

A more complex agent can be created by providing additional configuration. This agent shows almost every possible configuration option:

```python
import controlflow as cf
from langchain_openai import ChatOpenAI

agent = cf.Agent(
name="Data Analyst",
description="An AI agent specialized in data analysis",
instructions=(
"Perform data analysis tasks efficiently and accurately. "
"Browse the web for data and use Python to analyze it."
),
tools=[cf.tools.web.get_url, cf.tools.code.python],
model=ChatpOpenAI('gpt-4o-mini'),
interactive=True,
)
```

## Agent properties

### Name

An agent's name is an identifier that is visible to other agents in the workflow. It is used to distinguish between agents and for logging and debugging purposes. If possible, keep agent names unique within a flow to avoid confusion. While agents do have deterministic IDs that can be used to disambiguate two agents with the same name, they will often use names when interacting with each other.

### Description

A description is a brief summary of the agent's role or specialization. This information is visible to other agents, and helps them understand the agent's capabilities and expertise.

### Instructions

Instructions are specific instructions or guidelines for the agent to follow during task execution. These instructions are private and not shared with other agents.

### Tools

Tools are Python functions that the agent can call to perform specific actions or computations. They are defined as a list of functions when creating an agent, and can be used to enhance the agent's capabilities. The agent will have access to these tools in every task they are assigned to. If a task defines additional tools, the agent will have access to those as well.

### Model

Each agent has a model, which is the LLM that powers the agent responses. This allows you to choose the most suitable model for your needs, based on factors such as performance, latency, and cost.

ControlFlow supports any LangChain LLM that supports chat and function calling. For more details on how to configure models, see the [LLMs guide](/guides/llms).

### Interactivity

By default, agents have no way to communicate with users. If you want to chat with an agent, set `interactive=True`. By default, this will let the agent communicate with users on the command line.

To learn more, see the [Interactivity guide](/patterns/interactivity).

## Assigning agents to tasks

Agents must be assigned to tasks in order to work on them. You can assign agents by passing them to the `agents` parameter when creating a task. Each task requires at least one assigned agent, and will use a default agent if none are provided. Agents can be assigned to multiple tasks, and tasks can have multiple agents.

## Assigning agents

### Tasks with no agents

If you do not assign any agents to a task, it will determine its agents at runtimeaccording to the following rules:
If you do not assign any agents to a task, it will determine its agents at runtime according to the following rules:

1. If the task has a parent, it will use the parent's agents.
2. If the task's flow has a default agent, it will use that agent.
Expand Down Expand Up @@ -124,8 +196,9 @@ temporary positive outcomes, despite the overall bleak and discouraging reality.
</CodeGroup>
When tasks have multiple agents, it's important to understand how they collaborate (and to provide them with clear instructions to guide that behavior). To learn more, see the [collaboration](/patterns/collaborating-agents) doc.
## Completion agents
#### Assigning completion agents
By default, every agent assigned to a task will be given tools for marking the task as successful or failed. If you want to restrict completion tools to a specific agent or agents, you can do so by setting the task's `completion_agents`.
Expand Down
24 changes: 0 additions & 24 deletions docs/concepts/agents/agents.mdx

This file was deleted.

62 changes: 0 additions & 62 deletions docs/concepts/agents/creating-agents.mdx

This file was deleted.

59 changes: 44 additions & 15 deletions docs/concepts/concepts.mdx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
---
title: Core Concepts
title: Core concepts
sidebarTitle: Overview
description: The building blocks of agentic workflows.
description: The building blocks of agentic workflows
---

ControlFlow is a framework for building AI workflows that bridges the gap between
Expand All @@ -18,29 +18,58 @@ of AI while maintaining fine-grained control over your applications.
Tasks represent the structured side of ControlFlow. They are specific,
well-defined objectives that form the backbone of your workflow. Tasks
encapsulate the "what" and "how" of your AI-driven operations, providing a
clear, programmatic structure. By defining expected result types and validation
criteria, Tasks ensure that AI outputs align with your application's requirements.
clear, programmatic structure.

To learn more about tasks, see the [Tasks](/concepts/tasks) section.
Key features of Tasks:
- Define specific objectives for AI to accomplish
- Specify expected result types and validation criteria
- Can include instructions, context, and tools for execution
- Serve as checkpoints in your workflow

Learn more in the [Tasks](/concepts/tasks) section.

## 🦾 Agents

Agents embody the unstructured, natural language side of ControlFlow. They are
AI-powered entities capable of understanding and generating human-like text,
bringing flexibility and adaptability to your workflows. Agents can be
specialized for specific tasks, have access to different tools, or even
represent different LLM models, allowing you to optimize your workflow for
various requirements. Assign agents to tasks to determine "who" will execute
your work.
bringing flexibility and adaptability to your workflows.

Key features of Agents:
- Represent configurable AI entities with their own identity and capabilities
- Can be specialized for specific tasks or have access to different tools
- Collaborate to complete tasks according to provided instructions
- Can be interactive, allowing communication with users
- Allow configuration of different LLM models to power their responses

To learn more about agents, see the [Agents](/concepts/agents) section.
Agents can be configured with different LLM models, enabling you to choose the
most suitable model for your needs based on factors such as performance,
latency, and cost.

Learn more in the [Agents](/concepts/agents) section.

## 🧩 Flows

Flows provide a shared context for all tasks and agents within a workflow. They
orchestrate the execution of tasks and the interaction of agents, allowing you
to create complex, adaptive AI workflows. Flows maintain a consistent state and
history across all components, enabling seamless collaboration and information
sharing.
to create complex, adaptive AI workflows.

Key features of Flows:
- Act as high-level containers for entire AI-powered workflows
- Maintain consistent state and history across all components
- Provide shared context for tasks and agents
- Can be nested to create hierarchical workflows

Learn more in the [Flows](/concepts/flows) section.

## Putting it all together

In a typical ControlFlow application:

1. You define a Flow to represent your overall workflow
2. Within the Flow, you create Tasks to represent specific objectives
3. You assign Agents to work on these Tasks
4. The Flow orchestrates the execution of Tasks and the interaction of Agents

To learn more about flows, see the [Flows](/concepts/flows) section.
This structure allows you to create powerful, flexible AI workflows while
maintaining control over the process and ensuring that outputs align with your
application's requirements.
Loading

0 comments on commit 1493135

Please sign in to comment.