from core.attribution_transfer import AttributionTransfer
from core.criteria import RatingCriteria, process_model_tasks
import sys
import os
import datetime

# Centralized configuration
CONFIG = {
    "mode": "rating",  # One of ["reframe", "rating", "both"]
    "input_path": "0_origin_dataset",
    "output_path": "1_reframed_results",
    "log_dir": "logs",
    "model_reframe": ["qwen3:32b"],
    "domain_reframe": ["GAS2SPAS", "IAS2EAS", "SAS2UAS"],
    "file_numbers": [3, 4, 5, 6, 7, 8, 9, 10],
    "num_samples": 3,
    "temperature": 1.0,
    "critic_model": "llama3.3:70b",
    "model_rating": ["qwen3:32b"],
    "domain_rating": ["SAS2UAS"],  # Example: "GAS2SPAS", "IAS2EAS"
    "gpt": False
}

class Tee:
    """Redirect stdout/stderr to both terminal and file"""
    def __init__(self, *files):
        self.files = files

    def write(self, obj):
        for f in self.files:
            f.write(obj)
            f.flush()

    def flush(self):
        for f in self.files:
            f.flush()

def redirect_log(log_dir):
    """Redirect log output to a timestamped file"""
    now = datetime.datetime.now().strftime("%Y%m%d_%H%M%S")
    os.makedirs(log_dir, exist_ok=True)
    log_file = os.path.join(log_dir, f"log_{now}.txt")
    log_f = open(log_file, "w", encoding="utf-8")
    sys.stdout = Tee(sys.__stdout__, log_f)
    sys.stderr = Tee(sys.__stderr__, log_f)
    return log_f

def run_reframe(cfg):
    """Run attributional style reframing on specified domains"""
    for model in cfg["model_reframe"]:
        for domain in cfg["domain_reframe"]:
            print(f"Running reframing: {model} - {domain}")
            transfer = AttributionTransfer(model, domain, cfg["num_samples"], cfg["temperature"])
            transfer.process_all_files(cfg["input_path"], cfg["output_path"], cfg["file_numbers"])
            print(f"Reframing complete: {model} - {domain}")
    print("\nAll reframing tasks completed.")

def run_rating(cfg):
    """Run rating evaluation based on attributional criteria"""
    rating_criteria = RatingCriteria(model_name=cfg["critic_model"], gpt=cfg["gpt"])
    for model in cfg["model_rating"]:
        process_model_tasks(
            rating_criteria,
            model,
            cfg["domain_rating"],
            cfg["file_numbers"]
        )
    print(f"Rating completed for model: {cfg['critic_model']}")

def main():
    log_f = redirect_log(CONFIG["log_dir"])
    start_time = datetime.datetime.now()
    print(f"Start time: {start_time.strftime('%Y-%m-%d %H:%M:%S')}")

    mode = CONFIG["mode"]
    assert mode in ["reframe", "rating", "both"], "Invalid mode: choose from 'reframe', 'rating', or 'both'."

    if mode in ["reframe", "both"]:
        run_reframe(CONFIG)
    if mode in ["rating", "both"]:
        run_rating(CONFIG)

    end_time = datetime.datetime.now()
    print(f"End time: {end_time.strftime('%Y-%m-%d %H:%M:%S')}")
    duration = (end_time - start_time).total_seconds()
    print(f"Total runtime: {duration:.2f} seconds ({duration/3600:.2f} hours)")
    log_f.close()

if __name__ == "__main__":
    main()
