Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
chenpangpang
ComfyUI
Commits
06ad35b4
Commit
06ad35b4
authored
May 02, 2023
by
pythongosssss
Browse files
added progress to encode + upscale
parent
c8c9926e
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
16 additions
and
4 deletions
+16
-4
comfy/sd.py
comfy/sd.py
+9
-3
comfy_extras/nodes_upscale_model.py
comfy_extras/nodes_upscale_model.py
+7
-1
No files found.
comfy/sd.py
View file @
06ad35b4
...
...
@@ -491,9 +491,15 @@ class VAE:
model_management
.
unload_model
()
self
.
first_stage_model
=
self
.
first_stage_model
.
to
(
self
.
device
)
pixel_samples
=
pixel_samples
.
movedim
(
-
1
,
1
).
to
(
self
.
device
)
samples
=
utils
.
tiled_scale
(
pixel_samples
,
lambda
a
:
self
.
first_stage_model
.
encode
(
2.
*
a
-
1.
).
sample
()
*
self
.
scale_factor
,
tile_x
,
tile_y
,
overlap
,
upscale_amount
=
(
1
/
8
),
out_channels
=
4
)
samples
+=
utils
.
tiled_scale
(
pixel_samples
,
lambda
a
:
self
.
first_stage_model
.
encode
(
2.
*
a
-
1.
).
sample
()
*
self
.
scale_factor
,
tile_x
*
2
,
tile_y
//
2
,
overlap
,
upscale_amount
=
(
1
/
8
),
out_channels
=
4
)
samples
+=
utils
.
tiled_scale
(
pixel_samples
,
lambda
a
:
self
.
first_stage_model
.
encode
(
2.
*
a
-
1.
).
sample
()
*
self
.
scale_factor
,
tile_x
//
2
,
tile_y
*
2
,
overlap
,
upscale_amount
=
(
1
/
8
),
out_channels
=
4
)
it_1
=
-
(
pixel_samples
.
shape
[
2
]
//
-
(
tile_y
*
2
-
overlap
))
*
-
(
pixel_samples
.
shape
[
3
]
//
-
(
tile_x
//
2
-
overlap
))
it_2
=
-
(
pixel_samples
.
shape
[
2
]
//
-
(
tile_y
//
2
-
overlap
))
*
-
(
pixel_samples
.
shape
[
3
]
//
-
(
tile_x
*
2
-
overlap
))
it_3
=
-
(
pixel_samples
.
shape
[
2
]
//
-
(
tile_y
-
overlap
))
*
-
(
pixel_samples
.
shape
[
3
]
//
-
(
tile_x
-
overlap
))
pbar
=
tqdm
(
total
=
(
it_1
+
it_2
+
it_3
))
samples
=
utils
.
tiled_scale
(
pixel_samples
,
lambda
a
:
self
.
first_stage_model
.
encode
(
2.
*
a
-
1.
).
sample
()
*
self
.
scale_factor
,
tile_x
,
tile_y
,
overlap
,
upscale_amount
=
(
1
/
8
),
out_channels
=
4
,
pbar
=
pbar
)
samples
+=
utils
.
tiled_scale
(
pixel_samples
,
lambda
a
:
self
.
first_stage_model
.
encode
(
2.
*
a
-
1.
).
sample
()
*
self
.
scale_factor
,
tile_x
*
2
,
tile_y
//
2
,
overlap
,
upscale_amount
=
(
1
/
8
),
out_channels
=
4
,
pbar
=
pbar
)
samples
+=
utils
.
tiled_scale
(
pixel_samples
,
lambda
a
:
self
.
first_stage_model
.
encode
(
2.
*
a
-
1.
).
sample
()
*
self
.
scale_factor
,
tile_x
//
2
,
tile_y
*
2
,
overlap
,
upscale_amount
=
(
1
/
8
),
out_channels
=
4
,
pbar
=
pbar
)
samples
/=
3.0
self
.
first_stage_model
=
self
.
first_stage_model
.
cpu
()
samples
=
samples
.
cpu
()
...
...
comfy_extras/nodes_upscale_model.py
View file @
06ad35b4
...
...
@@ -4,6 +4,7 @@ from comfy import model_management
import
torch
import
comfy.utils
import
folder_paths
from
tqdm.auto
import
tqdm
class
UpscaleModelLoader
:
@
classmethod
...
...
@@ -37,7 +38,12 @@ class ImageUpscaleWithModel:
device
=
model_management
.
get_torch_device
()
upscale_model
.
to
(
device
)
in_img
=
image
.
movedim
(
-
1
,
-
3
).
to
(
device
)
s
=
comfy
.
utils
.
tiled_scale
(
in_img
,
lambda
a
:
upscale_model
(
a
),
tile_x
=
128
+
64
,
tile_y
=
128
+
64
,
overlap
=
8
,
upscale_amount
=
upscale_model
.
scale
)
tile
=
128
+
64
overlap
=
8
its
=
-
(
in_img
.
shape
[
2
]
//
-
(
tile
-
overlap
))
*
-
(
in_img
.
shape
[
3
]
//
-
(
tile
-
overlap
))
pbar
=
tqdm
(
total
=
its
)
s
=
comfy
.
utils
.
tiled_scale
(
in_img
,
lambda
a
:
upscale_model
(
a
),
tile_x
=
tile
,
tile_y
=
tile
,
overlap
=
overlap
,
upscale_amount
=
upscale_model
.
scale
,
pbar
=
pbar
)
upscale_model
.
cpu
()
s
=
torch
.
clamp
(
s
.
movedim
(
-
3
,
-
1
),
min
=
0
,
max
=
1.0
)
return
(
s
,)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment