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
    pipeline = StableDiffusionPipeline.from_pretrained(
        "SPO-Diffusion-Models/SPO-SD-v1-5_4k-p_10ep",
        torch_dtype=inference_dtype,
        safety_checker=None,
        use_auth_token=False,
        resume_download=True
    )
    
    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 path
    input_file = './DPG-Bench.txt'
    save_dir = Path('./Generation/SPO')
    
    # Create save directory
    save_dir.mkdir(parents=True, exist_ok=True)
    
    # Initialize the pipeline
    print("Initializing pipeline...")
    pipeline = setup_pipeline()
    
    # Load prompts
    prompts = load_prompts(input_file)
    print(f"Loaded {len(prompts)} prompts")
    
    # Generate images
    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()