Classifier overview
The Classifier is a crucial component of the Multi-Agent Orchestrator, responsible for analyzing user input and identifying the most appropriate agents. The orchestrator supports multiple classifier implementations, with Bedrock Classifier and Anthropic Classifier being the primary options.
Available Classifiers
-
Bedrock Classifier leverages Amazon Bedrock’s AI models for intent classification. It is the default classifier used by the orchestrator.
-
Anthropic Classifier uses Anthropic’s AI models for intent classification. It provides an alternative option for users who prefer or have access to Anthropic’s services.
-
OpenAI Classifier uses OpenAI’s AI models for intent classification. It provides an alternative option for users who prefer or have access to OpenAI’s services.
Process Flow
Regardless of the classifier used, the general process remains the same:
- User input is collected by the orchestrator.
- The Classifier performs input analysis, considering:
- Conversation history across all agents
- Individual agent profiles and capabilities
- The most suitable agent is determined.
By default, if no agent is selected the orchestrator can be configured to:
A. Use a default agent (a BedrockLLMAgent for example)
B. Return a message prompting the user for more information.
This behavior can be customized using the USE_DEFAULT_AGENT_IF_NONE_IDENTIFIED
and NO_SELECTED_AGENT_MESSAGE
configuration options in the orchestrator.
For a detailed explanation of these options and other orchestrator configurations, please refer to the Orchestrator Overview page.
The classifier’s decision-making process is crucial for the effective routing of user queries to the most appropriate agent, ensuring a seamless and efficient multi-agent interaction experience.
Initialization
When you create a new Orchestrator by initializing a MultiAgentOrchestrator
the default Bedrock Classifier is initialized.
To use the Anthropic Classifier, you can pass it as an option:
Custom Classifier Implementation
You can provide your own custom implementation of the classifier by extending the abstract Classifier
class. For details on how to do this, please refer to the Custom Classifier section.
Testing
You can test any Classifier directly using the classify
method:
This allows you to:
- Verify the Classifier’s decision-making process
- Test different inputs and conversation scenarios
- Fine-tune the system prompt or agent descriptions
Common Issues
- Misclassification: If you notice frequent misclassifications, review and update agent descriptions or adjust the system prompt.
- API Key Issues: For AnthropicClassifier, ensure your API key is valid and properly configured.
- Model Availability: For BedrockClassifier, ensure you have access to the specified Amazon Bedrock model in your AWS account.
Choosing the Right Classifier
When deciding between different classifiers, consider:
- API Access: Which service you have access to and prefer.
- Model Performance: Test classifiers with your specific use case to determine which performs better for your needs.
- Cost: Compare the pricing structures for your expected usage.
By thoroughly testing and debugging your chosen Classifier, you can ensure accurate intent classification and efficient query routing in your Multi-Agent Orchestrator.
Direct Classifier Access
With Context Management
Test the classifier with full conversation history handling:
This method:
- Retrieves conversation history automatically
- Maintains context across test calls
- Ideal for end-to-end testing
Without Context
Test raw classification without conversation history:
Best for:
- Prompt tuning
- Single-input validation
- Classification unit tests
For more detailed information on each classifier, refer to the BedrockClassifier and AnthropicClassifier documentation pages.