import os
import torch
import numpy as np
from pathlib import Path
from PIL import Image
from statistics import mean
from utils.hps_utils import Selector

def load_prompts(file_path):
    """Load prompts from text file"""
    with open(file_path, 'r', encoding='utf-8') as f:
        return [line.strip() for line in f]

def calculate_scores(prompts, image_dir, selector):
    """Calculate scores"""
    scores = []
    for idx, prompt in enumerate(prompts):
        image_path = os.path.join(image_dir, f"img{idx}.jpg")
        try:
            score = selector.score(image_path, prompt)[0]
            scores.append(score)
            print(f"Score for image {idx}: {score}")
        except Exception as e:
            print(f"Error processing image {idx}: {e}")
    return scores

def print_statistics(scores):
    """Print statistical analysis of scores"""
    separator = '*' * 50
    mean_score = mean(scores)
    std_score = np.std(scores, ddof=1)
    
    print(f"Complete score list: {scores}")
    print(f"Mean score: {mean_score:.4f}")
    print(f"Standard deviation: {std_score:.4f}")
    print(f"\n{separator}Results Summary{separator}")
    print(f"Mean score: {mean_score:.4f}")
    print(f"Standard deviation: {std_score:.4f}")

def main():
    torch.set_grad_enabled(False)
    
    # Setup the path
    base_dir = Path("./evaluating")
    prompt_file = base_dir / "image_generation/T2I-Com/T2I-Com/texture.txt"
    image_dir = base_dir / "image_generation/T2I-Com/Generation/RainbowPA/texture"
    
    # Load prompts
    prompts = load_prompts(prompt_file)
    print(f"Loaded {len(prompts)} prompts")
    
    # Initialization
    selector = Selector('cuda:0')
    
    # Calculate scores
    scores = calculate_scores(prompts, image_dir, selector)
    
    # Print statistics
    print_statistics(scores)

if __name__ == "__main__":
    main()