* feat: add approval human-in-the-loop pattern Change-Id: I8217d0b92e5df954adfbae129f945a52d9367a08 * feat: add review-and-edit human-in-the-loop pattern Change-Id: Ifebae102fe01c6b5c1239c56d4bde9b83f89ff45 * feat: add follow-up human-in-the-loop pattern Change-Id: I79323759e03607496b411a7e6bd06a6eac18c986 * feat: change 'review-and-edit' to 'feedback-loop' Change-Id: I6c0a94d97a745dce9badda5b73e895ea440076e4 * feat: re-add the review-and-edit pattern Change-Id: If2058922c3e2428ab896c5f8c59d12de79ae2ae5 * fix(adk): improve review-and-edit tool call wrapper response Change-Id: I22b30575551f3f9d9b10a65ce11bcc2a92199a0b * docs: update command path with actual dir name * chore: update to eino v0.7.0 release Change-Id: Ie61a51f9d6dc0edbc1ddac973966740f2edf466b --------- Co-authored-by: HaotianChen <chenhaotian16@huawei.com> |
6 months ago | |
|---|---|---|
| .. | ||
| README.md | 6 months ago | |
| README_ZH.md | 6 months ago | |
| follow_up_agent.go | 6 months ago | |
| main.go | 6 months ago | |
| trip_planner_agent.go | 6 months ago | |
README.md
Human-in-the-Loop: Follow-up Pattern
This example demonstrates an intelligent "human-in-the-loop" pattern: Follow-up. It showcases a multi-agent workflow where one agent (the itinerary planner) identifies missing information and delegates to another specialized follow-up agent to proactively and iteratively collect necessary information from the user, ultimately completing complex tasks.
How It Works
This implementation uses a nested agent architecture with two specialized agents working together:
-
Itinerary Planning Agent: A specialized agent that generates travel itineraries. When it detects insufficient information in user requests (e.g., knowing the destination but not the interests), it calls the follow-up agent.
-
Follow-up Agent: A specialized agent responsible for information collection. It:
- Uses the
FollowUpToolto interrupt execution and ask the user questions - Analyzes user responses to extract required information
- If information is incomplete, formulates new questions to continue the inquiry
- Returns an information summary when exit conditions are met (complete information, user refusal, maximum attempts reached)
- Uses the
Workflow Sequence
- Initial Request: User makes a vague request (e.g., "Plan a 3-day trip to New York City")
- Information Recognition: Itinerary planning agent identifies missing information and calls the follow-up agent
- Follow-up Interruption: Follow-up agent triggers an interrupt, presenting formatted question lists to the user
- User Response: User provides natural language answers
- Information Extraction & Iteration: Follow-up agent:
- Extracts required information from responses
- If information is incomplete, creates new targeted questions
- Repeats the follow-up process (up to 10 attempts)
- Information Summary: When sufficient information is gathered or exit conditions are met, returns an information summary
- Task Completion: Itinerary planning agent generates personalized itinerary based on collected information
Key Features Demonstrated
- Intelligent Information Recognition: Agents can identify when more information is needed
- Iterative Follow-up: Supports multi-turn conversations, dynamically adjusting questions based on user responses
- Information Extraction: Extracts structured information from natural language responses
- Exit Condition Management: Gracefully handles incomplete information or user refusal
- Nested Agent Collaboration: Demonstrates how agents can delegate specialized tasks
How to Configure Environment Variables
Before running the example, you need to set up the required environment variables for the LLM API. You have two options:
Option 1: OpenAI-Compatible Configuration
export OPENAI_API_KEY="{your api key}"
export OPENAI_BASE_URL="{your model base url}"
# Only configure this if you are using Azure-like LLM providers
export OPENAI_BY_AZURE=true
# 'gpt-4o' is just an example, configure the model name provided by your LLM provider
export OPENAI_MODEL="gpt-4o-2024-05-13"
Option 2: ARK Configuration
export MODEL_TYPE="ark"
export ARK_API_KEY="{your ark api key}"
export ARK_MODEL="{your ark model name}"
Alternatively, you can create a .env file in the project root with these variables.
How to Run
Ensure you have set up your environment variables (e.g., LLM API keys). Then, run the following command from the root of the eino-examples repository:
go run ./adk/human-in-the-loop/4_follow-up
You will see:
- Itinerary planning agent identifying information needs
- Follow-up agent starting the questioning process
- Multi-turn conversation with the agent
- Final personalized itinerary based on your preferences
Workflow Diagram
graph TD
A[User: Vague Request] --> B{Itinerary Planning Agent};
B --> C[Identify Information Gap] --> D{Follow-up Agent};
D --> E[Interrupt: Ask Questions] --> F{User Response};
F --> G[Information Extraction] --> H{Information Complete?};
H -- "No" --> I[Formulate New Questions] --> E;
H -- "Yes" --> J[Information Summary] --> K[Return to Itinerary Agent];
K --> L[Generate Personalized Itinerary] --> M[Workflow Complete];
Practical Example
Here's a real trace from running the example, showing how the follow-up process works:
name: ItineraryAgent
path: [{ItineraryAgent}]
tool name: FollowUpAgent
arguments: {"request":"What are your interests or preferences for this 3-day trip to New York City? For example, do you like museums, theater, shopping, food experiences, outdoor activities, historical sites, or anything else specific?"}
name: ItineraryAgent
path: [{ItineraryAgent}]
We need more information. Please answer the following questions:
1. What are your interests or preferences for the 3-day trip to New York City?
2. Do you prefer museums, theater, shopping, food experiences, outdoor activities, or historical sites?
3. Are there any specific places or activities you want to include in your trip?
Your answer: My main interest are family friendly theme parks. We prefer theaters at night. I don't have any particular places or activities in mind.
name: ItineraryAgent
path: [{ItineraryAgent}]
We need more information. Please answer the following questions:
1. Are you interested in visiting any of the well-known theme parks near New York City, such as Six Flags Great Adventure or Coney Island?
2. What type of theater shows do you prefer at night? (e.g., musicals, Broadway shows, plays, comedy)
3. Do you want recommendations for family-friendly restaurants or dining experiences?
Your answer: I have no prior knowledge or New York City's theme parks, so help me decide. We prefer musicals. Chinese food will suffice.
name: ItineraryAgent
path: [{ItineraryAgent}]
tool response: You are interested in family-friendly theme parks but do not have prior knowledge of the options near New York City. You prefer theatrical musicals for evening shows and are open to Chinese food for dining experiences. You don't have specific places or activities in mind and are seeking help to decide on theme parks to visit.
name: ItineraryAgent
path: [{ItineraryAgent}]
answer: Here's a suggested 3-day itinerary for your family-friendly trip to New York City, including theme parks, theatrical musicals, and Chinese dining experiences:
Day 1:
- Morning: Visit Luna Park at Coney Island, a classic family-friendly amusement park with rides and games.
- Lunch: Enjoy a casual meal at one of the park's eateries.
- Afternoon: Explore the Coney Island Boardwalk and beach area.
- Evening: Dinner at a Chinese restaurant in Manhattan's Chinatown, experiencing authentic flavors.
- Night: Attend a theatrical musical on Broadway, suitable for families.
Day 2:
- Morning: Head to the Bronx Zoo, a large and renowned zoo with interactive exhibits for children.
- Lunch: Picnic or dine at the zoo café.
- Afternoon: Visit the New York Botanical Garden nearby for a relaxing walk.
- Evening: Dinner at another top-rated Chinese restaurant, possibly in Flushing, Queens (known for excellent Chinese cuisine).
- Night: Consider a Broadway or off-Broadway musical that caters to family audiences.
Day 3:
- Morning: Explore the American Museum of Natural History, which is engaging for all ages.
- Lunch: Eat at a family-friendly restaurant on the Upper West Side.
- Afternoon: Walk or bike through Central Park, visit playgrounds, or enjoy a boat ride on the lake.
- Evening: Final dinner at a Chinese restaurant specializing in dim sum or regional specialties.
- Night: Optional second musical or relaxation depending on the family's energy.
If you want me to customize this further with specific shows, restaurants, or travel tips, please let me know!
This trace demonstrates:
- Initial Information Recognition: The itinerary planning agent identifies the need for more user preference information
- Iterative Follow-up: The follow-up agent conducts two rounds of questioning, progressively refining user requirements
- Intelligent Information Extraction: Key information is extracted from user responses (family-friendly theme parks, musicals, Chinese food)
- Personalized Results: A highly personalized itinerary is generated based on collected information
The path notation shows how agents collaborate through tool calls and interrupt mechanisms.
Implementation Details
Agent Architecture
- ItineraryAgent: Itinerary planning agent created using
adk.NewChatModelAgent - FollowUpAgent: Specialized follow-up agent wrapped as a tool using
adk.NewAgentTool - Nested Calls: Itinerary planning agent delegates information collection to the specialized follow-up agent
Tool Integration
- FollowUpTool: Custom tool located in
adk/common/tool/follow_up_tool.go - Formatted Questioning: The tool provides clear, numbered question lists for optimal user experience
- State Management: Uses
StatefulInterruptto maintain follow-up session state
Exit Condition Management
- Maximum Attempts: Limited to 10 follow-up attempts to avoid infinite loops
- User Refusal Handling: Recognizes exit signals like "I don't know" or "I refuse to answer"
- Information Completeness Check: Intelligently determines when sufficient information is available to complete the task
Use Cases
This pattern is suitable for:
- Complex task planning requiring user input
- Information collection and requirements analysis workflows
- Customer service and consultation scenarios
- Any scenario requiring iterative clarification and refinement of user requirements
This implementation demonstrates how to use the Eino framework to build intelligent, adaptive conversational systems that can proactively identify information needs and collect necessary information through multi-turn dialogues.