Register
Login
Resources
Docs Blog Datasets Glossary Case Studies Tutorials & Webinars
Product
Data Engine LLMs Platform Enterprise
Pricing Explore
Connect to our Discord channel

app.py 2.9 KB

You have to be logged in to leave a comment. Sign In
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
  1. import gradio as gr
  2. import torch
  3. import numpy as np
  4. import modin.pandas as pd
  5. from PIL import Image
  6. from diffusers import DiffusionPipeline, StableDiffusion3Pipeline
  7. from huggingface_hub import hf_hub_download
  8. device = 'cuda' if torch.cuda.is_available() else 'cpu'
  9. torch.cuda.max_memory_allocated(device=device)
  10. torch.cuda.empty_cache()
  11. #torch.cuda.max_memory_allocated(device=device)
  12. pipe = DiffusionPipeline.from_pretrained("circulus/canvers-fusionXL-v1", torch_dtype=torch.bfloat16).to(device)
  13. pipe.enable_xformers_memory_efficient_attention()
  14. # Open it for reduce GPU memory usage
  15. #pipe.enable_model_cpu_offload()
  16. pipe.vae.enable_slicing()
  17. pipe.vae.enable_tiling()
  18. torch.cuda.empty_cache()
  19. #torch.cuda.max_memory_allocated(device=device)
  20. refiner = DiffusionPipeline.from_pretrained("stabilityai/stable-diffusion-xl-refiner-1.0", use_safetensors=True, torch_dtype=torch.bfloat16, variant="fp16").to(device)
  21. refiner.enable_xformers_memory_efficient_attention()
  22. torch.cuda.empty_cache()
  23. def genie (Prompt, negative_prompt, height, width, scale, steps, seed, progress=gr.Progress(track_tqdm=True)):
  24. generator = np.random.seed(0) if seed == 0 else torch.manual_seed(seed)
  25. #generator=np.random.seed(0)
  26. int_image = pipe(Prompt, negative_prompt=negative_prompt, height=height, width=width, num_inference_steps=steps, guidance_scale=scale, output_type="latent").images
  27. image = refiner(Prompt, negative_prompt=negative_prompt, image=int_image, denoising_start=.99).images[0]
  28. torch.cuda.empty_cache()
  29. return image
  30. gr.Interface(fn=genie, inputs=[gr.Textbox(label='What you want the AI to generate. 77 Token Limit.'),
  31. gr.Textbox(label='What you Do Not want the AI to generate. 77 Token Limit'),
  32. gr.Slider(512, 1280, 1024, step=128, label='Height'),
  33. gr.Slider(512, 1280, 1024, step=128, label='Width'),
  34. gr.Slider(.5, maximum=15, value=9, step=.25, label='Guidance Scale'),
  35. gr.Slider(10, maximum=50, value=25, step=5, label='Number of Prior Iterations'),
  36. gr.Slider(minimum=0, step=1, maximum=9999999999999999, randomize=True, label='Seed: 0 is Random')],
  37. outputs=gr.Image(label='Generated Image'),
  38. title="Manju Dream Booth V2.5 with Fusion XL - GPU",
  39. description="<br><br><b/>Warning: This Demo is capable of producing NSFW content.",
  40. article = "If You Enjoyed this Demo and would like to Donate, you can send any amount to any of these Wallets. <br><br>SHIB (BEP20): 0xbE8f2f3B71DFEB84E5F7E3aae1909d60658aB891 <br>PayPal: https://www.paypal.me/ManjushriBodhisattva <br>ETH: 0xbE8f2f3B71DFEB84E5F7E3aae1909d60658aB891 <br>DOGE: D9QdVPtcU1EFH8jDC8jhU9uBcSTqUiA8h6<br><br>Code Monkey: <a href=\"https://huggingface.co/Manjushri\">Manjushri</a>").launch(debug=True)
Tip!

Press p or to see the previous file or, n or to see the next file

Comments

Loading...