test_outpainting.py 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. import os
  2. from sorawm.iopaint.tests.utils import check_device, current_dir
  3. os.environ["PYTORCH_ENABLE_MPS_FALLBACK"] = "1"
  4. import pytest
  5. import torch
  6. from sorawm.iopaint.model_manager import ModelManager
  7. from sorawm.iopaint.schema import SDSampler
  8. from sorawm.iopaint.tests.test_model import assert_equal, get_config
  9. @pytest.mark.parametrize("name", ["runwayml/stable-diffusion-inpainting"])
  10. @pytest.mark.parametrize("device", ["cuda", "mps"])
  11. @pytest.mark.parametrize(
  12. "rect",
  13. [
  14. [0, -100, 512, 512 - 128 + 100],
  15. [0, 128, 512, 512 - 128 + 100],
  16. [128, 0, 512 - 128 + 100, 512],
  17. [-100, 0, 512 - 128 + 100, 512],
  18. [0, 0, 512, 512 + 200],
  19. [256, 0, 512 + 200, 512],
  20. [-100, -100, 512 + 200, 512 + 200],
  21. ],
  22. )
  23. def test_outpainting(name, device, rect):
  24. sd_steps = check_device(device)
  25. model = ModelManager(
  26. name=name,
  27. device=torch.device(device),
  28. disable_nsfw=True,
  29. sd_cpu_textencoder=False,
  30. )
  31. cfg = get_config(
  32. prompt="a dog sitting on a bench in the park",
  33. sd_steps=sd_steps,
  34. use_extender=True,
  35. extender_x=rect[0],
  36. extender_y=rect[1],
  37. extender_width=rect[2],
  38. extender_height=rect[3],
  39. sd_guidance_scale=8.0,
  40. sd_sampler=SDSampler.dpm_plus_plus_2m,
  41. )
  42. assert_equal(
  43. model,
  44. cfg,
  45. f"{name.replace('/', '--')}_outpainting_{'_'.join(map(str, rect))}_device_{device}.png",
  46. img_p=current_dir / "overture-creations-5sI6fQgYIuo.png",
  47. mask_p=current_dir / "overture-creations-5sI6fQgYIuo_mask.png",
  48. )
  49. @pytest.mark.parametrize("name", ["kandinsky-community/kandinsky-2-2-decoder-inpaint"])
  50. @pytest.mark.parametrize("device", ["cuda", "mps"])
  51. @pytest.mark.parametrize(
  52. "rect",
  53. [
  54. [-128, -128, 768, 768],
  55. ],
  56. )
  57. def test_kandinsky_outpainting(name, device, rect):
  58. sd_steps = check_device(device)
  59. model = ModelManager(
  60. name=name,
  61. device=torch.device(device),
  62. disable_nsfw=True,
  63. sd_cpu_textencoder=False,
  64. )
  65. cfg = get_config(
  66. prompt="a cat",
  67. negative_prompt="lowres, text, error, cropped, worst quality, low quality, jpeg artifacts, ugly, duplicate, morbid, mutilated, out of frame, extra fingers, mutated hands, poorly drawn hands, poorly drawn face, mutation, deformed, blurry, dehydrated, bad anatomy, bad proportions, extra limbs, cloned face, disfigured, gross proportions, malformed limbs, missing arms, missing legs, extra arms, extra legs, fused fingers, too many fingers, long neck, username, watermark, signature",
  68. sd_steps=sd_steps,
  69. use_extender=True,
  70. extender_x=rect[0],
  71. extender_y=rect[1],
  72. extender_width=rect[2],
  73. extender_height=rect[3],
  74. sd_guidance_scale=7,
  75. sd_sampler=SDSampler.dpm_plus_plus_2m,
  76. )
  77. assert_equal(
  78. model,
  79. cfg,
  80. f"{name.replace('/', '--')}_outpainting_{'_'.join(map(str, rect))}_device_{device}.png",
  81. img_p=current_dir / "cat.png",
  82. mask_p=current_dir / "overture-creations-5sI6fQgYIuo_mask.png",
  83. fx=1,
  84. fy=1,
  85. )
  86. @pytest.mark.parametrize("name", ["Sanster/PowerPaint-V1-stable-diffusion-inpainting"])
  87. @pytest.mark.parametrize("device", ["cuda", "mps"])
  88. @pytest.mark.parametrize(
  89. "rect",
  90. [
  91. [-100, -100, 512 + 200, 512 + 200],
  92. ],
  93. )
  94. def test_powerpaint_outpainting(name, device, rect):
  95. sd_steps = check_device(device)
  96. model = ModelManager(
  97. name=name,
  98. device=torch.device(device),
  99. disable_nsfw=True,
  100. sd_cpu_textencoder=False,
  101. low_mem=True,
  102. )
  103. cfg = get_config(
  104. prompt="a dog sitting on a bench in the park",
  105. sd_steps=sd_steps,
  106. use_extender=True,
  107. extender_x=rect[0],
  108. extender_y=rect[1],
  109. extender_width=rect[2],
  110. extender_height=rect[3],
  111. sd_guidance_scale=8.0,
  112. sd_sampler=SDSampler.dpm_plus_plus_2m,
  113. powerpaint_task="outpainting",
  114. )
  115. assert_equal(
  116. model,
  117. cfg,
  118. f"{name.replace('/', '--')}_outpainting_{'_'.join(map(str, rect))}_device_{device}.png",
  119. img_p=current_dir / "overture-creations-5sI6fQgYIuo.png",
  120. mask_p=current_dir / "overture-creations-5sI6fQgYIuo_mask.png",
  121. )