Spaces:
Paused
Paused
File size: 974 Bytes
343346a |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
import torch
from diffusers import DiffusionPipeline
import time
class SDXLImageGenerator:
def __init__(self):
# Check if cuda is available
self.use_cuda = torch.cuda.is_available()
# Set proper device based on cuda availability
self.device = torch.device("cuda" if self.use_cuda else "cpu")
# Load the pipeline
self.pipe = DiffusionPipeline.from_pretrained(
"stabilityai/stable-diffusion-xl-base-1.0",
torch_dtype=torch.float16,
use_safetensors=True,
variant="fp16"
)
self.pipe.to(self.device)
def generate_images(self, prompts):
images = []
start_time = time.time()
for i, prompt in enumerate(prompts):
gen_image = self.pipe(prompt=prompt).images[0]
images.append(gen_image)
end_time = time.time()
print("Total Time SDXL: %4f seconds" % (end_time - start_time))
return images
|