from evo_optimizer import EvoOptimizer
from FlowGen import FlowGen
from evo_optimizer import FlowGenome
from typing import Dict, Any, List
import json
import os
from tools.base import Configuration, Server
import asyncio
from dotenv import load_dotenv
from tools.unified_tool import UnifiedTool, ToolRegistry

def calculator(operation: str, a: float, b: float) -> float:
    """Perform basic arithmetic operations.
    
    :param operation: The operation to perform (add, subtract, multiply, divide)
    :param a: First number
    :param b: Second number
    :return: Result of the operation
    """
    if operation == "add":
        return a + b
    elif operation == "subtract":
        return a - b
    elif operation == "multiply":
        return a * b
    elif operation == "divide":
        return a / b
    else:
        raise ValueError(f"Unknown operation: {operation}")

def text_analyzer(text: str) -> Dict[str, int]:
    """Analyze text and return statistics.
    
    :param text: The text to analyze
    :return: Dictionary with word count, character count, and unique word count
    """
    words = text.split()
    return {
        "word_count": len(words),
        "char_count": len(text),
        "unique_words": len(set(words))
    }

# Create a tool registry to manage all tools
tool_registry = ToolRegistry()

# mcp tools
async def main():
    
    load_dotenv(override=True)
    # Register function-based tools
    tool_registry.register_function(calculator)
    # tool_registry.register_function(text_analyzer)
    
    # Load and initialize MCP servers
    config = Configuration()
    server_config = config.load_config("mcp_servers/test_servers_config.json")

    servers = [
        Server(name, srv_config)
        for name, srv_config in server_config["mcpServers"].items()
    ]

    for server in servers:
        await server.initialize()

    # Register MCP server tools
    for server in servers:
        await tool_registry.register_server_tools(server)

    # Print all tool descriptions
    # tools_description = tool_registry.get_tool_descriptions()
    # print(tools_description)
    
    # population = FlowGen("You need to solve middle school math problems.", tools=tools_description).generation()

    # with open("flow.json", "w", encoding="utf-8") as f3:
    #     json.dump(population, f3, ensure_ascii=False, indent=4)

    # with open("flow_genome_tmp.py", "w", encoding="utf-8") as f2:
    #     f2.write(population["code"])
    
    from agent.Agent_async import Actor
    actor = Actor(tool_registry.get_all_tools())
    result = await actor.react("999+1111*20=?")
    print(result)

    # Create a MultiAgentSystem with unified tools
    # from flow import MultiAgentSystem
    # system = MultiAgentSystem("Test", tool_registry.get_all_tools())
    # result = await system.run("999+1111=?")
    # print(result)

    for server in servers:
        await server.cleanup()
        
if __name__ == "__main__":

    # normal func
    # calculator = {
    #         "name": tool.name,
    #         "description": tool.description,
    #         "input_schema": tool.inputSchema
    # }
    #...
    # tools = {
    #     "calculator": calculator,
    #     "text_analyzer": text_analyzer
    # }
    # tools = None

    # mcp test
    asyncio.run(main())
    
    # -----------------------------------------------------flow生成测试-----------------------------------------------------
    # population = FlowGen("你要解决简单的中学数学问题", tools=None).generation()

    # print(population["plan"])

    # with open("flow.json", "w", encoding="utf-8") as f3:
    #     json.dump(population, f3, ensure_ascii=False, indent=4)

    # with open("flow_genome_tmp.py", "w", encoding="utf-8") as f2:
    #     f2.write(population["code"])
    # from flow_genome_tmp import MultiAgentSystem
    # system = MultiAgentSystem("Test", tools)
    # result = system.run("2025年有多少天")
    # print(result["answer"])

    # -----------------------------------------------------进化算法策略测试-----------------------------------------------------
    # with open("flow.json", "r", encoding="utf-8") as f1:
    #     population = json.load(f1)
    
    # flowevo = FlowGenome("You need to solve simple middle school math problems.", tools=tools)

    # ----------进化算法策略1,3测试----------
    # pops = [population]

    # for i in range(5):
    #     new_population = flowevo.evolve(strategy_type="1", parents=pops, llm="gpt-4o-mini")
    #     pops.append(new_population)

    #     with open("flow_genome_tmp.py", "w", encoding="utf-8") as f2:
    #         f2.write(new_population["code"])

    #     print(new_population["plan"])
        

    #     from flow_genome_tmp import MultiAgentSystem
    #     system = MultiAgentSystem("Test", tools)
    #     result = system.run("2025年有多少天")
    #     print(result["answer"])

    # ----------进化算法策略2,4,5测试----------
    # for i in range(5):
    #     new_population = flowevo.evolve(strategy_type="4", parents=population, llm="gpt-4o-mini")
    #     with open("flow_genome_tmp.py", "w", encoding="utf-8") as f2:
    #         f2.write(new_population["code"])
    #     print(new_population["plan"])
    #     from flow_genome_tmp import MultiAgentSystem
    #     system = MultiAgentSystem("Test", tools)
    #     result = system.run("2025年有多少天")
    #     print(result["answer"])
    #     population = new_population
    
    # -----------------------------------------------------进化算法测试-----------------------------------------------------

    # population = None

    # with open("ini_flow.json", "r") as f:  
    #     population = json.load(f)      

    # optimizer = EvoOptimizer("你要解决比较复杂的中学数学问题",  tools=None, population_size=2, initial_population=population, llm="gpt-4o-mini")
    # best_individual = optimizer.evolve(generations=1, benchmark_type="gsm-8k")
    # optimizer.evaluate(best_individual,mode="test")