import time
import logger
from llm import LLM
from prompt.start import START_SYSTEM_PROMPT
from agent.datascience import DSagent
import utils
import globals




def mainwithtool(requirement: str):
    logger.debug(
        f"【API 配置】: {utils.active_api_config},",
    )
    logger.info(f"【用户需求】{requirement}")
    llm = LLM(config_name=utils.active_api_config)
    messages = [
        {"role": "system", "content": START_SYSTEM_PROMPT},
        {"role": "user", "content": requirement},
    ]
    # 允许模型调用 run_datascience 以及之前的工具
    tool_names = ["run_datascience"]
    if getattr(utils.module_config, 'web_datadownload_tool', False):
        tool_names.insert(0, "web_search_summarize")
    response = llm.ask_with_tools(
        messages=messages,
        tool_names=tool_names,
        max_loops=4,
    )
    logger.success("【最终回答】" + (response.choices[0].message.content or ""))

def main(requirement):
    logger.debug(
        f"【API 配置】: {utils.api_config.config_name},",
    )
    ds=DSagent()
    ds.act(requirement=requirement)
    

if __name__ == "__main__":
    logger.init()
    start_time = time.time()
    logger.info(
        "------------------------------【程序开始】------------------------------"
    )
    requirement = '在sklearn Iris数据集上做数据分析，绘图并训练简单模型'
    # requirement = '对泰坦尼克号乘客数据进行分析，找出影响生存率的关键因素，并训练一个预测模型'
    # requirement = 'workspace\\PVODdatasets_v1.0目录下是一个发电站数据集，包含多个站点的信息，帮我训练一个预测发电量的模型'
    #从workspace/requirement.md读取需求
    # with open('workspace/requirement.md', 'r', encoding='utf-8') as f:
    #     requirement = f.read().strip()
    # requirement+="\n训练数据集和测试数据集分别位于 data/train.csv 和 data/test.csv 。最终输出预测结果到 output/predictions.csv。"
    main(requirement)
    end_time = time.time()
    elapsed_time_minutes = (end_time - start_time) / 60
    logger.debug(f"【程序运行时间】 {elapsed_time_minutes:.2f} 分钟")
    # 打印 LLM Token 累计消耗
    logger.log_token_summary()
    logger.info(
        "------------------------------【程序结束】------------------------------"
    )
