stable-diffusion-webui
stable-diffusion-webui copied to clipboard
Add support for merging inpainting models
data:image/s3,"s3://crabby-images/47f96/47f96e8f21e408b05847e2ac3aa18e1355fbc412" alt="image"
Curious as to the final output of this. Will it be a unet with the same inputs as the model you are merging with? So that embedding and so on work with it as if it is one of the "standard" models? Or will it have the extra inputs of the inpainting model?
It will have the extra inputs of the inpainting model as before the merge, since those are needed for inpainting. Other inputs are merged based on the multiplier.
OK thanks @ntrpnr :)
I tested it out and the merger works. Also the new inpainting model produced seems to make good results as per my limited testing so far.
Should this not be possible to do without checkbos and without the big if/else block? Just checking the sizes of certain layer dicts to determine if you have an inpainting model or not.
@AUTOMATIC1111 Yes it is possible without checkbox. The reason for doing it this way:
- The user will be aware that it’s now possible to merge inpainting models.
- This approach leaves the current merge logic untouched and will change fewer lines of code.
One thing you can do to avoid adding another if-else layer is to just pad any weights that are not the 9-input weights before hand. Then you can re-use the assignment code without modification.
FIRST_WEIGHT = "model.diffusion_model.input_blocks.0.0.weight"
if theta_0[FIRST_WEIGHT].shape[1] == 4:
theta_0[FIRST_WEIGHT] = torch.nn.functional.pad(theta_0[FIRST_WEIGHT], (0, 0, 0, 0, 0, 5))
@random-thoughtss Thanks, but I’m not sure this improves readability. At least not to me as a Python novice.
But it might be a cleaner approach.
I had try it and sucessful merger my model with inpainting models.But it failed when I loaded it.
Traceback (most recent call last):
File "K:\SDUI3\venv\lib\site-packages\gradio\routes.py", line 283, in run_predict
output = await app.blocks.process_api(
File "K:\SDUI3\venv\lib\site-packages\gradio\blocks.py", line 936, in process_api
result = await self.call_function(fn_index, inputs, iterator)
File "K:\SDUI3\venv\lib\site-packages\gradio\blocks.py", line 777, in call_function
prediction = await anyio.to_thread.run_sync(
File "K:\SDUI3\venv\lib\site-packages\anyio\to_thread.py", line 31, in run_sync
return await get_asynclib().run_sync_in_worker_thread(
File "K:\SDUI3\venv\lib\site-packages\anyio_backends_asyncio.py", line 937, in run_sync_in_worker_thread
return await future
File "K:\SDUI3\venv\lib\site-packages\anyio_backends_asyncio.py", line 867, in run
result = context.run(func, *args)
File "K:\SDUI3\modules\ui.py", line 1633, in
@snsd21116890 Did you name it [...]inpainting.ckpt?
@snsd21116890 Did you name it [...]inpainting.ckpt?
It works now,thank you.It seems that the merger only enable in Weighted sum method.I had a error when I use Add difference method.Is possible the merger with inpainting model in Add difference method?
Any word on this merge? Seems like a very high value feature.
Currently, I don't have the time to continue working on this. If anyone else wants to go for it, please go ahead.
Thank you Automatic!