import os
import torch
import torch_fidelity
import shutil
import time
from torch.utils.tensorboard import SummaryWriter
import argparse



def evaluate_images(image_folder=''):
    """
    Evaluate FID and IS metrics for a folder of already generated images.

    Args:
        image_folder (str): Path to folder containing generated images.
        img_size (int): Size of the images (256 or other supported sizes).
        log_writer: TensorBoard SummaryWriter for logging (optional).
        epoch (int): Current epoch (for logging purposes).
        use_ema (bool): Whether EMA was used (for logging purposes).
        cfg (float): CFG value used (for logging purposes).

    Returns:
        tuple: (fid, inception_score) metrics
    """
    print("Evaluating images in:", image_folder)
    img_size=256
    # Set up FID statistics file based on image size
    if img_size == 256:
        input2 = None
        fid_statistics_file = 'fid_stats/adm_in256_stats.npz'
    else:
        raise NotImplementedError(f"Image size {img_size} is not supported")

    # Calculate metrics
    metrics_dict = torch_fidelity.calculate_metrics(
        input1=image_folder,
        input2=input2,
        fid_statistics_file=fid_statistics_file,
        cuda=True,
        isc=True,
        fid=True,
        kid=False,
        prc=False,
        verbose=False,
    )

    fid = metrics_dict['frechet_inception_distance']
    inception_score = metrics_dict['inception_score_mean']

    # Print metrics
    print("FID: {:.4f}, Inception Score: {:.4f}".format(fid, inception_score))

    return fid, inception_score

fid, is_score = evaluate_images(
    image_folder="./runtime/mar_large/ariter24-diffsteps100-temp1.0-linearcfg3.0-image50000-20250920_193839_ema_evaluate")