import sys
import os
import time
from learn import effect_estimate
from eval import evaluation
import json
import traceback


# 从环境变量读取，默认值保留原来的路径
MODELS_JSON = os.environ.get('MODELS_JSON', './examples/model.json')

def run():
    if not os.path.exists(MODELS_JSON):
        raise FileNotFoundError(f"MODELS_JSON file not found: {MODELS_JSON}")
    # 修正：把打开的文件对象传给 json.load
    with open(MODELS_JSON, 'r', encoding='utf-8') as f:
        model_args_list = json.load(f)

    for model_args in model_args_list:
        try:
            effect_estimate(model_args)
        except Exception as e:
            print(f"effect_estimate failed for model {model_args.get('name', model_args)}: {e}")
            print("--- Full Traceback ---")
            print(traceback.format_exc())
       	try:
            evaluation(model_args)
        except Exception as e:
            print(f"evaluation failed for model {model_args.get('name', model_args)}: {e}")
            print("--- Full Traceback ---")
            print(traceback.format_exc())

if __name__ == "__main__":
    run()
