nodes: ImagePadForOutpaint: fix feathering, ignore edges not expanded

This commit is contained in:
Guo Y.K 2023-03-25 16:27:47 +08:00
parent 4580f3e644
commit 4c01386c19
No known key found for this signature in database
GPG Key ID: 315A5D46A979A359

View File

@ -1,3 +1,5 @@
import math
import torch import torch
import os import os
@ -942,28 +944,31 @@ class ImagePadForOutpaint:
dtype=torch.float32, dtype=torch.float32,
) )
if feathering > 0 and feathering * 2 < d2 and feathering * 2 < d3: t = torch.zeros(
# distances to border (d2, d3),
mi, mj = torch.meshgrid( dtype=torch.float32
torch.arange(d2, dtype=torch.float32), )
torch.arange(d3, dtype=torch.float32),
indexing='ij',
)
distances = torch.minimum(
torch.minimum(mi, mj),
torch.minimum(d2 - 1 - mi, d3 - 1 - mj),
)
# convert distances to square falloff from 1 to 0
t = (feathering - distances) / feathering
t.clamp_(min=0)
t.square_()
mask[top:top + d2, left:left + d3] = t if feathering > 0 and feathering * 2 < d2 and feathering * 2 < d3:
else:
mask[top:top + d2, left:left + d3] = torch.zeros( for i in range(d2):
(d2, d3), for j in range(d3):
dtype=torch.float32, dt = i if top != 0 else d2
) db = d2 - i if bottom != 0 else d2
dl = j if left != 0 else d3
dr = d3 - j if right != 0 else d3
d = min(dt, db, dl, dr)
if d >= feathering:
continue
v = (feathering - d) / feathering
t[i, j] = v * v
mask[top:top + d2, left:left + d3] = t
return (new_image, mask) return (new_image, mask)