from script_utils import ScriptUtils

ScriptUtils.setup_script()

from experiments import ExperimentLoader, ResultsCollector
from utils import logger_utils

from tqdm import tqdm

from datetime import datetime

args = ScriptUtils.get_args()
config = ScriptUtils.get_debate_round_script_config(args)
start_time = str(datetime.now()).replace(" ", "_") if not args.start_time else args.start_time
logger = logger_utils.get_default_logger(__name__)
should_save_transcripts = not args.local or args.force_save_transcripts
should_save_results = (not args.local) or args.force_save_results

print(config)

debate_rounds, experiment = ExperimentLoader.generate_debate_rounds(
    experiment_file_path=config.experiment_file_path, name=config.experiment_name, count=args.num_iters, starting_index=args.starting_index
)

results_collector = ResultsCollector(
    experiment=experiment,
    graphs_path_prefix=f"{config.graphs_path_prefix}/{start_time}_",
    full_record_path_prefix=f"{config.full_record_path_prefix}/{start_time}_",
    stats_path_prefix=f"{config.stats_path_prefix}/{start_time}",
    should_save=should_save_results,
)

for i, debate_round in enumerate(debate_rounds):
    logger.info(f"Beginning round {i} out of {len(debate_rounds)}")
    save_file_path_prefix = f"{config.transcript_path_prefix}/{start_time}_{i}" if should_save_transcripts else None
    print(save_file_path_prefix)
    summary = debate_round(save_file_path_prefix=save_file_path_prefix)
    results_collector.record_result(summary)

if not args.suppress_graphs:
    results_collector.graph_results()
