import os
import torch
from pathlib import Path
from diffusers import StableDiffusionPipeline
from tqdm import tqdm

def setup_pipeline():
    """Set up and initialize Stable Diffusion pipeline"""
    # Configure CUDA device
    os.environ["CUDA_VISIBLE_DEVICES"] = "0"
    device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
    
    # Load the model
    inference_dtype = torch.float16
    huggingface_cache_dir = os.environ.get('HUGGING_FACE_CACHE_DIR', None)
    
    pipeline = StableDiffusionPipeline.from_pretrained(
        'runwayml/stable-diffusion-v1-5',
        torch_dtype=inference_dtype,
        cache_dir=huggingface_cache_dir,
        safety_checker=None
    )
    
    return pipeline.to(device)

def generate_image(prompt, pipeline, seed=42):
    """Generate a single image"""
    generator = torch.Generator(device='cuda:0').manual_seed(seed)
    image = pipeline(
        prompt=prompt,
        generator=generator,
        guidance_scale=7.5,
        num_inference_steps=50
    ).images[0]
    return image

def load_prompts(file_path):
    """Load prompts from file"""
    with open(file_path, 'r', encoding='utf-8') as f:
        return [line.strip() for line in f if line.strip()]

def main():
    # Set the paths
    input_file = './GenEval.txt'
    save_dir = Path('./Generation/SD-1-5')
    
    # Create save directory
    save_dir.mkdir(parents=True, exist_ok=True)
    
    # Initialize the pipeline
    pipeline = setup_pipeline()
    
    prompts = load_prompts(input_file)
    print(f"Loaded {len(prompts)} prompts")
    
    # Generation
    for idx, prompt in enumerate(tqdm(prompts, desc="Generating images")):
        image_path = save_dir / f"img{idx}.jpg"
        try:
            image = generate_image(prompt, pipeline)
            image.save(image_path)
        except Exception as e:
            print(f"Error generating image {idx}: {e}")

if __name__ == "__main__":
    main()