1
0
Fork 0
onnx-web/api/onnx_web/chain/upscale.py

129 lines
4.3 KiB
Python
Raw Normal View History

2023-01-28 23:09:19 +00:00
from logging import getLogger
from typing import List, Optional, Tuple
2023-04-01 16:26:10 +00:00
from ..params import ImageParams, SizeChart, StageParams, UpscaleParams
from . import ChainPipeline, PipelineStage
from .correct_codeformer import CorrectCodeformerStage
from .correct_gfpgan import CorrectGFPGANStage
from .upscale_bsrgan import UpscaleBSRGANStage
from .upscale_resrgan import UpscaleRealESRGANStage
from .upscale_stable_diffusion import UpscaleStableDiffusionStage
from .upscale_swinir import UpscaleSwinIRStage
2023-01-16 21:11:40 +00:00
2023-01-28 23:09:19 +00:00
logger = getLogger(__name__)
def split_upscale(
upscale: UpscaleParams,
) -> Tuple[Optional[UpscaleParams], UpscaleParams]:
if upscale.faces and (
upscale.upscale_order == "correction-both"
or upscale.upscale_order == "correction-first"
):
return (
upscale.with_args(
scale=1,
outscale=1,
),
upscale.with_args(
upscale_order="correction-last",
),
)
else:
return (
None,
upscale,
)
2023-07-01 02:42:24 +00:00
def stage_upscale_correction(
stage: StageParams,
params: ImageParams,
*,
upscale: UpscaleParams,
chain: Optional[ChainPipeline] = None,
pre_stages: Optional[List[PipelineStage]] = None,
post_stages: Optional[List[PipelineStage]] = None,
**kwargs,
) -> ChainPipeline:
2023-02-05 13:53:26 +00:00
"""
This is a convenience method for a chain pipeline that will run upscaling and
correction, based on the `upscale` params.
2023-02-05 13:53:26 +00:00
"""
2023-04-01 21:38:08 +00:00
logger.info(
"staging upscaling and correction pipeline at %s:%s",
2023-04-01 21:38:08 +00:00
upscale.scale,
upscale.outscale,
)
if chain is None:
chain = ChainPipeline()
if pre_stages is not None:
for pre_stage in pre_stages:
chain.append(pre_stage)
upscale_opts = {
**kwargs,
"upscale": upscale,
}
upscale_stage: Optional[PipelineStage] = None
if upscale.scale > 1:
if "bsrgan" in upscale.upscale_model:
bsrgan_params = StageParams(
tile_size=stage.tile_size,
outscale=upscale.outscale,
)
upscale_stage = (UpscaleBSRGANStage(), bsrgan_params, upscale_opts)
elif "esrgan" in upscale.upscale_model:
esrgan_params = StageParams(
tile_size=stage.tile_size,
outscale=upscale.outscale,
2023-02-06 23:26:51 +00:00
)
upscale_stage = (UpscaleRealESRGANStage(), esrgan_params, upscale_opts)
2023-02-05 13:53:26 +00:00
elif "stable-diffusion" in upscale.upscale_model:
2023-01-28 20:56:06 +00:00
mini_tile = min(SizeChart.mini, stage.tile_size)
sd_params = StageParams(tile_size=mini_tile, outscale=upscale.outscale)
upscale_stage = (UpscaleStableDiffusionStage(), sd_params, upscale_opts)
2023-04-10 22:57:42 +00:00
elif "swinir" in upscale.upscale_model:
swinir_params = StageParams(
tile_size=stage.tile_size,
outscale=upscale.outscale,
)
upscale_stage = (UpscaleSwinIRStage(), swinir_params, upscale_opts)
else:
logger.warning("unknown upscaling model: %s", upscale.upscale_model)
correct_stage: Optional[PipelineStage] = None
if upscale.faces:
face_params = StageParams(
2023-02-06 23:26:51 +00:00
tile_size=stage.tile_size, outscale=upscale.face_outscale
)
if upscale.correction_model is None:
logger.warning("no correction model set, skipping")
elif "codeformer" in upscale.correction_model:
correct_stage = (CorrectCodeformerStage(), face_params, upscale_opts)
elif "gfpgan" in upscale.correction_model:
correct_stage = (CorrectGFPGANStage(), face_params, upscale_opts)
else:
logger.warning("unknown correction model: %s", upscale.correction_model)
if upscale.upscale_order == "correction-both":
chain.append(correct_stage)
chain.append(upscale_stage)
chain.append(correct_stage)
elif upscale.upscale_order == "correction-first":
chain.append(correct_stage)
chain.append(upscale_stage)
elif upscale.upscale_order == "correction-last":
chain.append(upscale_stage)
chain.append(correct_stage)
else:
logger.warning("unknown upscaling order: %s", upscale.upscale_order)
if post_stages is not None:
for post_stage in post_stages:
chain.append(post_stage)
return chain