"""
Agent Block Library - Concise Blocks for multi-agent systems
Using only three roles: Planner, Actor, and Verifier
"""

# Dictionary of agent Blocks with brief descriptions
AGENT_BLOCKS = {
    # Basic Blocks
    "basic": "Actor (directly give answer)",

    "sequential": "Actor -> Verifier -> ... -> Actor (Actor processes task, Verifier validates result)",
    
    "feedback_loop": "Block <-> Verifier -> Actor (Verifier provides feedback for Block to improve)",
    
    "ensemble": "Actor1 + Actor2 + Actor3 -> Actor4 (Multiple Actors with different approaches, results combined)",
    
    # Advanced Blocks
#    "divide_conquer": "Planner (divides task) -> Block (Planner dynamically breaks down task, Actors solve parts)",
    
    "expert_panel": "Actor (expert1) + Actor (expert2) + Actor (expert3) -> Verifier -> Actor (Different domain experts collaborate)",
    
    "self_critique": "Actor (solution) -> Verifier (critique) -> Actor (improved) (Same Actor in different roles)",
    
#    "hierarchical": "Planner (high-level) -> Planner (detailed) -> Multiple Actors (Planning at multiple levels)",
    
    "debate": "Actor (position A) <-> Actor (position B) -> Verifier (judge) (Actors debate different approaches)",
    
    "chain_of_thought": "Actor (reasoning) -> Actor (solution)",

}

# Example implementations of Blocks
PATTERN_EXAMPLES = {
}

def get_pattern_description(pattern_name):
    """Get the description of a pattern by name"""
    return AGENT_BLOCKS.get(pattern_name, "Pattern not found")

def get_pattern_example(pattern_name):
    """Get an example implementation of a pattern by name"""
    return PATTERN_EXAMPLES.get(pattern_name, "Example not available")

def list_Blocks():
    """List all available Blocks"""
    return list(AGENT_BLOCKS.keys())
