diff options
Diffstat (limited to 'modules/sd_hijack.py')
-rw-r--r-- | modules/sd_hijack.py | 24 |
1 files changed, 13 insertions, 11 deletions
diff --git a/modules/sd_hijack.py b/modules/sd_hijack.py index c6d17764..fba23c38 100644 --- a/modules/sd_hijack.py +++ b/modules/sd_hijack.py @@ -184,17 +184,19 @@ class StableDiffusionModelHijack: errors.display(e, "applying cross attention optimization")
undo_optimizations()
- def conv_ssd(self, m):
- delattr(m.model.diffusion_model.middle_block, '1')
- delattr(m.model.diffusion_model.middle_block, '2')
- for i in ['9','8','7','6','5','4']:
- delattr(m.model.diffusion_model.input_blocks[7][1].transformer_blocks,i)
- delattr(m.model.diffusion_model.input_blocks[8][1].transformer_blocks,i)
- delattr(m.model.diffusion_model.output_blocks[0][1].transformer_blocks,i)
- delattr(m.model.diffusion_model.output_blocks[1][1].transformer_blocks,i)
- delattr(m.model.diffusion_model.output_blocks[4][1].transformer_blocks,'1')
- delattr(m.model.diffusion_model.output_blocks[5][1].transformer_blocks,'1')
- devices.torch_gc()
+ def convert_sdxl_to_ssd(self, m):
+ """Converts an SDXL model to a Segmind Stable Diffusion model (see https://huggingface.co/segmind/SSD-1B)"""
+
+ delattr(m.model.diffusion_model.middle_block, '1')
+ delattr(m.model.diffusion_model.middle_block, '2')
+ for i in ['9', '8', '7', '6', '5', '4']:
+ delattr(m.model.diffusion_model.input_blocks[7][1].transformer_blocks, i)
+ delattr(m.model.diffusion_model.input_blocks[8][1].transformer_blocks, i)
+ delattr(m.model.diffusion_model.output_blocks[0][1].transformer_blocks, i)
+ delattr(m.model.diffusion_model.output_blocks[1][1].transformer_blocks, i)
+ delattr(m.model.diffusion_model.output_blocks[4][1].transformer_blocks, '1')
+ delattr(m.model.diffusion_model.output_blocks[5][1].transformer_blocks, '1')
+ devices.torch_gc()
def hijack(self, m):
conditioner = getattr(m, 'conditioner', None)
|